mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-24 18:50:54 +07:00
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: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
This commit is contained in:
parent
309f0b70ab
commit
509100e601
@ -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, \
|
|||||||
}
|
}
|
||||||
|
|
||||||
#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, \
|
|||||||
|
|
||||||
/* 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, \
|
|||||||
|
|
||||||
|
|
||||||
#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, \
|
|||||||
/* 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 {
|
|||||||
/* 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 { \
|
|||||||
};
|
};
|
||||||
|
|
||||||
#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) \
|
|||||||
}
|
}
|
||||||
|
|
||||||
#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) \
|
|||||||
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 : */
|
||||||
|
Loading…
Reference in New Issue
Block a user