ceph: move ceph_osdc_{read,write}pages to ceph.ko
Since these helpers are only used by ceph.ko, move them there and rename them with _sync_ qualifiers. Signed-off-by: Xiubo Li <xiubli@redhat.com> Reviewed-by: Jeff Layton <jlayton@kernel.org> Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
This commit is contained in:
		| @@ -5228,85 +5228,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, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user