aboutsummaryrefslogtreecommitdiffstats
path: root/net/ceph/osd_client.c
diff options
context:
space:
mode:
authorAlex Elder <elder@inktank.com>2013-04-05 02:27:12 -0400
committerSage Weil <sage@inktank.com>2013-05-02 00:18:21 -0400
commite65550fd94c5c01b438e24fbf4a29ba65709ec97 (patch)
tree589ea50de6231f616fa3948e7f7e943938ed182f /net/ceph/osd_client.c
parent5f562df5f59340eae4272501b974903f48d2ad92 (diff)
libceph: move ceph_osdc_build_request()
This simply moves ceph_osdc_build_request() later in its source file without any change. Done as a separate patch to facilitate review of the change in the next patch. Signed-off-by: Alex Elder <elder@inktank.com> Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'net/ceph/osd_client.c')
-rw-r--r--net/ceph/osd_client.c196
1 files changed, 98 insertions, 98 deletions
diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c
index db2624860384..3fe8a7909ed9 100644
--- a/net/ceph/osd_client.c
+++ b/net/ceph/osd_client.c
@@ -526,104 +526,6 @@ static u64 osd_req_encode_op(struct ceph_osd_request *req,
526} 526}
527 527
528/* 528/*
529 * build new request AND message
530 *
531 */
532void ceph_osdc_build_request(struct ceph_osd_request *req, u64 off,
533 struct ceph_snap_context *snapc, u64 snap_id,
534 struct timespec *mtime)
535{
536 struct ceph_msg *msg = req->r_request;
537 void *p;
538 size_t msg_size;
539 int flags = req->r_flags;
540 u64 data_len;
541 unsigned int i;
542
543 req->r_snapid = snap_id;
544 req->r_snapc = ceph_get_snap_context(snapc);
545
546 /* encode request */
547 msg->hdr.version = cpu_to_le16(4);
548
549 p = msg->front.iov_base;
550 ceph_encode_32(&p, 1); /* client_inc is always 1 */
551 req->r_request_osdmap_epoch = p;
552 p += 4;
553 req->r_request_flags = p;
554 p += 4;
555 if (req->r_flags & CEPH_OSD_FLAG_WRITE)
556 ceph_encode_timespec(p, mtime);
557 p += sizeof(struct ceph_timespec);
558 req->r_request_reassert_version = p;
559 p += sizeof(struct ceph_eversion); /* will get filled in */
560
561 /* oloc */
562 ceph_encode_8(&p, 4);
563 ceph_encode_8(&p, 4);
564 ceph_encode_32(&p, 8 + 4 + 4);
565 req->r_request_pool = p;
566 p += 8;
567 ceph_encode_32(&p, -1); /* preferred */
568 ceph_encode_32(&p, 0); /* key len */
569
570 ceph_encode_8(&p, 1);
571 req->r_request_pgid = p;
572 p += 8 + 4;
573 ceph_encode_32(&p, -1); /* preferred */
574
575 /* oid */
576 ceph_encode_32(&p, req->r_oid_len);
577 memcpy(p, req->r_oid, req->r_oid_len);
578 dout("oid '%.*s' len %d\n", req->r_oid_len, req->r_oid, req->r_oid_len);
579 p += req->r_oid_len;
580
581 /* ops--can imply data */
582 ceph_encode_16(&p, (u16)req->r_num_ops);
583 data_len = 0;
584 for (i = 0; i < req->r_num_ops; i++) {
585 data_len += osd_req_encode_op(req, p, i);
586 p += sizeof(struct ceph_osd_op);
587 }
588
589 /* snaps */
590 ceph_encode_64(&p, req->r_snapid);
591 ceph_encode_64(&p, req->r_snapc ? req->r_snapc->seq : 0);
592 ceph_encode_32(&p, req->r_snapc ? req->r_snapc->num_snaps : 0);
593 if (req->r_snapc) {
594 for (i = 0; i < snapc->num_snaps; i++) {
595 ceph_encode_64(&p, req->r_snapc->snaps[i]);
596 }
597 }
598
599 req->r_request_attempts = p;
600 p += 4;
601
602 /* data */
603 if (flags & CEPH_OSD_FLAG_WRITE) {
604 u16 data_off;
605
606 /*
607 * The header "data_off" is a hint to the receiver
608 * allowing it to align received data into its
609 * buffers such that there's no need to re-copy
610 * it before writing it to disk (direct I/O).
611 */
612 data_off = (u16) (off & 0xffff);
613 req->r_request->hdr.data_off = cpu_to_le16(data_off);
614 }
615 req->r_request->hdr.data_len = cpu_to_le32(data_len);
616
617 BUG_ON(p > msg->front.iov_base + msg->front.iov_len);
618 msg_size = p - msg->front.iov_base;
619 msg->front.iov_len = msg_size;
620 msg->hdr.front_len = cpu_to_le32(msg_size);
621
622 dout("build_request msg_size was %d\n", (int)msg_size);
623}
624EXPORT_SYMBOL(ceph_osdc_build_request);
625
626/*
627 * build new request AND message, calculate layout, and adjust file 529 * build new request AND message, calculate layout, and adjust file
628 * extent as needed. 530 * extent as needed.
629 * 531 *
@@ -1968,6 +1870,104 @@ static void ceph_osdc_msg_data_set(struct ceph_msg *msg,
1968} 1870}
1969 1871
1970/* 1872/*
1873 * build new request AND message
1874 *
1875 */
1876void ceph_osdc_build_request(struct ceph_osd_request *req, u64 off,
1877 struct ceph_snap_context *snapc, u64 snap_id,
1878 struct timespec *mtime)
1879{
1880 struct ceph_msg *msg = req->r_request;
1881 void *p;
1882 size_t msg_size;
1883 int flags = req->r_flags;
1884 u64 data_len;
1885 unsigned int i;
1886
1887 req->r_snapid = snap_id;
1888 req->r_snapc = ceph_get_snap_context(snapc);
1889
1890 /* encode request */
1891 msg->hdr.version = cpu_to_le16(4);
1892
1893 p = msg->front.iov_base;
1894 ceph_encode_32(&p, 1); /* client_inc is always 1 */
1895 req->r_request_osdmap_epoch = p;
1896 p += 4;
1897 req->r_request_flags = p;
1898 p += 4;
1899 if (req->r_flags & CEPH_OSD_FLAG_WRITE)
1900 ceph_encode_timespec(p, mtime);
1901 p += sizeof(struct ceph_timespec);
1902 req->r_request_reassert_version = p;
1903 p += sizeof(struct ceph_eversion); /* will get filled in */
1904
1905 /* oloc */
1906 ceph_encode_8(&p, 4);
1907 ceph_encode_8(&p, 4);
1908 ceph_encode_32(&p, 8 + 4 + 4);
1909 req->r_request_pool = p;
1910 p += 8;
1911 ceph_encode_32(&p, -1); /* preferred */
1912 ceph_encode_32(&p, 0); /* key len */
1913
1914 ceph_encode_8(&p, 1);
1915 req->r_request_pgid = p;
1916 p += 8 + 4;
1917 ceph_encode_32(&p, -1); /* preferred */
1918
1919 /* oid */
1920 ceph_encode_32(&p, req->r_oid_len);
1921 memcpy(p, req->r_oid, req->r_oid_len);
1922 dout("oid '%.*s' len %d\n", req->r_oid_len, req->r_oid, req->r_oid_len);
1923 p += req->r_oid_len;
1924
1925 /* ops--can imply data */
1926 ceph_encode_16(&p, (u16)req->r_num_ops);
1927 data_len = 0;
1928 for (i = 0; i < req->r_num_ops; i++) {
1929 data_len += osd_req_encode_op(req, p, i);
1930 p += sizeof(struct ceph_osd_op);
1931 }
1932
1933 /* snaps */
1934 ceph_encode_64(&p, req->r_snapid);
1935 ceph_encode_64(&p, req->r_snapc ? req->r_snapc->seq : 0);
1936 ceph_encode_32(&p, req->r_snapc ? req->r_snapc->num_snaps : 0);
1937 if (req->r_snapc) {
1938 for (i = 0; i < snapc->num_snaps; i++) {
1939 ceph_encode_64(&p, req->r_snapc->snaps[i]);
1940 }
1941 }
1942
1943 req->r_request_attempts = p;
1944 p += 4;
1945
1946 /* data */
1947 if (flags & CEPH_OSD_FLAG_WRITE) {
1948 u16 data_off;
1949
1950 /*
1951 * The header "data_off" is a hint to the receiver
1952 * allowing it to align received data into its
1953 * buffers such that there's no need to re-copy
1954 * it before writing it to disk (direct I/O).
1955 */
1956 data_off = (u16) (off & 0xffff);
1957 req->r_request->hdr.data_off = cpu_to_le16(data_off);
1958 }
1959 req->r_request->hdr.data_len = cpu_to_le32(data_len);
1960
1961 BUG_ON(p > msg->front.iov_base + msg->front.iov_len);
1962 msg_size = p - msg->front.iov_base;
1963 msg->front.iov_len = msg_size;
1964 msg->hdr.front_len = cpu_to_le32(msg_size);
1965
1966 dout("build_request msg_size was %d\n", (int)msg_size);
1967}
1968EXPORT_SYMBOL(ceph_osdc_build_request);
1969
1970/*
1971 * Register request, send initial attempt. 1971 * Register request, send initial attempt.
1972 */ 1972 */
1973int ceph_osdc_start_request(struct ceph_osd_client *osdc, 1973int ceph_osdc_start_request(struct ceph_osd_client *osdc,