Lines Matching refs:iocb
829 static ssize_t ceph_sync_read(struct kiocb *iocb, struct iov_iter *to, in ceph_sync_read() argument
832 struct file *file = iocb->ki_filp; in ceph_sync_read()
838 u64 off = iocb->ki_pos; in ceph_sync_read()
945 if (off > iocb->ki_pos) { in ceph_sync_read()
949 ret = off - iocb->ki_pos; in ceph_sync_read()
950 iocb->ki_pos = off; in ceph_sync_read()
958 struct kiocb *iocb; member
986 if (aio_req->iocb->ki_flags & IOCB_DIRECT) in ceph_aio_complete()
998 loff_t endoff = aio_req->iocb->ki_pos + aio_req->total_len; in ceph_aio_complete()
1017 aio_req->iocb->ki_complete(aio_req->iocb, ret, 0); in ceph_aio_complete()
1074 loff_t endoff = aio_req->iocb->ki_pos + rc; in ceph_aio_complete_req()
1167 ceph_direct_read_write(struct kiocb *iocb, struct iov_iter *iter, in ceph_direct_read_write() argument
1171 struct file *file = iocb->ki_filp; in ceph_direct_read_write()
1185 loff_t pos = iocb->ki_pos; in ceph_direct_read_write()
1245 if (pos == iocb->ki_pos && !is_sync_kiocb(iocb) && in ceph_direct_read_write()
1249 aio_req->iocb = iocb; in ceph_direct_read_write()
1363 if (ret != -EOLDSNAPC && pos > iocb->ki_pos) { in ceph_direct_read_write()
1364 ret = pos - iocb->ki_pos; in ceph_direct_read_write()
1365 iocb->ki_pos = pos; in ceph_direct_read_write()
1378 ceph_sync_write(struct kiocb *iocb, struct iov_iter *from, loff_t pos, in ceph_sync_write() argument
1381 struct file *file = iocb->ki_filp; in ceph_sync_write()
1494 iocb->ki_pos = pos; in ceph_sync_write()
1506 static ssize_t ceph_read_iter(struct kiocb *iocb, struct iov_iter *to) in ceph_read_iter() argument
1508 struct file *filp = iocb->ki_filp; in ceph_read_iter()
1514 bool direct_lock = iocb->ki_flags & IOCB_DIRECT; in ceph_read_iter()
1521 inode, ceph_vinop(inode), iocb->ki_pos, (unsigned)len, inode); in ceph_read_iter()
1535 if (iocb->ki_flags & IOCB_DIRECT) in ceph_read_iter()
1543 (iocb->ki_flags & IOCB_DIRECT) || in ceph_read_iter()
1547 inode, ceph_vinop(inode), iocb->ki_pos, (unsigned)len, in ceph_read_iter()
1551 if (!retry_op && (iocb->ki_flags & IOCB_DIRECT)) { in ceph_read_iter()
1552 ret = ceph_direct_read_write(iocb, to, in ceph_read_iter()
1557 ret = ceph_sync_read(iocb, to, &retry_op); in ceph_read_iter()
1565 inode, ceph_vinop(inode), iocb->ki_pos, (unsigned)len, in ceph_read_iter()
1568 ret = generic_file_read_iter(iocb, to); in ceph_read_iter()
1610 if (iocb->ki_pos < i_size && in ceph_read_iter()
1611 iocb->ki_pos < PAGE_SIZE) { in ceph_read_iter()
1613 iocb->ki_pos + len); in ceph_read_iter()
1618 iocb->ki_pos & ~PAGE_MASK, in ceph_read_iter()
1619 end - iocb->ki_pos, to); in ceph_read_iter()
1620 iocb->ki_pos += ret; in ceph_read_iter()
1623 if (iocb->ki_pos < i_size && read < len) { in ceph_read_iter()
1625 i_size - iocb->ki_pos); in ceph_read_iter()
1627 iocb->ki_pos += ret; in ceph_read_iter()
1635 if (retry_op == CHECK_EOF && iocb->ki_pos < i_size && in ceph_read_iter()
1638 ", reading more\n", iocb->ki_pos, i_size); in ceph_read_iter()
1663 static ssize_t ceph_write_iter(struct kiocb *iocb, struct iov_iter *from) in ceph_write_iter() argument
1665 struct file *file = iocb->ki_filp; in ceph_write_iter()
1687 if ((iocb->ki_flags & (IOCB_DIRECT | IOCB_APPEND)) == IOCB_DIRECT) in ceph_write_iter()
1699 if (iocb->ki_flags & IOCB_APPEND) { in ceph_write_iter()
1705 err = generic_write_checks(iocb, from); in ceph_write_iter()
1709 pos = iocb->ki_pos; in ceph_write_iter()
1765 (iocb->ki_flags & IOCB_DIRECT) || (fi->flags & CEPH_F_SYNC) || in ceph_write_iter()
1785 if (iocb->ki_flags & IOCB_DIRECT) in ceph_write_iter()
1786 written = ceph_direct_read_write(iocb, &data, snapc, in ceph_write_iter()
1789 written = ceph_sync_write(iocb, &data, pos, snapc); in ceph_write_iter()
1807 iocb->ki_pos = pos + written; in ceph_write_iter()
1821 if (ceph_quota_is_max_bytes_approaching(inode, iocb->ki_pos)) in ceph_write_iter()
1839 iocb->ki_flags |= IOCB_DSYNC; in ceph_write_iter()
1840 written = generic_write_sync(iocb, written); in ceph_write_iter()