Sage Weil | 1fe60e5 | 2012-07-30 16:23:22 -0700 | [diff] [blame] | 1 | #ifndef __CEPH_FEATURES |
| 2 | #define __CEPH_FEATURES |
| 3 | |
| 4 | /* |
Ilya Dryomov | f179d3b | 2017-06-05 14:44:59 +0200 | [diff] [blame] | 5 | * Each time we reclaim bits for reuse we need to specify another bit |
| 6 | * that, if present, indicates we have the new incarnation of that |
| 7 | * feature. Base case is 1 (first use). |
Sage Weil | 1fe60e5 | 2012-07-30 16:23:22 -0700 | [diff] [blame] | 8 | */ |
Ilya Dryomov | f179d3b | 2017-06-05 14:44:59 +0200 | [diff] [blame] | 9 | #define CEPH_FEATURE_INCARNATION_1 (0ull) |
| 10 | #define CEPH_FEATURE_INCARNATION_2 (1ull<<57) // CEPH_FEATURE_SERVER_JEWEL |
Ilya Dryomov | 2b3e0c9 | 2013-12-24 21:19:24 +0200 | [diff] [blame] | 11 | |
Ilya Dryomov | f179d3b | 2017-06-05 14:44:59 +0200 | [diff] [blame] | 12 | #define DEFINE_CEPH_FEATURE(bit, incarnation, name) \ |
| 13 | const static uint64_t CEPH_FEATURE_##name = (1ULL<<bit); \ |
| 14 | const static uint64_t CEPH_FEATUREMASK_##name = \ |
| 15 | (1ULL<<bit | CEPH_FEATURE_INCARNATION_##incarnation); |
| 16 | |
| 17 | /* this bit is ignored but still advertised by release *when* */ |
| 18 | #define DEFINE_CEPH_FEATURE_DEPRECATED(bit, incarnation, name, when) \ |
| 19 | const static uint64_t DEPRECATED_CEPH_FEATURE_##name = (1ULL<<bit); \ |
| 20 | const static uint64_t DEPRECATED_CEPH_FEATUREMASK_##name = \ |
| 21 | (1ULL<<bit | CEPH_FEATURE_INCARNATION_##incarnation); |
| 22 | |
| 23 | /* |
| 24 | * this bit is ignored by release *unused* and not advertised by |
| 25 | * release *unadvertised* |
| 26 | */ |
| 27 | #define DEFINE_CEPH_FEATURE_RETIRED(bit, inc, name, unused, unadvertised) |
| 28 | |
| 29 | |
| 30 | /* |
| 31 | * test for a feature. this test is safer than a typical mask against |
| 32 | * the bit because it ensures that we have the bit AND the marker for the |
| 33 | * bit's incarnation. this must be used in any case where the features |
| 34 | * bits may include an old meaning of the bit. |
| 35 | */ |
| 36 | #define CEPH_HAVE_FEATURE(x, name) \ |
| 37 | (((x) & (CEPH_FEATUREMASK_##name)) == (CEPH_FEATUREMASK_##name)) |
| 38 | |
| 39 | |
| 40 | /* |
| 41 | * Notes on deprecation: |
| 42 | * |
| 43 | * A *major* release is a release through which all upgrades must pass |
| 44 | * (e.g., jewel). For example, no pre-jewel server will ever talk to |
| 45 | * a post-jewel server (mon, osd, etc). |
| 46 | * |
| 47 | * For feature bits used *only* on the server-side: |
| 48 | * |
| 49 | * - In the first phase we indicate that a feature is DEPRECATED as of |
| 50 | * a particular release. This is the first major release X (say, |
| 51 | * jewel) that does not depend on its peers advertising the feature. |
| 52 | * That is, it safely assumes its peers all have the feature. We |
| 53 | * indicate this with the DEPRECATED macro. For example, |
| 54 | * |
| 55 | * DEFINE_CEPH_FEATURE_DEPRECATED( 2, 1, MONCLOCKCHECK, JEWEL) |
| 56 | * |
| 57 | * because 10.2.z (jewel) did not care if its peers advertised this |
| 58 | * feature bit. |
| 59 | * |
| 60 | * - In the second phase we stop advertising the the bit and call it |
| 61 | * RETIRED. This can normally be done in the *next* major release |
| 62 | * following the one in which we marked the feature DEPRECATED. In |
| 63 | * the above example, for 12.0.z (luminous) we can say: |
| 64 | * |
| 65 | * DEFINE_CEPH_FEATURE_RETIRED( 2, 1, MONCLOCKCHECK, JEWEL, LUMINOUS) |
| 66 | * |
| 67 | * - The bit can be reused in the first post-luminous release, 13.0.z |
| 68 | * (m). |
| 69 | * |
| 70 | * This ensures that no two versions who have different meanings for |
| 71 | * the bit ever speak to each other. |
| 72 | */ |
| 73 | |
| 74 | DEFINE_CEPH_FEATURE( 0, 1, UID) |
| 75 | DEFINE_CEPH_FEATURE( 1, 1, NOSRCADDR) |
| 76 | DEFINE_CEPH_FEATURE_RETIRED( 2, 1, MONCLOCKCHECK, JEWEL, LUMINOUS) |
| 77 | |
| 78 | DEFINE_CEPH_FEATURE( 3, 1, FLOCK) |
| 79 | DEFINE_CEPH_FEATURE( 4, 1, SUBSCRIBE2) |
| 80 | DEFINE_CEPH_FEATURE( 5, 1, MONNAMES) |
| 81 | DEFINE_CEPH_FEATURE( 6, 1, RECONNECT_SEQ) |
| 82 | DEFINE_CEPH_FEATURE( 7, 1, DIRLAYOUTHASH) |
| 83 | DEFINE_CEPH_FEATURE( 8, 1, OBJECTLOCATOR) |
| 84 | DEFINE_CEPH_FEATURE( 9, 1, PGID64) |
| 85 | DEFINE_CEPH_FEATURE(10, 1, INCSUBOSDMAP) |
| 86 | DEFINE_CEPH_FEATURE(11, 1, PGPOOL3) |
| 87 | DEFINE_CEPH_FEATURE(12, 1, OSDREPLYMUX) |
| 88 | DEFINE_CEPH_FEATURE(13, 1, OSDENC) |
| 89 | DEFINE_CEPH_FEATURE_RETIRED(14, 1, OMAP, HAMMER, JEWEL) |
| 90 | DEFINE_CEPH_FEATURE(14, 2, SERVER_KRAKEN) |
| 91 | DEFINE_CEPH_FEATURE(15, 1, MONENC) |
| 92 | DEFINE_CEPH_FEATURE_RETIRED(16, 1, QUERY_T, JEWEL, LUMINOUS) |
| 93 | |
| 94 | DEFINE_CEPH_FEATURE_RETIRED(17, 1, INDEP_PG_MAP, JEWEL, LUMINOUS) |
| 95 | |
| 96 | DEFINE_CEPH_FEATURE(18, 1, CRUSH_TUNABLES) |
| 97 | DEFINE_CEPH_FEATURE_RETIRED(19, 1, CHUNKY_SCRUB, JEWEL, LUMINOUS) |
| 98 | |
| 99 | DEFINE_CEPH_FEATURE_RETIRED(20, 1, MON_NULLROUTE, JEWEL, LUMINOUS) |
| 100 | |
| 101 | DEFINE_CEPH_FEATURE_RETIRED(21, 1, MON_GV, HAMMER, JEWEL) |
| 102 | DEFINE_CEPH_FEATURE(21, 2, SERVER_LUMINOUS) |
| 103 | DEFINE_CEPH_FEATURE(21, 2, RESEND_ON_SPLIT) // overlap |
| 104 | DEFINE_CEPH_FEATURE(21, 2, RADOS_BACKOFF) // overlap |
| 105 | DEFINE_CEPH_FEATURE(21, 2, OSDMAP_PG_UPMAP) // overlap |
| 106 | DEFINE_CEPH_FEATURE(21, 2, CRUSH_CHOOSE_ARGS) // overlap |
| 107 | DEFINE_CEPH_FEATURE_RETIRED(22, 1, BACKFILL_RESERVATION, JEWEL, LUMINOUS) |
| 108 | |
| 109 | DEFINE_CEPH_FEATURE(23, 1, MSG_AUTH) |
| 110 | DEFINE_CEPH_FEATURE_RETIRED(24, 1, RECOVERY_RESERVATION, JEWEL, LUNINOUS) |
| 111 | |
| 112 | DEFINE_CEPH_FEATURE(25, 1, CRUSH_TUNABLES2) |
| 113 | DEFINE_CEPH_FEATURE(26, 1, CREATEPOOLID) |
| 114 | DEFINE_CEPH_FEATURE(27, 1, REPLY_CREATE_INODE) |
| 115 | DEFINE_CEPH_FEATURE_RETIRED(28, 1, OSD_HBMSGS, HAMMER, JEWEL) |
| 116 | DEFINE_CEPH_FEATURE(28, 2, SERVER_M) |
| 117 | DEFINE_CEPH_FEATURE(29, 1, MDSENC) |
| 118 | DEFINE_CEPH_FEATURE(30, 1, OSDHASHPSPOOL) |
| 119 | DEFINE_CEPH_FEATURE(31, 1, MON_SINGLE_PAXOS) // deprecate me |
| 120 | DEFINE_CEPH_FEATURE_RETIRED(32, 1, OSD_SNAPMAPPER, JEWEL, LUMINOUS) |
| 121 | |
| 122 | DEFINE_CEPH_FEATURE_RETIRED(33, 1, MON_SCRUB, JEWEL, LUMINOUS) |
| 123 | |
| 124 | DEFINE_CEPH_FEATURE_RETIRED(34, 1, OSD_PACKED_RECOVERY, JEWEL, LUMINOUS) |
| 125 | |
| 126 | DEFINE_CEPH_FEATURE(35, 1, OSD_CACHEPOOL) |
| 127 | DEFINE_CEPH_FEATURE(36, 1, CRUSH_V2) |
| 128 | DEFINE_CEPH_FEATURE(37, 1, EXPORT_PEER) |
| 129 | DEFINE_CEPH_FEATURE(38, 1, OSD_ERASURE_CODES) |
| 130 | DEFINE_CEPH_FEATURE(38, 1, OSD_OSD_TMAP2OMAP) // overlap |
| 131 | DEFINE_CEPH_FEATURE(39, 1, OSDMAP_ENC) |
| 132 | DEFINE_CEPH_FEATURE(40, 1, MDS_INLINE_DATA) |
| 133 | DEFINE_CEPH_FEATURE(41, 1, CRUSH_TUNABLES3) |
| 134 | DEFINE_CEPH_FEATURE(41, 1, OSD_PRIMARY_AFFINITY) // overlap |
| 135 | DEFINE_CEPH_FEATURE(42, 1, MSGR_KEEPALIVE2) |
| 136 | DEFINE_CEPH_FEATURE(43, 1, OSD_POOLRESEND) |
| 137 | DEFINE_CEPH_FEATURE(44, 1, ERASURE_CODE_PLUGINS_V2) |
| 138 | DEFINE_CEPH_FEATURE_RETIRED(45, 1, OSD_SET_ALLOC_HINT, JEWEL, LUMINOUS) |
| 139 | |
| 140 | DEFINE_CEPH_FEATURE(46, 1, OSD_FADVISE_FLAGS) |
| 141 | DEFINE_CEPH_FEATURE_RETIRED(46, 1, OSD_REPOP, JEWEL, LUMINOUS) // overlap |
| 142 | DEFINE_CEPH_FEATURE_RETIRED(46, 1, OSD_OBJECT_DIGEST, JEWEL, LUMINOUS) // overlap |
| 143 | DEFINE_CEPH_FEATURE_RETIRED(46, 1, OSD_TRANSACTION_MAY_LAYOUT, JEWEL, LUMINOUS) // overlap |
| 144 | |
| 145 | DEFINE_CEPH_FEATURE(47, 1, MDS_QUOTA) |
| 146 | DEFINE_CEPH_FEATURE(48, 1, CRUSH_V4) |
| 147 | DEFINE_CEPH_FEATURE_RETIRED(49, 1, OSD_MIN_SIZE_RECOVERY, JEWEL, LUMINOUS) |
| 148 | DEFINE_CEPH_FEATURE_RETIRED(49, 1, OSD_PROXY_FEATURES, JEWEL, LUMINOUS) // overlap |
| 149 | |
| 150 | DEFINE_CEPH_FEATURE(50, 1, MON_METADATA) |
| 151 | DEFINE_CEPH_FEATURE(51, 1, OSD_BITWISE_HOBJ_SORT) |
| 152 | DEFINE_CEPH_FEATURE(52, 1, OSD_PROXY_WRITE_FEATURES) |
| 153 | DEFINE_CEPH_FEATURE(53, 1, ERASURE_CODE_PLUGINS_V3) |
| 154 | DEFINE_CEPH_FEATURE(54, 1, OSD_HITSET_GMT) |
| 155 | DEFINE_CEPH_FEATURE(55, 1, HAMMER_0_94_4) |
| 156 | DEFINE_CEPH_FEATURE(56, 1, NEW_OSDOP_ENCODING) |
| 157 | DEFINE_CEPH_FEATURE(57, 1, MON_STATEFUL_SUB) |
| 158 | DEFINE_CEPH_FEATURE(57, 1, MON_ROUTE_OSDMAP) // overlap |
| 159 | DEFINE_CEPH_FEATURE(57, 1, OSDSUBOP_NO_SNAPCONTEXT) // overlap |
| 160 | DEFINE_CEPH_FEATURE(57, 1, SERVER_JEWEL) // overlap |
| 161 | DEFINE_CEPH_FEATURE(58, 1, CRUSH_TUNABLES5) |
| 162 | DEFINE_CEPH_FEATURE(58, 1, NEW_OSDOPREPLY_ENCODING) // overlap |
| 163 | DEFINE_CEPH_FEATURE(58, 1, FS_FILE_LAYOUT_V2) // overlap |
| 164 | DEFINE_CEPH_FEATURE(59, 1, FS_BTIME) |
| 165 | DEFINE_CEPH_FEATURE(59, 1, FS_CHANGE_ATTR) // overlap |
| 166 | DEFINE_CEPH_FEATURE(59, 1, MSG_ADDR2) // overlap |
| 167 | DEFINE_CEPH_FEATURE(60, 1, BLKIN_TRACING) // *do not share this bit* |
| 168 | |
| 169 | DEFINE_CEPH_FEATURE(61, 1, RESERVED2) // unused, but slow down! |
| 170 | DEFINE_CEPH_FEATURE(62, 1, RESERVED) // do not use; used as a sentinal |
| 171 | DEFINE_CEPH_FEATURE_DEPRECATED(63, 1, RESERVED_BROKEN, LUMINOUS) // client-facing |
| 172 | |
Ilya Dryomov | 2b3e0c9 | 2013-12-24 21:19:24 +0200 | [diff] [blame] | 173 | |
Sage Weil | 1fe60e5 | 2012-07-30 16:23:22 -0700 | [diff] [blame] | 174 | /* |
| 175 | * Features supported. |
| 176 | */ |
Ilya Dryomov | 2b3e0c9 | 2013-12-24 21:19:24 +0200 | [diff] [blame] | 177 | #define CEPH_FEATURES_SUPPORTED_DEFAULT \ |
Sage Weil | 4f6a7e5 | 2013-02-23 10:41:09 -0800 | [diff] [blame] | 178 | (CEPH_FEATURE_NOSRCADDR | \ |
Ilya Dryomov | 74da4a0f | 2017-03-03 18:16:07 +0100 | [diff] [blame] | 179 | CEPH_FEATURE_FLOCK | \ |
Ilya Dryomov | 82dcaba | 2016-01-19 16:19:06 +0100 | [diff] [blame] | 180 | CEPH_FEATURE_SUBSCRIBE2 | \ |
Sage Weil | 3a23083 | 2013-03-25 08:47:40 -0700 | [diff] [blame] | 181 | CEPH_FEATURE_RECONNECT_SEQ | \ |
Ilya Dryomov | 74da4a0f | 2017-03-03 18:16:07 +0100 | [diff] [blame] | 182 | CEPH_FEATURE_DIRLAYOUTHASH | \ |
Sage Weil | 4f6a7e5 | 2013-02-23 10:41:09 -0800 | [diff] [blame] | 183 | CEPH_FEATURE_PGID64 | \ |
| 184 | CEPH_FEATURE_PGPOOL3 | \ |
| 185 | CEPH_FEATURE_OSDENC | \ |
| 186 | CEPH_FEATURE_CRUSH_TUNABLES | \ |
Ilya Dryomov | 33e9c8d | 2017-06-26 12:05:55 +0200 | [diff] [blame] | 187 | CEPH_FEATURE_SERVER_LUMINOUS | \ |
| 188 | CEPH_FEATURE_RESEND_ON_SPLIT | \ |
| 189 | CEPH_FEATURE_RADOS_BACKOFF | \ |
| 190 | CEPH_FEATURE_OSDMAP_PG_UPMAP | \ |
| 191 | CEPH_FEATURE_CRUSH_CHOOSE_ARGS | \ |
Yan, Zheng | 33d0733 | 2014-11-04 16:33:37 +0800 | [diff] [blame] | 192 | CEPH_FEATURE_MSG_AUTH | \ |
Sage Weil | 4f6a7e5 | 2013-02-23 10:41:09 -0800 | [diff] [blame] | 193 | CEPH_FEATURE_CRUSH_TUNABLES2 | \ |
Sage Weil | 83ca14f | 2013-02-26 10:39:09 -0800 | [diff] [blame] | 194 | CEPH_FEATURE_REPLY_CREATE_INODE | \ |
Ilya Dryomov | 74da4a0f | 2017-03-03 18:16:07 +0100 | [diff] [blame] | 195 | CEPH_FEATURE_MDSENC | \ |
Ilya Dryomov | cdff499 | 2013-12-24 21:19:27 +0200 | [diff] [blame] | 196 | CEPH_FEATURE_OSDHASHPSPOOL | \ |
Ilya Dryomov | 80e163a | 2014-01-27 17:40:20 +0200 | [diff] [blame] | 197 | CEPH_FEATURE_OSD_CACHEPOOL | \ |
Yan, Zheng | 80213a8 | 2014-01-21 11:07:16 +0800 | [diff] [blame] | 198 | CEPH_FEATURE_CRUSH_V2 | \ |
Ilya Dryomov | 07bd7de | 2014-03-19 16:58:37 +0200 | [diff] [blame] | 199 | CEPH_FEATURE_EXPORT_PEER | \ |
Ilya Dryomov | ddf3a21 | 2014-03-21 19:05:31 +0200 | [diff] [blame] | 200 | CEPH_FEATURE_OSDMAP_ENC | \ |
Ilya Dryomov | 74da4a0f | 2017-03-03 18:16:07 +0100 | [diff] [blame] | 201 | CEPH_FEATURE_MDS_INLINE_DATA | \ |
Ilya Dryomov | 18cb95a | 2014-03-24 17:12:50 +0200 | [diff] [blame] | 202 | CEPH_FEATURE_CRUSH_TUNABLES3 | \ |
Ilya Dryomov | 7c1c474 | 2015-04-14 23:13:31 +0300 | [diff] [blame] | 203 | CEPH_FEATURE_OSD_PRIMARY_AFFINITY | \ |
Ilya Dryomov | 335c258 | 2015-09-14 12:44:22 +0300 | [diff] [blame] | 204 | CEPH_FEATURE_MSGR_KEEPALIVE2 | \ |
Ilya Dryomov | 2d7522e | 2017-06-05 14:45:00 +0200 | [diff] [blame] | 205 | CEPH_FEATURE_OSD_POOLRESEND | \ |
Ilya Dryomov | 97db9a8 | 2016-02-01 17:08:33 +0100 | [diff] [blame] | 206 | CEPH_FEATURE_CRUSH_V4 | \ |
Ilya Dryomov | 33e9c8d | 2017-06-26 12:05:55 +0200 | [diff] [blame] | 207 | CEPH_FEATURE_NEW_OSDOP_ENCODING | \ |
Ilya Dryomov | 220abf5 | 2017-06-05 14:45:00 +0200 | [diff] [blame] | 208 | CEPH_FEATURE_SERVER_JEWEL | \ |
| 209 | CEPH_FEATURE_MON_STATEFUL_SUB | \ |
Ilya Dryomov | b0b31a8 | 2016-02-03 15:25:48 +0100 | [diff] [blame] | 210 | CEPH_FEATURE_CRUSH_TUNABLES5 | \ |
| 211 | CEPH_FEATURE_NEW_OSDOPREPLY_ENCODING) |
Sage Weil | 1fe60e5 | 2012-07-30 16:23:22 -0700 | [diff] [blame] | 212 | |
| 213 | #define CEPH_FEATURES_REQUIRED_DEFAULT \ |
Sage Weil | 4f6a7e5 | 2013-02-23 10:41:09 -0800 | [diff] [blame] | 214 | (CEPH_FEATURE_NOSRCADDR | \ |
Ilya Dryomov | 82dcaba | 2016-01-19 16:19:06 +0100 | [diff] [blame] | 215 | CEPH_FEATURE_SUBSCRIBE2 | \ |
Sage Weil | 3a23083 | 2013-03-25 08:47:40 -0700 | [diff] [blame] | 216 | CEPH_FEATURE_RECONNECT_SEQ | \ |
Sage Weil | 4f6a7e5 | 2013-02-23 10:41:09 -0800 | [diff] [blame] | 217 | CEPH_FEATURE_PGID64 | \ |
| 218 | CEPH_FEATURE_PGPOOL3 | \ |
| 219 | CEPH_FEATURE_OSDENC) |
Ilya Dryomov | 2b3e0c9 | 2013-12-24 21:19:24 +0200 | [diff] [blame] | 220 | |
Sage Weil | 1fe60e5 | 2012-07-30 16:23:22 -0700 | [diff] [blame] | 221 | #endif |