diff options
| -rw-r--r-- | net/ceph/osdmap.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/net/ceph/osdmap.c b/net/ceph/osdmap.c index 94f068dda433..e97c3588c3ec 100644 --- a/net/ceph/osdmap.c +++ b/net/ceph/osdmap.c | |||
| @@ -830,15 +830,20 @@ struct ceph_osdmap *osdmap_apply_incremental(void **p, void *end, | |||
| 830 | map->osd_addr[osd] = addr; | 830 | map->osd_addr[osd] = addr; |
| 831 | } | 831 | } |
| 832 | 832 | ||
| 833 | /* new_down */ | 833 | /* new_state */ |
| 834 | ceph_decode_32_safe(p, end, len, bad); | 834 | ceph_decode_32_safe(p, end, len, bad); |
| 835 | while (len--) { | 835 | while (len--) { |
| 836 | u32 osd; | 836 | u32 osd; |
| 837 | u8 xorstate; | ||
| 837 | ceph_decode_32_safe(p, end, osd, bad); | 838 | ceph_decode_32_safe(p, end, osd, bad); |
| 839 | xorstate = **(u8 **)p; | ||
| 838 | (*p)++; /* clean flag */ | 840 | (*p)++; /* clean flag */ |
| 839 | pr_info("osd%d down\n", osd); | 841 | if (xorstate == 0) |
| 842 | xorstate = CEPH_OSD_UP; | ||
| 843 | if (xorstate & CEPH_OSD_UP) | ||
| 844 | pr_info("osd%d down\n", osd); | ||
| 840 | if (osd < map->max_osd) | 845 | if (osd < map->max_osd) |
| 841 | map->osd_state[osd] &= ~CEPH_OSD_UP; | 846 | map->osd_state[osd] ^= xorstate; |
| 842 | } | 847 | } |
| 843 | 848 | ||
| 844 | /* new_weight */ | 849 | /* new_weight */ |
