On Wed, 2020-01-29 at 03:27 -0500, xiubli@xxxxxxxxxx wrote: > From: Xiubo Li <xiubli@xxxxxxxxxx> > > Since this helpers are only used by cpeh.ko, let's move it to ceph.ko > and rename to _sync_. > > Signed-off-by: Xiubo Li <xiubli@xxxxxxxxxx> > --- > fs/ceph/addr.c | 86 ++++++++++++++++++++++++++++++++- > include/linux/ceph/osd_client.h | 17 ------- > net/ceph/osd_client.c | 79 ------------------------------ > 3 files changed, 84 insertions(+), 98 deletions(-) > > diff --git a/fs/ceph/addr.c b/fs/ceph/addr.c > index 29d4513eff8c..20e5ebfff389 100644 > --- a/fs/ceph/addr.c > +++ b/fs/ceph/addr.c > @@ -182,6 +182,47 @@ static int ceph_releasepage(struct page *page, gfp_t g) > return !PagePrivate(page); > } > > +/* > + * Read some contiguous pages. If we cross a stripe boundary, shorten > + * *plen. Return number of bytes read, or error. > + */ > +static int ceph_sync_readpages(struct ceph_fs_client *fsc, > + struct ceph_vino vino, > + struct ceph_file_layout *layout, > + u64 off, u64 *plen, > + u32 truncate_seq, u64 truncate_size, > + struct page **pages, int num_pages, > + int page_align) > +{ > + struct ceph_osd_client *osdc = &fsc->client->osdc; > + struct ceph_osd_request *req; > + int rc = 0; > + > + dout("readpages on ino %llx.%llx on %llu~%llu\n", vino.ino, > + vino.snap, off, *plen); > + req = ceph_osdc_new_request(osdc, layout, vino, off, plen, 0, 1, > + CEPH_OSD_OP_READ, CEPH_OSD_FLAG_READ, > + NULL, truncate_seq, truncate_size, > + false); > + if (IS_ERR(req)) > + return PTR_ERR(req); > + > + /* it may be a short read due to an object boundary */ > + osd_req_op_extent_osd_data_pages(req, 0, > + pages, *plen, page_align, false, false); > + > + dout("readpages final extent is %llu~%llu (%llu bytes align %d)\n", > + off, *plen, *plen, page_align); > + > + rc = ceph_osdc_start_request(osdc, req, false); > + if (!rc) > + rc = ceph_osdc_wait_request(osdc, req); > + > + ceph_osdc_put_request(req); > + dout("readpages result %d\n", rc); > + return rc; > +} > + > /* > * read a single page, without unlocking it. > */ > @@ -218,7 +259,7 @@ static int ceph_do_readpage(struct file *filp, struct page *page) > > dout("readpage inode %p file %p page %p index %lu\n", > inode, filp, page, page->index); > - err = ceph_osdc_readpages(&fsc->client->osdc, ceph_vino(inode), > + err = ceph_sync_readpages(fsc, ceph_vino(inode), > &ci->i_layout, off, &len, > ci->i_truncate_seq, ci->i_truncate_size, > &page, 1, 0); > @@ -570,6 +611,47 @@ static u64 get_writepages_data_length(struct inode *inode, > return end > start ? end - start : 0; > } > > +/* > + * do a synchronous write on N pages > + */ > +static int ceph_sync_writepages(struct ceph_fs_client *fsc, > + struct ceph_vino vino, > + struct ceph_file_layout *layout, > + struct ceph_snap_context *snapc, > + u64 off, u64 len, > + u32 truncate_seq, u64 truncate_size, > + struct timespec64 *mtime, > + struct page **pages, int num_pages) > +{ > + struct ceph_osd_client *osdc = &fsc->client->osdc; > + struct ceph_osd_request *req; > + int rc = 0; > + int page_align = off & ~PAGE_MASK; > + > + req = ceph_osdc_new_request(osdc, layout, vino, off, &len, 0, 1, > + CEPH_OSD_OP_WRITE, CEPH_OSD_FLAG_WRITE, > + snapc, truncate_seq, truncate_size, > + true); > + if (IS_ERR(req)) > + return PTR_ERR(req); > + > + /* it may be a short write due to an object boundary */ > + osd_req_op_extent_osd_data_pages(req, 0, pages, len, page_align, > + false, false); > + dout("writepages %llu~%llu (%llu bytes)\n", off, len, len); > + > + req->r_mtime = *mtime; > + rc = ceph_osdc_start_request(osdc, req, true); > + if (!rc) > + rc = ceph_osdc_wait_request(osdc, req); > + > + ceph_osdc_put_request(req); > + if (rc == 0) > + rc = len; > + dout("writepages result %d\n", rc); > + return rc; > +} > + > /* > * Write a single page, but leave the page locked. > * > @@ -628,7 +710,7 @@ static int writepage_nounlock(struct page *page, struct writeback_control *wbc) > set_bdi_congested(inode_to_bdi(inode), BLK_RW_ASYNC); > > set_page_writeback(page); > - err = ceph_osdc_writepages(&fsc->client->osdc, ceph_vino(inode), > + err = ceph_sync_writepages(fsc, ceph_vino(inode), > &ci->i_layout, snapc, page_off, len, > ceph_wbc.truncate_seq, > ceph_wbc.truncate_size, > diff --git a/include/linux/ceph/osd_client.h b/include/linux/ceph/osd_client.h > index 5a62dbd3f4c2..9d9f745b98a1 100644 > --- a/include/linux/ceph/osd_client.h > +++ b/include/linux/ceph/osd_client.h > @@ -509,23 +509,6 @@ int ceph_osdc_call(struct ceph_osd_client *osdc, > struct page *req_page, size_t req_len, > struct page **resp_pages, size_t *resp_len); > > -extern int ceph_osdc_readpages(struct ceph_osd_client *osdc, > - struct ceph_vino vino, > - struct ceph_file_layout *layout, > - u64 off, u64 *plen, > - u32 truncate_seq, u64 truncate_size, > - struct page **pages, int nr_pages, > - int page_align); > - > -extern int ceph_osdc_writepages(struct ceph_osd_client *osdc, > - struct ceph_vino vino, > - struct ceph_file_layout *layout, > - struct ceph_snap_context *sc, > - u64 off, u64 len, > - u32 truncate_seq, u64 truncate_size, > - struct timespec64 *mtime, > - struct page **pages, int nr_pages); > - > int ceph_osdc_copy_from(struct ceph_osd_client *osdc, > u64 src_snapid, u64 src_version, > struct ceph_object_id *src_oid, > diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c > index b68b376d8c2f..8ff2856e2d52 100644 > --- a/net/ceph/osd_client.c > +++ b/net/ceph/osd_client.c > @@ -5230,85 +5230,6 @@ void ceph_osdc_stop(struct ceph_osd_client *osdc) > ceph_msgpool_destroy(&osdc->msgpool_op_reply); > } > > -/* > - * Read some contiguous pages. If we cross a stripe boundary, shorten > - * *plen. Return number of bytes read, or error. > - */ > -int ceph_osdc_readpages(struct ceph_osd_client *osdc, > - struct ceph_vino vino, struct ceph_file_layout *layout, > - u64 off, u64 *plen, > - u32 truncate_seq, u64 truncate_size, > - struct page **pages, int num_pages, int page_align) > -{ > - struct ceph_osd_request *req; > - int rc = 0; > - > - dout("readpages on ino %llx.%llx on %llu~%llu\n", vino.ino, > - vino.snap, off, *plen); > - req = ceph_osdc_new_request(osdc, layout, vino, off, plen, 0, 1, > - CEPH_OSD_OP_READ, CEPH_OSD_FLAG_READ, > - NULL, truncate_seq, truncate_size, > - false); > - if (IS_ERR(req)) > - return PTR_ERR(req); > - > - /* it may be a short read due to an object boundary */ > - osd_req_op_extent_osd_data_pages(req, 0, > - pages, *plen, page_align, false, false); > - > - dout("readpages final extent is %llu~%llu (%llu bytes align %d)\n", > - off, *plen, *plen, page_align); > - > - rc = ceph_osdc_start_request(osdc, req, false); > - if (!rc) > - rc = ceph_osdc_wait_request(osdc, req); > - > - ceph_osdc_put_request(req); > - dout("readpages result %d\n", rc); > - return rc; > -} > -EXPORT_SYMBOL(ceph_osdc_readpages); > - > -/* > - * do a synchronous write on N pages > - */ > -int ceph_osdc_writepages(struct ceph_osd_client *osdc, struct ceph_vino vino, > - struct ceph_file_layout *layout, > - struct ceph_snap_context *snapc, > - u64 off, u64 len, > - u32 truncate_seq, u64 truncate_size, > - struct timespec64 *mtime, > - struct page **pages, int num_pages) > -{ > - struct ceph_osd_request *req; > - int rc = 0; > - int page_align = off & ~PAGE_MASK; > - > - req = ceph_osdc_new_request(osdc, layout, vino, off, &len, 0, 1, > - CEPH_OSD_OP_WRITE, CEPH_OSD_FLAG_WRITE, > - snapc, truncate_seq, truncate_size, > - true); > - if (IS_ERR(req)) > - return PTR_ERR(req); > - > - /* it may be a short write due to an object boundary */ > - osd_req_op_extent_osd_data_pages(req, 0, pages, len, page_align, > - false, false); > - dout("writepages %llu~%llu (%llu bytes)\n", off, len, len); > - > - req->r_mtime = *mtime; > - rc = ceph_osdc_start_request(osdc, req, true); > - if (!rc) > - rc = ceph_osdc_wait_request(osdc, req); > - > - ceph_osdc_put_request(req); > - if (rc == 0) > - rc = len; > - dout("writepages result %d\n", rc); > - return rc; > -} > -EXPORT_SYMBOL(ceph_osdc_writepages); > - > static int osd_req_op_copy_from_init(struct ceph_osd_request *req, > u64 src_snapid, u64 src_version, > struct ceph_object_id *src_oid, This looks like a nice cleanup. I'll plan to merge this one after a bit of testing. -- Jeff Layton <jlayton@xxxxxxxxxx>