提交 509100e6 编写于 作者: A Andreas Gruenbacher 提交者: Philipp Reisner

drbd: Output signed / unsigned netlink fields correctly

Note: All input values are still treated as signed; unsigned long long values
are still broken.
Signed-off-by: NPhilipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: NLars Ellenberg <lars.ellenberg@linbit.com>
上级 309f0b70
...@@ -78,12 +78,13 @@ static struct nla_policy s_name ## _nl_policy[] __read_mostly = \ ...@@ -78,12 +78,13 @@ static struct nla_policy s_name ## _nl_policy[] __read_mostly = \
{ s_fields }; { s_fields };
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, _type, __get, __put) \ #define __field(attr_nr, attr_flag, name, nla_type, _type, __get, \
__put, __is_signed) \
[__nla_type(attr_nr)] = { .type = nla_type }, [__nla_type(attr_nr)] = { .type = nla_type },
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, _type, maxlen, \ #define __array(attr_nr, attr_flag, name, nla_type, _type, maxlen, \
__get, __put) \ __get, __put, __is_signed) \
[__nla_type(attr_nr)] = { .type = nla_type, \ [__nla_type(attr_nr)] = { .type = nla_type, \
.len = maxlen - (nla_type == NLA_NUL_STRING) }, .len = maxlen - (nla_type == NLA_NUL_STRING) },
...@@ -241,7 +242,8 @@ static int s_name ## _from_attrs_for_change(struct s_name *s, \ ...@@ -241,7 +242,8 @@ static int s_name ## _from_attrs_for_change(struct s_name *s, \
} }
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put) \ #define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put, \
__is_signed) \
__assign(attr_nr, attr_flag, name, nla_type, type, \ __assign(attr_nr, attr_flag, name, nla_type, type, \
if (s) \ if (s) \
s->name = __get(nla); \ s->name = __get(nla); \
...@@ -249,7 +251,8 @@ static int s_name ## _from_attrs_for_change(struct s_name *s, \ ...@@ -249,7 +251,8 @@ static int s_name ## _from_attrs_for_change(struct s_name *s, \
/* validate_nla() already checked nla_len <= maxlen appropriately. */ /* validate_nla() already checked nla_len <= maxlen appropriately. */
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, __get, __put) \ #define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, \
__get, __put, __is_signed) \
__assign(attr_nr, attr_flag, name, nla_type, type, \ __assign(attr_nr, attr_flag, name, nla_type, type, \
if (s) \ if (s) \
s->name ## _len = \ s->name ## _len = \
...@@ -410,14 +413,16 @@ static inline int s_name ## _to_unpriv_skb(struct sk_buff *skb, \ ...@@ -410,14 +413,16 @@ static inline int s_name ## _to_unpriv_skb(struct sk_buff *skb, \
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put) \ #define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put, \
__is_signed) \
if (!exclude_sensitive || !((attr_flag) & GENLA_F_SENSITIVE)) { \ if (!exclude_sensitive || !((attr_flag) & GENLA_F_SENSITIVE)) { \
DPRINT_FIELD(">>", nla_type, name, s, NULL); \ DPRINT_FIELD(">>", nla_type, name, s, NULL); \
__put(skb, attr_nr, s->name); \ __put(skb, attr_nr, s->name); \
} }
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, __get, __put) \ #define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, \
__get, __put, __is_signed) \
if (!exclude_sensitive || !((attr_flag) & GENLA_F_SENSITIVE)) { \ if (!exclude_sensitive || !((attr_flag) & GENLA_F_SENSITIVE)) { \
DPRINT_ARRAY(">>",nla_type, name, s, NULL); \ DPRINT_ARRAY(">>",nla_type, name, s, NULL); \
__put(skb, attr_nr, min_t(int, maxlen, \ __put(skb, attr_nr, min_t(int, maxlen, \
...@@ -431,9 +436,11 @@ static inline int s_name ## _to_unpriv_skb(struct sk_buff *skb, \ ...@@ -431,9 +436,11 @@ static inline int s_name ## _to_unpriv_skb(struct sk_buff *skb, \
/* Functions for initializing structs to default values. */ /* Functions for initializing structs to default values. */
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put) #define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put, \
__is_signed)
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, __get, __put) #define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, \
__get, __put, __is_signed)
#undef __u32_field_def #undef __u32_field_def
#define __u32_field_def(attr_nr, attr_flag, name, default) \ #define __u32_field_def(attr_nr, attr_flag, name, default) \
x->name = default; x->name = default;
......
...@@ -87,28 +87,28 @@ enum { ...@@ -87,28 +87,28 @@ enum {
/* possible field types */ /* possible field types */
#define __flg_field(attr_nr, attr_flag, name) \ #define __flg_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U8, char, \ __field(attr_nr, attr_flag, name, NLA_U8, char, \
nla_get_u8, NLA_PUT_U8) nla_get_u8, NLA_PUT_U8, false)
#define __u8_field(attr_nr, attr_flag, name) \ #define __u8_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U8, unsigned char, \ __field(attr_nr, attr_flag, name, NLA_U8, unsigned char, \
nla_get_u8, NLA_PUT_U8) nla_get_u8, NLA_PUT_U8, false)
#define __u16_field(attr_nr, attr_flag, name) \ #define __u16_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U16, __u16, \ __field(attr_nr, attr_flag, name, NLA_U16, __u16, \
nla_get_u16, NLA_PUT_U16) nla_get_u16, NLA_PUT_U16, false)
#define __u32_field(attr_nr, attr_flag, name) \ #define __u32_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U32, __u32, \ __field(attr_nr, attr_flag, name, NLA_U32, __u32, \
nla_get_u32, NLA_PUT_U32) nla_get_u32, NLA_PUT_U32, false)
#define __s32_field(attr_nr, attr_flag, name) \ #define __s32_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U32, __s32, \ __field(attr_nr, attr_flag, name, NLA_U32, __s32, \
nla_get_u32, NLA_PUT_U32) nla_get_u32, NLA_PUT_U32, true)
#define __u64_field(attr_nr, attr_flag, name) \ #define __u64_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U64, __u64, \ __field(attr_nr, attr_flag, name, NLA_U64, __u64, \
nla_get_u64, NLA_PUT_U64) nla_get_u64, NLA_PUT_U64, false)
#define __str_field(attr_nr, attr_flag, name, maxlen) \ #define __str_field(attr_nr, attr_flag, name, maxlen) \
__array(attr_nr, attr_flag, name, NLA_NUL_STRING, char, maxlen, \ __array(attr_nr, attr_flag, name, NLA_NUL_STRING, char, maxlen, \
nla_strlcpy, NLA_PUT) nla_strlcpy, NLA_PUT, false)
#define __bin_field(attr_nr, attr_flag, name, maxlen) \ #define __bin_field(attr_nr, attr_flag, name, maxlen) \
__array(attr_nr, attr_flag, name, NLA_BINARY, char, maxlen, \ __array(attr_nr, attr_flag, name, NLA_BINARY, char, maxlen, \
nla_memcpy, NLA_PUT) nla_memcpy, NLA_PUT, false)
/* fields with default values */ /* fields with default values */
#define __flg_field_def(attr_nr, attr_flag, name, default) \ #define __flg_field_def(attr_nr, attr_flag, name, default) \
...@@ -174,11 +174,13 @@ enum { \ ...@@ -174,11 +174,13 @@ enum { \
}; };
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put) \ #define __field(attr_nr, attr_flag, name, nla_type, type, \
__get, __put, __is_signed) \
T_ ## name = (__u16)(attr_nr | attr_flag), T_ ## name = (__u16)(attr_nr | attr_flag),
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, __get, __put) \ #define __array(attr_nr, attr_flag, name, nla_type, type, \
maxlen, __get, __put, __is_signed) \
T_ ## name = (__u16)(attr_nr | attr_flag), T_ ## name = (__u16)(attr_nr | attr_flag),
#include GENL_MAGIC_INCLUDE_FILE #include GENL_MAGIC_INCLUDE_FILE
...@@ -238,11 +240,13 @@ static inline void ct_assert_unique_ ## s_name ## _attributes(void) \ ...@@ -238,11 +240,13 @@ static inline void ct_assert_unique_ ## s_name ## _attributes(void) \
} }
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put) \ #define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put, \
__is_signed) \
case attr_nr: case attr_nr:
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, __get, __put) \ #define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, \
__get, __put, __is_signed) \
case attr_nr: case attr_nr:
#include GENL_MAGIC_INCLUDE_FILE #include GENL_MAGIC_INCLUDE_FILE
...@@ -260,16 +264,36 @@ static inline void ct_assert_unique_ ## s_name ## _attributes(void) \ ...@@ -260,16 +264,36 @@ static inline void ct_assert_unique_ ## s_name ## _attributes(void) \
struct s_name { s_fields }; struct s_name { s_fields };
#undef __field #undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put) \ #define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put, \
__is_signed) \
type name; type name;
#undef __array #undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, __get, __put) \ #define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, \
__get, __put, __is_signed) \
type name[maxlen]; \ type name[maxlen]; \
__u32 name ## _len; __u32 name ## _len;
#include GENL_MAGIC_INCLUDE_FILE #include GENL_MAGIC_INCLUDE_FILE
#undef GENL_struct
#define GENL_struct(tag_name, tag_number, s_name, s_fields) \
enum { \
s_fields \
};
#undef __field
#define __field(attr_nr, attr_flag, name, nla_type, type, __get, __put, \
is_signed) \
F_ ## name ## _IS_SIGNED = is_signed,
#undef __array
#define __array(attr_nr, attr_flag, name, nla_type, type, maxlen, \
__get, __put, is_signed) \
F_ ## name ## _IS_SIGNED = is_signed,
#include GENL_MAGIC_INCLUDE_FILE
/* }}}1 */ /* }}}1 */
#endif /* GENL_MAGIC_STRUCT_H */ #endif /* GENL_MAGIC_STRUCT_H */
/* vim: set foldmethod=marker nofoldenable : */ /* vim: set foldmethod=marker nofoldenable : */
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册