diff options
author | Sage Weil <sage@newdream.net> | 2009-11-03 18:17:56 -0500 |
---|---|---|
committer | Sage Weil <sage@newdream.net> | 2009-11-03 18:17:56 -0500 |
commit | 63f2d211954b790fea0a9caeae605c7956535af6 (patch) | |
tree | b49257aa54d9657539eeba014f9ff5f91f8495de | |
parent | 859e7b149362475672e2a996f29b8f45cbb34d82 (diff) |
ceph: use fixed endian encoding for ceph_entity_addr
We exchange struct ceph_entity_addr over the wire and store it on disk.
The sockaddr_storage.ss_family field, however, is host endianness. So,
fix ss_family endianness to big endian when sending/receiving over the
wire.
Signed-off-by: Sage Weil <sage@newdream.net>
-rw-r--r-- | fs/ceph/decode.h | 16 | ||||
-rw-r--r-- | fs/ceph/mdsmap.c | 1 | ||||
-rw-r--r-- | fs/ceph/messenger.c | 23 | ||||
-rw-r--r-- | fs/ceph/messenger.h | 1 | ||||
-rw-r--r-- | fs/ceph/mon_client.c | 2 | ||||
-rw-r--r-- | fs/ceph/msgr.h | 2 | ||||
-rw-r--r-- | fs/ceph/osdmap.c | 3 |
7 files changed, 40 insertions, 8 deletions
diff --git a/fs/ceph/decode.h b/fs/ceph/decode.h index 91179fb2cc3f..a382aecc55bb 100644 --- a/fs/ceph/decode.h +++ b/fs/ceph/decode.h | |||
@@ -76,19 +76,31 @@ static inline void ceph_decode_copy(void **p, void *pv, size_t n) | |||
76 | * struct ceph_timespec <-> struct timespec | 76 | * struct ceph_timespec <-> struct timespec |
77 | */ | 77 | */ |
78 | static inline void ceph_decode_timespec(struct timespec *ts, | 78 | static inline void ceph_decode_timespec(struct timespec *ts, |
79 | struct ceph_timespec *tv) | 79 | const struct ceph_timespec *tv) |
80 | { | 80 | { |
81 | ts->tv_sec = le32_to_cpu(tv->tv_sec); | 81 | ts->tv_sec = le32_to_cpu(tv->tv_sec); |
82 | ts->tv_nsec = le32_to_cpu(tv->tv_nsec); | 82 | ts->tv_nsec = le32_to_cpu(tv->tv_nsec); |
83 | } | 83 | } |
84 | static inline void ceph_encode_timespec(struct ceph_timespec *tv, | 84 | static inline void ceph_encode_timespec(struct ceph_timespec *tv, |
85 | struct timespec *ts) | 85 | const struct timespec *ts) |
86 | { | 86 | { |
87 | tv->tv_sec = cpu_to_le32(ts->tv_sec); | 87 | tv->tv_sec = cpu_to_le32(ts->tv_sec); |
88 | tv->tv_nsec = cpu_to_le32(ts->tv_nsec); | 88 | tv->tv_nsec = cpu_to_le32(ts->tv_nsec); |
89 | } | 89 | } |
90 | 90 | ||
91 | /* | 91 | /* |
92 | * sockaddr_storage <-> ceph_sockaddr | ||
93 | */ | ||
94 | static inline void ceph_encode_addr(struct ceph_entity_addr *a) | ||
95 | { | ||
96 | a->in_addr.ss_family = htons(a->in_addr.ss_family); | ||
97 | } | ||
98 | static inline void ceph_decode_addr(struct ceph_entity_addr *a) | ||
99 | { | ||
100 | a->in_addr.ss_family = ntohs(a->in_addr.ss_family); | ||
101 | } | ||
102 | |||
103 | /* | ||
92 | * encoders | 104 | * encoders |
93 | */ | 105 | */ |
94 | static inline void ceph_encode_64(void **p, u64 v) | 106 | static inline void ceph_encode_64(void **p, u64 v) |
diff --git a/fs/ceph/mdsmap.c b/fs/ceph/mdsmap.c index 80daea064470..4226c810ce22 100644 --- a/fs/ceph/mdsmap.c +++ b/fs/ceph/mdsmap.c | |||
@@ -86,6 +86,7 @@ struct ceph_mdsmap *ceph_mdsmap_decode(void **p, void *end) | |||
86 | 86 | ||
87 | ceph_decode_need(p, end, sizeof(addr) + 1 + sizeof(u32), bad); | 87 | ceph_decode_need(p, end, sizeof(addr) + 1 + sizeof(u32), bad); |
88 | ceph_decode_copy(p, &addr, sizeof(addr)); | 88 | ceph_decode_copy(p, &addr, sizeof(addr)); |
89 | ceph_decode_addr(&addr); | ||
89 | infoversion = ceph_decode_8(p); | 90 | infoversion = ceph_decode_8(p); |
90 | namelen = ceph_decode_32(p); /* skip mds name */ | 91 | namelen = ceph_decode_32(p); /* skip mds name */ |
91 | *p += namelen; | 92 | *p += namelen; |
diff --git a/fs/ceph/messenger.c b/fs/ceph/messenger.c index b48abc0b3be7..6ff44bbddf67 100644 --- a/fs/ceph/messenger.c +++ b/fs/ceph/messenger.c | |||
@@ -12,6 +12,7 @@ | |||
12 | 12 | ||
13 | #include "super.h" | 13 | #include "super.h" |
14 | #include "messenger.h" | 14 | #include "messenger.h" |
15 | #include "decode.h" | ||
15 | 16 | ||
16 | /* | 17 | /* |
17 | * Ceph uses the messenger to exchange ceph_msg messages with other | 18 | * Ceph uses the messenger to exchange ceph_msg messages with other |
@@ -97,6 +98,12 @@ const char *pr_addr(const struct sockaddr_storage *ss) | |||
97 | return s; | 98 | return s; |
98 | } | 99 | } |
99 | 100 | ||
101 | static void encode_my_addr(struct ceph_messenger *msgr) | ||
102 | { | ||
103 | memcpy(&msgr->my_enc_addr, &msgr->inst.addr, sizeof(msgr->my_enc_addr)); | ||
104 | ceph_encode_addr(&msgr->my_enc_addr); | ||
105 | } | ||
106 | |||
100 | /* | 107 | /* |
101 | * work queue for all reading and writing to/from the socket. | 108 | * work queue for all reading and writing to/from the socket. |
102 | */ | 109 | */ |
@@ -590,12 +597,12 @@ static void prepare_write_connect(struct ceph_messenger *msgr, | |||
590 | 597 | ||
591 | con->out_kvec[0].iov_base = CEPH_BANNER; | 598 | con->out_kvec[0].iov_base = CEPH_BANNER; |
592 | con->out_kvec[0].iov_len = len; | 599 | con->out_kvec[0].iov_len = len; |
593 | con->out_kvec[1].iov_base = &msgr->inst.addr; | 600 | con->out_kvec[1].iov_base = &msgr->my_enc_addr; |
594 | con->out_kvec[1].iov_len = sizeof(msgr->inst.addr); | 601 | con->out_kvec[1].iov_len = sizeof(msgr->my_enc_addr); |
595 | con->out_kvec[2].iov_base = &con->out_connect; | 602 | con->out_kvec[2].iov_base = &con->out_connect; |
596 | con->out_kvec[2].iov_len = sizeof(con->out_connect); | 603 | con->out_kvec[2].iov_len = sizeof(con->out_connect); |
597 | con->out_kvec_left = 3; | 604 | con->out_kvec_left = 3; |
598 | con->out_kvec_bytes = len + sizeof(msgr->inst.addr) + | 605 | con->out_kvec_bytes = len + sizeof(msgr->my_enc_addr) + |
599 | sizeof(con->out_connect); | 606 | sizeof(con->out_connect); |
600 | con->out_kvec_cur = con->out_kvec; | 607 | con->out_kvec_cur = con->out_kvec; |
601 | con->out_more = 0; | 608 | con->out_more = 0; |
@@ -976,6 +983,9 @@ static int process_connect(struct ceph_connection *con) | |||
976 | if (verify_hello(con) < 0) | 983 | if (verify_hello(con) < 0) |
977 | return -1; | 984 | return -1; |
978 | 985 | ||
986 | ceph_decode_addr(&con->actual_peer_addr); | ||
987 | ceph_decode_addr(&con->peer_addr_for_me); | ||
988 | |||
979 | /* | 989 | /* |
980 | * Make sure the other end is who we wanted. note that the other | 990 | * Make sure the other end is who we wanted. note that the other |
981 | * end may not yet know their ip address, so if it's 0.0.0.0, give | 991 | * end may not yet know their ip address, so if it's 0.0.0.0, give |
@@ -1005,6 +1015,7 @@ static int process_connect(struct ceph_connection *con) | |||
1005 | &con->peer_addr_for_me.in_addr, | 1015 | &con->peer_addr_for_me.in_addr, |
1006 | sizeof(con->peer_addr_for_me.in_addr)); | 1016 | sizeof(con->peer_addr_for_me.in_addr)); |
1007 | addr_set_port(&con->msgr->inst.addr.in_addr, port); | 1017 | addr_set_port(&con->msgr->inst.addr.in_addr, port); |
1018 | encode_my_addr(con->msgr); | ||
1008 | dout("process_connect learned my addr is %s\n", | 1019 | dout("process_connect learned my addr is %s\n", |
1009 | pr_addr(&con->msgr->inst.addr.in_addr)); | 1020 | pr_addr(&con->msgr->inst.addr.in_addr)); |
1010 | } | 1021 | } |
@@ -1780,6 +1791,7 @@ struct ceph_messenger *ceph_messenger_create(struct ceph_entity_addr *myaddr) | |||
1780 | /* select a random nonce */ | 1791 | /* select a random nonce */ |
1781 | get_random_bytes(&msgr->inst.addr.nonce, | 1792 | get_random_bytes(&msgr->inst.addr.nonce, |
1782 | sizeof(msgr->inst.addr.nonce)); | 1793 | sizeof(msgr->inst.addr.nonce)); |
1794 | encode_my_addr(msgr); | ||
1783 | 1795 | ||
1784 | dout("messenger_create %p\n", msgr); | 1796 | dout("messenger_create %p\n", msgr); |
1785 | return msgr; | 1797 | return msgr; |
@@ -1806,8 +1818,9 @@ void ceph_con_send(struct ceph_connection *con, struct ceph_msg *msg) | |||
1806 | } | 1818 | } |
1807 | 1819 | ||
1808 | /* set src+dst */ | 1820 | /* set src+dst */ |
1809 | msg->hdr.src = con->msgr->inst; | 1821 | msg->hdr.src.name = con->msgr->inst.name; |
1810 | msg->hdr.orig_src = con->msgr->inst; | 1822 | msg->hdr.src.addr = con->msgr->my_enc_addr; |
1823 | msg->hdr.orig_src = msg->hdr.src; | ||
1811 | msg->hdr.dst_erank = con->peer_addr.erank; | 1824 | msg->hdr.dst_erank = con->peer_addr.erank; |
1812 | 1825 | ||
1813 | /* queue */ | 1826 | /* queue */ |
diff --git a/fs/ceph/messenger.h b/fs/ceph/messenger.h index dcd98b64dca9..e016fa7cf970 100644 --- a/fs/ceph/messenger.h +++ b/fs/ceph/messenger.h | |||
@@ -53,6 +53,7 @@ extern const char *ceph_name_type_str(int t); | |||
53 | 53 | ||
54 | struct ceph_messenger { | 54 | struct ceph_messenger { |
55 | struct ceph_entity_inst inst; /* my name+address */ | 55 | struct ceph_entity_inst inst; /* my name+address */ |
56 | struct ceph_entity_addr my_enc_addr; | ||
56 | struct page *zero_page; /* used in certain error cases */ | 57 | struct page *zero_page; /* used in certain error cases */ |
57 | 58 | ||
58 | bool nocrc; | 59 | bool nocrc; |
diff --git a/fs/ceph/mon_client.c b/fs/ceph/mon_client.c index 61263c99c6a8..95b76e761e18 100644 --- a/fs/ceph/mon_client.c +++ b/fs/ceph/mon_client.c | |||
@@ -59,6 +59,8 @@ struct ceph_monmap *ceph_monmap_decode(void *p, void *end) | |||
59 | m->epoch = epoch; | 59 | m->epoch = epoch; |
60 | m->num_mon = num_mon; | 60 | m->num_mon = num_mon; |
61 | ceph_decode_copy(&p, m->mon_inst, num_mon*sizeof(m->mon_inst[0])); | 61 | ceph_decode_copy(&p, m->mon_inst, num_mon*sizeof(m->mon_inst[0])); |
62 | for (i = 0; i < num_mon; i++) | ||
63 | ceph_decode_addr(&m->mon_inst[i].addr); | ||
62 | 64 | ||
63 | dout("monmap_decode epoch %d, num_mon %d\n", m->epoch, | 65 | dout("monmap_decode epoch %d, num_mon %d\n", m->epoch, |
64 | m->num_mon); | 66 | m->num_mon); |
diff --git a/fs/ceph/msgr.h b/fs/ceph/msgr.h index 9abc879e25b1..8e3ea2eb1bf5 100644 --- a/fs/ceph/msgr.h +++ b/fs/ceph/msgr.h | |||
@@ -21,7 +21,7 @@ | |||
21 | * whenever the wire protocol changes. try to keep this string length | 21 | * whenever the wire protocol changes. try to keep this string length |
22 | * constant. | 22 | * constant. |
23 | */ | 23 | */ |
24 | #define CEPH_BANNER "ceph v022" | 24 | #define CEPH_BANNER "ceph v023" |
25 | #define CEPH_BANNER_MAX_LEN 30 | 25 | #define CEPH_BANNER_MAX_LEN 30 |
26 | 26 | ||
27 | 27 | ||
diff --git a/fs/ceph/osdmap.c b/fs/ceph/osdmap.c index d62e111b8a34..cd7bb265d789 100644 --- a/fs/ceph/osdmap.c +++ b/fs/ceph/osdmap.c | |||
@@ -460,6 +460,8 @@ struct ceph_osdmap *osdmap_decode(void **p, void *end) | |||
460 | 460 | ||
461 | *p += 4; /* skip length field (should match max) */ | 461 | *p += 4; /* skip length field (should match max) */ |
462 | ceph_decode_copy(p, map->osd_addr, map->max_osd*sizeof(*map->osd_addr)); | 462 | ceph_decode_copy(p, map->osd_addr, map->max_osd*sizeof(*map->osd_addr)); |
463 | for (i = 0; i < map->max_osd; i++) | ||
464 | ceph_decode_addr(&map->osd_addr[i]); | ||
463 | 465 | ||
464 | /* pg_temp */ | 466 | /* pg_temp */ |
465 | ceph_decode_32_safe(p, end, len, bad); | 467 | ceph_decode_32_safe(p, end, len, bad); |
@@ -619,6 +621,7 @@ struct ceph_osdmap *osdmap_apply_incremental(void **p, void *end, | |||
619 | struct ceph_entity_addr addr; | 621 | struct ceph_entity_addr addr; |
620 | ceph_decode_32_safe(p, end, osd, bad); | 622 | ceph_decode_32_safe(p, end, osd, bad); |
621 | ceph_decode_copy_safe(p, end, &addr, sizeof(addr), bad); | 623 | ceph_decode_copy_safe(p, end, &addr, sizeof(addr), bad); |
624 | ceph_decode_addr(&addr); | ||
622 | pr_info("osd%d up\n", osd); | 625 | pr_info("osd%d up\n", osd); |
623 | BUG_ON(osd >= map->max_osd); | 626 | BUG_ON(osd >= map->max_osd); |
624 | map->osd_state[osd] |= CEPH_OSD_UP; | 627 | map->osd_state[osd] |= CEPH_OSD_UP; |