@@ -140,6 +140,8 @@ static const char *const obd_connect_names[] = {
"mkdir_replay", /* 0x10000000 */
"dmv_imp_inherit", /* 0x20000000 */
"encryption_fid2path", /* 0x40000000 */
+ "large_nid", /* 0x100000000 */
+ "compressed_file", /* 0x200000000 */
NULL
};
@@ -1768,9 +1768,11 @@ void lustre_swab_connect(struct obd_connect_data *ocd)
__swab16s(&ocd->ocd_maxmodrpcs);
BUILD_BUG_ON(!offsetof(typeof(*ocd), padding0));
BUILD_BUG_ON(offsetof(typeof(*ocd), padding1) == 0);
- if (ocd->ocd_connect_flags & OBD_CONNECT_FLAGS2)
+ if (ocd->ocd_connect_flags & OBD_CONNECT_FLAGS2) {
__swab64s(&ocd->ocd_connect_flags2);
- BUILD_BUG_ON(offsetof(typeof(*ocd), padding3) == 0);
+ if (ocd->ocd_connect_flags2 & OBD_CONNECT2_COMPRESS)
+ __swab64s(&ocd->ocd_compr_type);
+ }
BUILD_BUG_ON(offsetof(typeof(*ocd), padding4) == 0);
BUILD_BUG_ON(offsetof(typeof(*ocd), padding5) == 0);
BUILD_BUG_ON(offsetof(typeof(*ocd), padding6) == 0);
@@ -1025,10 +1025,10 @@ void lustre_assert_wire_constants(void)
(long long)(int)offsetof(struct obd_connect_data, ocd_connect_flags2));
LASSERTF((int)sizeof(((struct obd_connect_data *)0)->ocd_connect_flags2) == 8, "found %lld\n",
(long long)(int)sizeof(((struct obd_connect_data *)0)->ocd_connect_flags2));
- LASSERTF((int)offsetof(struct obd_connect_data, padding3) == 88, "found %lld\n",
- (long long)(int)offsetof(struct obd_connect_data, padding3));
- LASSERTF((int)sizeof(((struct obd_connect_data *)0)->padding3) == 8, "found %lld\n",
- (long long)(int)sizeof(((struct obd_connect_data *)0)->padding3));
+ LASSERTF((int)offsetof(struct obd_connect_data, ocd_compr_type) == 88, "found %lld\n",
+ (long long)(int)offsetof(struct obd_connect_data, ocd_compr_type));
+ LASSERTF((int)sizeof(((struct obd_connect_data *)0)->ocd_compr_type) == 8, "found %lld\n",
+ (long long)(int)sizeof(((struct obd_connect_data *)0)->ocd_compr_type));
LASSERTF((int)offsetof(struct obd_connect_data, padding4) == 96, "found %lld\n",
(long long)(int)offsetof(struct obd_connect_data, padding4));
LASSERTF((int)sizeof(((struct obd_connect_data *)0)->padding4) == 8, "found %lld\n",
@@ -1255,6 +1255,11 @@ void lustre_assert_wire_constants(void)
OBD_CONNECT2_DMV_IMP_INHERIT);
LASSERTF(OBD_CONNECT2_ENCRYPT_FID2PATH == 0x40000000ULL, "found 0x%.16llxULL\n",
OBD_CONNECT2_ENCRYPT_FID2PATH);
+ LASSERTF(OBD_CONNECT2_LARGE_NID == 0x100000000ULL, "found 0x%.16llxULL\n",
+ OBD_CONNECT2_LARGE_NID);
+ LASSERTF(OBD_CONNECT2_COMPRESS == 0x200000000ULL, "found 0x%.16llxULL\n",
+ OBD_CONNECT2_COMPRESS);
+
LASSERTF(OBD_CKSUM_CRC32 == 0x00000001UL, "found 0x%.8xUL\n",
(unsigned int)OBD_CKSUM_CRC32);
LASSERTF(OBD_CKSUM_ADLER == 0x00000002UL, "found 0x%.8xUL\n",
@@ -788,6 +788,8 @@ struct ptlrpc_body_v2 {
#define OBD_CONNECT2_ENCRYPT_NAME 0x8000000ULL /* name encrypt */
#define OBD_CONNECT2_DMV_IMP_INHERIT 0x20000000ULL /* client handle DMV inheritance */
#define OBD_CONNECT2_ENCRYPT_FID2PATH 0x40000000ULL /* fid2path enc file */
+#define OBD_CONNECT2_LARGE_NID 0x100000000ULL /* understands large/IPv6 NIDs */
+#define OBD_CONNECT2_COMPRESS 0x200000000ULL /* compressed file */
/* XXX README XXX README XXX README XXX README XXX README XXX README XXX
* Please DO NOT add OBD_CONNECT flags before first ensuring that this value
* is not in use by some other branch/patch. Email adilger@whamcloud.com
@@ -839,7 +841,7 @@ struct obd_connect_data {
__u16 padding0; /* READ BELOW! also fix lustre_swab_connect */
__u32 padding1; /* READ BELOW! also fix lustre_swab_connect */
__u64 ocd_connect_flags2;/* OBD_CONNECT2_* per above */
- __u64 padding3; /* READ BELOW! also fix lustre_swab_connect */
+ __u64 ocd_compr_type; /* bitmask of supported compression types */
__u64 padding4; /* READ BELOW! also fix lustre_swab_connect */
__u64 padding5; /* READ BELOW! also fix lustre_swab_connect */
__u64 padding6; /* READ BELOW! also fix lustre_swab_connect */