diff options
author | Sage Weil <sage@inktank.com> | 2013-02-26 13:39:09 -0500 |
---|---|---|
committer | Sage Weil <sage@inktank.com> | 2013-02-26 18:03:06 -0500 |
commit | 83ca14fdd35821554058e5fd4fa7b118ee504a33 (patch) | |
tree | 8f105c71b91854c68db4281f255723356e709ccd /include/linux/ceph/osdmap.h | |
parent | 1b83bef24c6746a146d39915a18fb5425f2facb0 (diff) |
libceph: add support for HASHPSPOOL pool flag
The legacy behavior adds the pgid seed and pool together as the input for
CRUSH. That is problematic because each pool's PGs end up mapping to the
same OSDs: 1.5 == 2.4 == 3.3 == ...
Instead, if the HASHPSPOOL flag is set, we has the ps and pool together and
feed that into CRUSH. This ensures that two adjacent pools will map to
an independent pseudorandom set of OSDs.
Advertise our support for this via a protocol feature flag.
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Alex Elder <elder@inktank.com>
Diffstat (limited to 'include/linux/ceph/osdmap.h')
-rw-r--r-- | include/linux/ceph/osdmap.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/include/linux/ceph/osdmap.h b/include/linux/ceph/osdmap.h index 35985125f118..c819190d1642 100644 --- a/include/linux/ceph/osdmap.h +++ b/include/linux/ceph/osdmap.h | |||
@@ -23,6 +23,8 @@ struct ceph_pg { | |||
23 | uint32_t seed; | 23 | uint32_t seed; |
24 | }; | 24 | }; |
25 | 25 | ||
26 | #define CEPH_POOL_FLAG_HASHPSPOOL 1 | ||
27 | |||
26 | struct ceph_pg_pool_info { | 28 | struct ceph_pg_pool_info { |
27 | struct rb_node node; | 29 | struct rb_node node; |
28 | s64 id; | 30 | s64 id; |