Lines Matching +full:nested +full:- +full:attributes

1 /* SPDX-License-Identifier: GPL-2.0 */
11 * Netlink Messages and Attributes Interface (As Seen On TV)
12 * ------------------------------------------------------------------------
14 * ------------------------------------------------------------------------
17 * <--- nlmsg_total_size(payload) --->
18 * <-- nlmsg_msg_size(payload) ->
19 * +----------+- - -+-------------+- - -+-------- - -
21 * +----------+- - -+-------------+- - -+-------- - -
22 * nlmsg_data(nlh)---^ ^
23 * nlmsg_next(nlh)-----------------------+
26 * <---------------------- nlmsg_len(nlh) --------------------->
27 * <------ hdrlen ------> <- nlmsg_attrlen(nlh, hdrlen) ->
28 * +----------------------+- - -+--------------------------------+
29 * | Family Header | Pad | Attributes |
30 * +----------------------+- - -+--------------------------------+
31 * nlmsg_attrdata(nlh, hdrlen)---^
60 * nlmsg_attrdata(nlh, hdrlen) head of attributes data
61 * nlmsg_attrlen(nlh, hdrlen) length of attributes data
66 * nlmsg_parse() parse attributes of a message
70 * nlmsg_for_each_attr() loop over all attributes
71 * nlmsg_for_each_attr_type() loop over all attributes with the
77 * ------------------------------------------------------------------------
78 * Attributes Interface
79 * ------------------------------------------------------------------------
82 * <------- nla_total_size(payload) ------->
83 * <---- nla_attr_size(payload) ----->
84 * +----------+- - -+- - - - - - - - - +- - -+-------- - -
86 * +----------+- - -+- - - - - - - - - +- - -+-------- - -
87 * <- nla_len(nla) -> ^
88 * nla_data(nla)----^ |
89 * nla_next(nla)-----------------------------'
119 * Nested Attributes Construction:
120 * nla_nest_start(skb, type) start a nested attribute
121 * nla_nest_end(skb, nla) finalize a nested attribute
122 * nla_nest_cancel(skb, nla) cancel nested attribute construction
159 * nla_validate() validate a stream of attributes
160 * nla_validate_nested() validate a stream of nested attributes
161 * nla_find() find attribute in stream of attributes
162 * nla_find_nested() find attribute in nested attributes
164 * nla_parse_nested() parse nested attributes
165 * nla_for_each_attr() loop over all attributes
166 * nla_for_each_attr_type() loop over all attributes with the
168 * nla_for_each_nested() loop over the nested attributes
169 * nla_for_each_nested_type() loop over the nested attributes with
203 #define NLA_TYPE_MAX (__NLA_TYPE_MAX - 1)
225 * struct nla_policy - attribute validation policy
228 * type-specific validation (e.g. range, function call), see
243 * nested header (or empty); len field is used if
245 * number in the nested policy.
260 * NLA_BITFIELD32 This is a 32-bit bitmap/bitselector attribute and
265 * NLA_NESTED `nested_policy' to a nested policy to validate, must
269 * parse, the nested sub-policies.
270 * NLA_NESTED_ARRAY `nested_policy' points to a nested policy to validate,
274 * NLA_NESTED has the nested attributes directly inside
275 * while an array has the nested attributes at another
296 * of s16 - do that using the NLA_POLICY_FULL_RANGE()
323 * All other Unused - but note that it's a union
333 * All other Unused - but note that it's a union
367 * validation is enforced for all attributes. For existing ones
368 * it should be set at least when new attributes are added to
397 _NLA_POLICY_NESTED(ARRAY_SIZE(policy) - 1, policy)
399 _NLA_POLICY_NESTED_ARRAY(ARRAY_SIZE(policy) - 1, policy)
486 * struct nl_info - netlink source information
491 * @skip_notify_kernel: Skip selected in-kernel notifications
502 * enum netlink_validation - netlink message/attribute validation levels
503 * @NL_VALIDATE_LIBERAL: Old-style "be liberal" validation, not caring about
504 * extra data at the end of the message, attributes being longer than
505 * they should be, or unknown attributes being present.
507 * @NL_VALIDATE_MAXTYPE: Reject attributes > max type; Together with _TRAILING
509 * @NL_VALIDATE_UNSPEC: Reject attributes with NLA_UNSPEC in the policy.
578 * nlmsg_msg_size - length of netlink message not including padding
587 * nlmsg_total_size - length of netlink message including padding
596 * nlmsg_padlen - length of padding at the message's tail
601 return nlmsg_total_size(payload) - nlmsg_msg_size(payload); in nlmsg_padlen()
605 * nlmsg_data - head of message payload
614 * nlmsg_len - length of message payload
619 return nlh->nlmsg_len - NLMSG_HDRLEN; in nlmsg_len()
623 * nlmsg_payload - message payload if the data fits in the len
632 if (nlh->nlmsg_len < nlmsg_msg_size(len)) in nlmsg_payload()
639 * nlmsg_attrdata - head of attributes data
651 * nlmsg_attrlen - length of attributes data
657 return nlmsg_len(nlh) - NLMSG_ALIGN(hdrlen); in nlmsg_attrlen()
661 * nlmsg_ok - check if the netlink message fits into the remaining bytes
668 nlh->nlmsg_len >= sizeof(struct nlmsghdr) && in nlmsg_ok()
669 nlh->nlmsg_len <= remaining); in nlmsg_ok()
673 * nlmsg_next - next netlink message in message stream
683 int totlen = NLMSG_ALIGN(nlh->nlmsg_len); in nlmsg_next()
685 *remaining -= totlen; in nlmsg_next()
691 * nla_parse - Parse a stream of attributes into a tb buffer
699 * Parses a stream of attributes and stores a pointer to each attribute in
700 * the tb array accessible via the attribute type. Attributes with a type
701 * exceeding maxtype will be rejected, policy must be specified, attributes
716 * nla_parse_deprecated - Parse a stream of attributes into a tb buffer
724 * Parses a stream of attributes and stores a pointer to each attribute in
725 * the tb array accessible via the attribute type. Attributes with a type
726 * exceeding maxtype will be ignored and attributes from the policy are not
727 * always strictly validated (only for new attributes).
741 * nla_parse_deprecated_strict - Parse a stream of attributes into a tb buffer
749 * Parses a stream of attributes and stores a pointer to each attribute in
750 * the tb array accessible via the attribute type. Attributes with a type
752 * policy is not completely strictly validated (only for new attributes).
767 * __nlmsg_parse - parse attributes of a netlink message
784 if (nlh->nlmsg_len < nlmsg_msg_size(hdrlen)) { in __nlmsg_parse()
786 return -EINVAL; in __nlmsg_parse()
795 * nlmsg_parse - parse attributes of a netlink message
815 * nlmsg_parse_deprecated - parse attributes of a netlink message
835 * nlmsg_parse_deprecated_strict - parse attributes of a netlink message
856 * nlmsg_find_attr - find a specific attribute in a netlink message
871 * nla_validate_deprecated - Validate a stream of attributes
878 * Validates all attributes in the specified attribute stream against the
894 * nla_validate - Validate a stream of attributes
901 * Validates all attributes in the specified attribute stream against the
916 * nlmsg_validate_deprecated - validate a netlink message including attributes
928 if (nlh->nlmsg_len < nlmsg_msg_size(hdrlen)) in nlmsg_validate_deprecated()
929 return -EINVAL; in nlmsg_validate_deprecated()
939 * nlmsg_report - need to report back to application?
946 return nlh ? !!(nlh->nlmsg_flags & NLM_F_ECHO) : 0; in nlmsg_report()
950 * nlmsg_seq - return the seq number of netlink message
957 return nlh ? nlh->nlmsg_seq : 0; in nlmsg_seq()
961 * nlmsg_for_each_attr - iterate over a stream of attributes
972 * nlmsg_for_each_attr_type - iterate over a stream of attributes
984 * nlmsg_put - Add a new netlink message to an skb
1005 * nlmsg_append - Add more data to a nlmsg in a skb
1010 * with multiple fixed-format headers (which is rare).
1019 if (NLMSG_ALIGN(size) - size) in nlmsg_append()
1021 NLMSG_ALIGN(size) - size); in nlmsg_append()
1026 * nlmsg_put_answer - Add a new callback based netlink message to an skb
1041 return nlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq, in nlmsg_put_answer()
1046 * nlmsg_new - Allocate a new netlink message
1059 * nlmsg_new_large - Allocate a new netlink message with non-contiguous
1063 * The allocated skb is unable to have frag page for shinfo->frags*,
1064 * as the NULL setting for skb->head in netlink_skb_destructor() will
1073 * nlmsg_end - Finalize a netlink message
1078 * attributes. Only necessary if attributes have been added to
1083 nlh->nlmsg_len = skb_tail_pointer(skb) - (unsigned char *)nlh; in nlmsg_end()
1087 * nlmsg_get_pos - return current position in netlink message
1098 * nlmsg_trim - Trim message to a mark
1107 WARN_ON((unsigned char *) mark < skb->data); in nlmsg_trim()
1108 skb_trim(skb, (unsigned char *) mark - skb->data); in nlmsg_trim()
1113 * nlmsg_cancel - Cancel construction of a netlink message
1118 * attributes from the socket buffer again.
1126 * nlmsg_free - drop a netlink message
1135 * nlmsg_consume - free a netlink message
1144 * nlmsg_multicast_filtered - multicast a netlink message with filter function
1174 * nlmsg_multicast - multicast a netlink message
1189 * nlmsg_unicast - unicast a netlink message
1206 * nlmsg_for_each_msg - iterate over a stream of messages
1218 * nl_dump_check_consistent - check if sequence is consistent and advertise if not
1225 * The correct way to use it is to set cb->seq to the generation counter when
1236 if (cb->prev_seq && cb->seq != cb->prev_seq) in nl_dump_check_consistent()
1237 nlh->nlmsg_flags |= NLM_F_DUMP_INTR; in nl_dump_check_consistent()
1238 cb->prev_seq = cb->seq; in nl_dump_check_consistent()
1242 * Netlink Attributes
1246 * nla_attr_size - length of attribute not including padding
1255 * nla_total_size - total length of attribute including padding
1264 * nla_padlen - length of padding at the tail of attribute
1269 return nla_total_size(payload) - nla_attr_size(payload); in nla_padlen()
1273 * nla_type - attribute type
1278 return nla->nla_type & NLA_TYPE_MASK; in nla_type()
1282 * nla_data - head of payload
1291 * nla_len - length of payload
1296 return nla->nla_len - NLA_HDRLEN; in nla_len()
1300 * nla_ok - check if the netlink attribute fits into the remaining bytes
1307 nla->nla_len >= sizeof(*nla) && in nla_ok()
1308 nla->nla_len <= remaining; in nla_ok()
1312 * nla_next - next netlink attribute in attribute stream
1321 unsigned int totlen = NLA_ALIGN(nla->nla_len); in nla_next()
1323 *remaining -= totlen; in nla_next()
1328 * nla_find_nested - find attribute in a set of nested attributes
1329 * @nla: attribute containing the nested attributes
1341 * nla_parse_nested - parse nested attributes
1344 * @nla: attribute containing the nested attributes
1355 if (!(nla->nla_type & NLA_F_NESTED)) { in nla_parse_nested()
1357 return -EINVAL; in nla_parse_nested()
1365 * nla_parse_nested_deprecated - parse nested attributes
1368 * @nla: attribute containing the nested attributes
1384 * nla_put_u8 - Add a u8 netlink attribute to a socket buffer
1391 /* temporary variables to work around GCC PR81715 with asan-stack=1 */ in nla_put_u8()
1398 * nla_put_u16 - Add a u16 netlink attribute to a socket buffer
1411 * nla_put_be16 - Add a __be16 netlink attribute to a socket buffer
1424 * nla_put_net16 - Add 16-bit network byte order netlink attribute to a socket buffer
1437 * nla_put_le16 - Add a __le16 netlink attribute to a socket buffer
1450 * nla_put_u32 - Add a u32 netlink attribute to a socket buffer
1463 * nla_put_uint - Add a variable-size unsigned int to a socket buffer
1479 * nla_put_be32 - Add a __be32 netlink attribute to a socket buffer
1492 * nla_put_net32 - Add 32-bit network byte order netlink attribute to a socket buffer
1505 * nla_put_le32 - Add a __le32 netlink attribute to a socket buffer
1518 * nla_put_u64_64bit - Add a u64 netlink attribute to a skb and align it
1533 * nla_put_be64 - Add a __be64 netlink attribute to a socket buffer and align it
1548 * nla_put_net64 - Add 64-bit network byte order nlattr to a skb and align it
1564 * nla_put_le64 - Add a __le64 netlink attribute to a socket buffer and align it
1579 * nla_put_s8 - Add a s8 netlink attribute to a socket buffer
1592 * nla_put_s16 - Add a s16 netlink attribute to a socket buffer
1605 * nla_put_s32 - Add a s32 netlink attribute to a socket buffer
1618 * nla_put_s64 - Add a s64 netlink attribute to a socket buffer and align it
1633 * nla_put_sint - Add a variable-size signed int to a socket buffer
1649 * nla_put_string - Add a string netlink attribute to a socket buffer
1661 * nla_put_flag - Add a flag netlink attribute to a socket buffer
1671 * nla_put_msecs - Add a msecs netlink attribute to a skb and align it
1686 * nla_put_in_addr - Add an IPv4 address netlink attribute to a socket
1701 * nla_put_in6_addr - Add an IPv6 address netlink attribute to a socket
1714 * nla_put_bitfield32 - Add a bitfield32 netlink attribute to a socket buffer
1729 * nla_get_u32 - return payload of u32 attribute
1738 * nla_get_u32_default - return payload of u32 attribute or default
1752 * nla_get_be32 - return payload of __be32 attribute
1761 * nla_get_be32_default - return payload of be32 attribute or default
1776 * nla_get_le32 - return payload of __le32 attribute
1785 * nla_get_le32_default - return payload of le32 attribute or default
1800 * nla_get_u16 - return payload of u16 attribute
1809 * nla_get_u16_default - return payload of u16 attribute or default
1823 * nla_get_be16 - return payload of __be16 attribute
1832 * nla_get_be16_default - return payload of be16 attribute or default
1847 * nla_get_le16 - return payload of __le16 attribute
1856 * nla_get_le16_default - return payload of le16 attribute or default
1871 * nla_get_u8 - return payload of u8 attribute
1880 * nla_get_u8_default - return payload of u8 attribute or default
1894 * nla_get_u64 - return payload of u64 attribute
1907 * nla_get_u64_default - return payload of u64 attribute or default
1921 * nla_get_uint - return payload of uint attribute
1932 * nla_get_uint_default - return payload of uint attribute or default
1946 * nla_get_be64 - return payload of __be64 attribute
1959 * nla_get_be64_default - return payload of be64 attribute or default
1974 * nla_get_le64 - return payload of __le64 attribute
1983 * nla_get_le64_default - return payload of le64 attribute or default
1998 * nla_get_s32 - return payload of s32 attribute
2007 * nla_get_s32_default - return payload of s32 attribute or default
2021 * nla_get_s16 - return payload of s16 attribute
2030 * nla_get_s16_default - return payload of s16 attribute or default
2044 * nla_get_s8 - return payload of s8 attribute
2053 * nla_get_s8_default - return payload of s8 attribute or default
2067 * nla_get_s64 - return payload of s64 attribute
2080 * nla_get_s64_default - return payload of s64 attribute or default
2094 * nla_get_sint - return payload of uint attribute
2105 * nla_get_sint_default - return payload of sint attribute or default
2119 * nla_get_flag - return payload of flag attribute
2128 * nla_get_msecs - return payload of msecs attribute
2141 * nla_get_msecs_default - return payload of msecs attribute or default
2156 * nla_get_in_addr - return payload of IPv4 address attribute
2165 * nla_get_in_addr_default - return payload of be32 attribute or default
2180 * nla_get_in6_addr - return payload of IPv6 address attribute
2192 * nla_get_bitfield32 - return payload of 32 bitfield attribute
2204 * nla_memdup - duplicate attribute memory (kmemdup)
2215 * nla_nest_start_noflag - Start a new level of nested attributes
2216 * @skb: socket buffer to add attributes to
2220 * marked their nest attributes with NLA_F_NESTED flag. New APIs should use
2237 * nla_nest_start - Start a new level of nested attributes, with NLA_F_NESTED
2238 * @skb: socket buffer to add attributes to
2252 * nla_nest_end - Finalize nesting of attributes
2253 * @skb: socket buffer the attributes are stored in
2257 * appended attributes.
2263 start->nla_len = skb_tail_pointer(skb) - (unsigned char *)start; in nla_nest_end()
2264 return skb->len; in nla_nest_end()
2268 * nla_nest_cancel - Cancel nesting of attributes
2272 * Removes the container attribute and including all nested
2273 * attributes. Returns -EMSGSIZE
2281 * nla_put_empty_nest - Create an empty nest
2287 * Returns: 0 when successful or -EMSGSIZE on failure.
2291 return nla_nest_start(skb, attrtype) ? 0 : -EMSGSIZE; in nla_put_empty_nest()
2295 * __nla_validate_nested - Validate a stream of nested attributes
2302 * Validates all attributes in the nested attribute stream against the
2303 * specified policy. Attributes with a type exceeding maxtype will be
2336 * nla_need_padding_for_64bit - test 64-bit alignment of the next attribute
2340 * a 64-bit aligned area.
2346 * if the skb->data _is_ aligned. A NOP attribute, plus in nla_need_padding_for_64bit()
2348 * 8-byte aligned. in nla_need_padding_for_64bit()
2357 * nla_align_64bit - 64-bit align the nla_data() of next attribute
2362 * the next attribute we emit have a 64-bit aligned nla_data() area.
2372 return -EMSGSIZE; in nla_align_64bit()
2378 * nla_total_size_64bit - total length of attribute including padding
2391 * nla_for_each_attr - iterate over a stream of attributes
2403 * nla_for_each_attr_type - iterate over a stream of attributes
2415 * nla_for_each_nested - iterate over nested attributes
2417 * @nla: attribute containing the nested attributes
2424 * nla_for_each_nested_type - iterate over nested attributes
2427 * @nla: attribute containing the nested attributes
2435 * nla_is_last - Test if attribute is last in stream
2441 return nla->nla_len == rem; in nla_is_last()