Netlink Attributes Construction/Parsing Interface.
More...
|
| int | nla_ok (const struct nlattr *nla, int remaining) |
| | check if the netlink attribute fits into the remaining bytes More...
|
| |
| struct nlattr * | nla_next (const struct nlattr *nla, int *remaining) |
| | next netlink attribte in attribute stream More...
|
| |
| int | nla_parse (struct nlattr *tb[], int maxtype, struct nlattr *head, int len, struct nla_policy *policy) |
| | Parse a stream of attributes into a tb buffer. More...
|
| |
| int | nla_parse_nested (struct nlattr *tb[], int maxtype, struct nlattr *nla, struct nla_policy *policy) |
| | parse nested attributes More...
|
| |
| int | nla_validate (struct nlattr *head, int len, int maxtype, struct nla_policy *policy) |
| | Validate a stream of attributes. More...
|
| |
| struct nlattr * | nla_find (struct nlattr *head, int len, int attrtype) |
| | Find a specific attribute in a stream of attributes. More...
|
| |
|
| int | nla_memcpy (void *dest, struct nlattr *src, int count) |
| | Copy a netlink attribute into another memory area. More...
|
| |
| size_t | nla_strlcpy (char *dst, const struct nlattr *nla, size_t dstsize) |
| | Copy string attribute payload into a sized buffer. More...
|
| |
| int | nla_memcmp (const struct nlattr *nla, const void *data, size_t size) |
| | Compare an attribute with sized memory area. More...
|
| |
| int | nla_strcmp (const struct nlattr *nla, const char *str) |
| | Compare a string attribute against a string. More...
|
| |
|
| struct nlattr * | nla_reserve (struct nl_msg *n, int attrtype, int attrlen) |
| | reserve room for attribute on the skb More...
|
| |
| int | nla_put (struct nl_msg *n, int attrtype, int attrlen, const void *data) |
| | Add a netlink attribute to a netlink message. More...
|
| |
| int | nla_put_nested (struct nl_msg *n, int attrtype, struct nl_msg *nested) |
| | Add a nested netlink attribute to a netlink message. More...
|
| |
| int | nla_put_u8 (struct nl_msg *n, int attrtype, uint8_t value) |
| | Add a u16 netlink attribute to a netlink message. More...
|
| |
| int | nla_put_u16 (struct nl_msg *n, int attrtype, uint16_t value) |
| | Add a u16 netlink attribute to a netlink message. More...
|
| |
| int | nla_put_u32 (struct nl_msg *n, int attrtype, uint32_t value) |
| | Add a u32 netlink attribute to a netlink message. More...
|
| |
| int | nla_put_u64 (struct nl_msg *n, int attrtype, uint64_t value) |
| | Add a u64 netlink attribute to a netlink message. More...
|
| |
| int | nla_put_string (struct nl_msg *n, int attrtype, const char *str) |
| | Add a string netlink attribute to a netlink message. More...
|
| |
| int | nla_put_flag (struct nl_msg *n, int attrtype) |
| | Add a flag netlink attribute to a netlink message. More...
|
| |
| int | nla_put_msecs (struct nl_msg *n, int attrtype, unsigned long msecs) |
| | Add a msecs netlink attribute to a netlink message. More...
|
| |
| int | nla_put_data (struct nl_msg *n, int attrtype, struct nl_data *data) |
| | Add an abstract data netlink attribute to a netlink message. More...
|
| |
| int | nla_put_addr (struct nl_msg *n, int attrtype, struct nl_addr *addr) |
| | Add an abstract address netlink attribute to a netlink message. More...
|
| |
|
| struct nlattr * | nla_nest_start (struct nl_msg *n, int attrtype) |
| | Start a new level of nested attributes. More...
|
| |
| int | nla_nest_end (struct nl_msg *n, struct nlattr *start) |
| | Finalize nesting of attributes. More...
|
| |
|
All these functions jump to nla_put_failure in case of a failure instead of returning an error code.
|
| #define | NLA_PUT(n, attrtype, attrlen, data) |
| | Add a netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_TYPE(n, type, attrtype, value) |
| | Add a basic netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_U8(n, attrtype, value) NLA_PUT_TYPE(n, uint8_t, attrtype, value) |
| | Add a u8 netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_U16(n, attrtype, value) NLA_PUT_TYPE(n, uint16_t, attrtype, value) |
| | Add a u16 netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_U32(n, attrtype, value) NLA_PUT_TYPE(n, uint32_t, attrtype, value) |
| | Add a u32 netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_U64(n, attrtype, value) NLA_PUT_TYPE(n, uint64_t, attrtype, value) |
| | Add a u64 netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_STRING(n, attrtype, value) NLA_PUT(n, attrtype, strlen(value) + 1, value) |
| | Add a character string netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_FLAG(n, attrtype) NLA_PUT(n, attrtype, 0, NULL) |
| | Add a flag netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_MSECS(n, attrtype, msecs) NLA_PUT_U64(n, attrtype, msecs) |
| | Add a msecs netlink attribute to a netlink message. More...
|
| |
| #define | NLA_PUT_ADDR(n, attrtype, addr) |
| | Add a address attribute to a netlink message. More...
|
| |
- 0) Introduction
- Netlink attributes are chained together following each other:
+----------+- - -+- - - - - - - - - +- - -+-------- - -
| Header | Pad | Payload | Pad | Header
+----------+- - -+- - - - - - - - - +- - -+-------- - -
nla_next(nla)-----------------------------
'
- The attribute header and payload must be aligned properly:
<------- NLA_HDRLEN ------> <-- NLA_ALIGN(payload)-->
+---------------------+- - -+- - - - - - - - - -+- - -+
| Header | Pad | Payload | Pad |
| (struct nlattr) | ing | | ing |
+---------------------+- - -+- - - - - - - - - -+- - -+
<-------------- nlattr->
nla_len -------------->
- Nested TLVs:
- Nested TLVs are an array of TLVs nested into another TLV. This can be useful to allow subsystems to have their own formatting rules without the need to make the underlying layer be aware of it. It can also be useful to transfer arrays, lists and flattened trees.
<-------------------- NLA_ALIGN(...) ------------------->
+---------------+- - - - - - - - - - - - - - - - - -+- - -+
| |+---------+---------+- - -+-------+| |
| TLV Header || TLV 1 | TLV 2 | | TLV n || Pad |
| |+---------+---------+- - -+-------+| |
+---------------+- - - - - - - - - - - - - - - - - -+- - -+
- 1) Constructing a message with attributes
int param1 = 10;
char *param2 = "parameter text";
- 2) Constructing nested attributes
struct nl_msg * nested_config(void)
{
int a = 5, int b = 10;
return n;
}
...
struct nl_msg *nest = nested_config();
◆ NLA_PUT
| #define NLA_PUT |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
attrlen, |
|
|
|
data |
|
) |
| |
Value: do { \
if (
nla_put(n, attrtype, attrlen, data) < 0) \
goto nla_put_failure; \
} while(0)
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| attrlen | length of attribute payload |
| data | head of attribute payload |
Definition at line 157 of file attr.h.
◆ NLA_PUT_TYPE
| #define NLA_PUT_TYPE |
( |
|
n, |
|
|
|
type, |
|
|
|
attrtype, |
|
|
|
value |
|
) |
| |
Value: do { \
type __tmp = value; \
NLA_PUT(n, attrtype, sizeof(type), &__tmp); \
} while(0)
- Parameters
-
| n | netlink message |
| type | atomic type |
| attrtype | attribute type |
| value | head of attribute payload |
Definition at line 171 of file attr.h.
◆ nla_for_each_attr
| #define nla_for_each_attr |
( |
|
pos, |
|
|
|
head, |
|
|
|
len, |
|
|
|
rem |
|
) |
| |
Value: for (pos = head, rem = len; \
nla_ok(pos, rem); \
- Parameters
-
| pos | loop counter, set to current attribute |
| head | head of attribute stream |
| len | length of attribute stream |
| rem | initialized to len, holds bytes currently remaining in stream |
Definition at line 264 of file attr.h.
◆ nla_for_each_nested
| #define nla_for_each_nested |
( |
|
pos, |
|
|
|
nla, |
|
|
|
rem |
|
) |
| |
Value:- Parameters
-
| pos | loop counter, set to current attribute |
| nla | attribute containing the nested attributes |
| rem | initialized to len, holds bytes currently remaining in stream |
Definition at line 276 of file attr.h.
◆ NLA_PUT_U8
| #define NLA_PUT_U8 |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
value |
|
) |
| NLA_PUT_TYPE(n, uint8_t, attrtype, value) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | numeric value |
Definition at line 183 of file attr.h.
◆ NLA_PUT_U16
| #define NLA_PUT_U16 |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
value |
|
) |
| NLA_PUT_TYPE(n, uint16_t, attrtype, value) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | numeric value |
Definition at line 192 of file attr.h.
◆ NLA_PUT_U32
| #define NLA_PUT_U32 |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
value |
|
) |
| NLA_PUT_TYPE(n, uint32_t, attrtype, value) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | numeric value |
Definition at line 201 of file attr.h.
◆ NLA_PUT_U64
| #define NLA_PUT_U64 |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
value |
|
) |
| NLA_PUT_TYPE(n, uint64_t, attrtype, value) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | numeric value |
Definition at line 210 of file attr.h.
◆ NLA_PUT_STRING
| #define NLA_PUT_STRING |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
value |
|
) |
| NLA_PUT(n, attrtype, strlen(value) + 1, value) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | character string |
Definition at line 219 of file attr.h.
◆ NLA_PUT_FLAG
| #define NLA_PUT_FLAG |
( |
|
n, |
|
|
|
attrtype |
|
) |
| NLA_PUT(n, attrtype, 0, NULL) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
Definition at line 227 of file attr.h.
◆ NLA_PUT_MSECS
| #define NLA_PUT_MSECS |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
msecs |
|
) |
| NLA_PUT_U64(n, attrtype, msecs) |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| msecs | numeric value in micro seconds |
Definition at line 236 of file attr.h.
◆ NLA_PUT_ADDR
| #define NLA_PUT_ADDR |
( |
|
n, |
|
|
|
attrtype, |
|
|
|
addr |
|
) |
| |
Value:- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| addr | abstract address object |
Definition at line 245 of file attr.h.
◆ anonymous enum
| Enumerator |
|---|
| NLA_UNSPEC | Unspecified type.
|
| NLA_U8 | 8bit integer
|
| NLA_U16 | 16bit integer
|
| NLA_U32 | 32bit integer
|
| NLA_U64 | 64bit integer
|
| NLA_STRING | character string
|
| NLA_FLAG | flag
|
| NLA_MSECS | micro seconds (64bit)
|
| NLA_NESTED | nested attributes
|
Definition at line 35 of file attr.h.
◆ nla_attr_size()
| int nla_attr_size |
( |
int |
payload | ) |
|
◆ nla_total_size()
| int nla_total_size |
( |
int |
payload | ) |
|
◆ nla_padlen()
| int nla_padlen |
( |
int |
payload | ) |
|
◆ nla_type()
| int nla_type |
( |
const struct nlattr * |
nla | ) |
|
◆ nla_data()
| void* nla_data |
( |
const struct nlattr * |
nla | ) |
|
- Parameters
-
Definition at line 151 of file attr.c.
153 return (
char *) nla + NLA_HDRLEN;
Referenced by nla_get_addr(), nla_get_data(), nla_get_string(), nla_get_u16(), nla_get_u32(), nla_get_u8(), nla_memcmp(), nla_memcpy(), nla_parse_nested(), nla_put(), nla_strcmp(), and nla_strlcpy().
◆ nla_len()
| int nla_len |
( |
const struct nlattr * |
nla | ) |
|
◆ nla_ok()
| int nla_ok |
( |
const struct nlattr * |
nla, |
|
|
int |
remaining |
|
) |
| |
- Parameters
-
| nla | netlink attribute |
| remaining | number of bytes remaining in attribute stream |
Definition at line 177 of file attr.c.
179 return remaining >=
sizeof(*nla) &&
180 nla->nla_len >=
sizeof(*nla) &&
181 nla->nla_len <= remaining;
◆ nla_next()
| struct nlattr* nla_next |
( |
const struct nlattr * |
nla, |
|
|
int * |
remaining |
|
) |
| |
- Parameters
-
| nla | netlink attribute |
| remaining | number of bytes remaining in attribute stream |
- Returns
- the next netlink attribute in the attribute stream and decrements remaining by the size of the current attribute.
Definition at line 192 of file attr.c.
194 int totlen = NLA_ALIGN(nla->nla_len);
196 *remaining -= totlen;
197 return (
struct nlattr *) ((
char *) nla + totlen);
◆ nla_parse()
| int nla_parse |
( |
struct nlattr * |
tb[], |
|
|
int |
maxtype, |
|
|
struct nlattr * |
head, |
|
|
int |
len, |
|
|
struct nla_policy * |
policy |
|
) |
| |
- Parameters
-
| tb | destination array with maxtype+1 elements |
| maxtype | maximum attribute type to be expected |
| head | head of attribute stream |
| len | length of attribute stream |
| policy | validation policy |
Parses a stream of attributes and stores a pointer to each attribute in the tb array accessable via the attribute type. Attributes with a type exceeding maxtype will be silently ignored for backwards compatibility reasons. policy may be set to NULL if no validation is required.
- Returns
- 0 on success or a negative error code.
Definition at line 262 of file attr.c.
268 memset(tb, 0,
sizeof(
struct nlattr *) * (maxtype + 1));
277 if (type <= maxtype) {
279 err = validate_nla(nla, maxtype, policy);
289 fprintf(stderr,
"netlink: %d bytes leftover after parsing "
290 "attributes.\n", rem);
References nla_for_each_attr, and nla_type().
Referenced by nla_parse_nested().
◆ nla_parse_nested()
| int nla_parse_nested |
( |
struct nlattr * |
tb[], |
|
|
int |
maxtype, |
|
|
struct nlattr * |
nla, |
|
|
struct nla_policy * |
policy |
|
) |
| |
- Parameters
-
| tb | destination array with maxtype+1 elements |
| maxtype | maximum attribute type to be expected |
| nla | attribute containing the nested attributes |
| policy | validation policy |
- See also
- nla_parse()
Definition at line 307 of file attr.c.
References nla_data(), nla_len(), and nla_parse().
◆ nla_validate()
| int nla_validate |
( |
struct nlattr * |
head, |
|
|
int |
len, |
|
|
int |
maxtype, |
|
|
struct nla_policy * |
policy |
|
) |
| |
- Parameters
-
| head | head of attribute stream |
| len | length of attribute stream |
| maxtype | maximum attribute type to be expected |
| policy | validation policy |
Validates all attributes in the specified attribute stream against the specified policy. Attributes with a type exceeding maxtype will be ignored. See documenation of struct nla_policy for more details.
- Returns
- 0 on success or a negative error code.
Definition at line 327 of file attr.c.
334 err = validate_nla(nla, maxtype, policy);
References nla_for_each_attr.
◆ nla_find()
| struct nlattr* nla_find |
( |
struct nlattr * |
head, |
|
|
int |
len, |
|
|
int |
attrtype |
|
) |
| |
- Parameters
-
| head | head of attribute stream |
| len | length of attribute stream |
| attrtype | type of attribute to look for |
- Returns
- the first attribute in the stream matching the specified type.
Definition at line 352 of file attr.c.
References nla_for_each_attr, and nla_type().
Referenced by nlmsg_find_attr().
◆ nla_memcpy()
| int nla_memcpy |
( |
void * |
dest, |
|
|
struct nlattr * |
src, |
|
|
int |
count |
|
) |
| |
- Parameters
-
| dest | where to copy to memcpy |
| src | netlink attribute to copy from |
| count | size of the destination area |
Note: The number of bytes copied is limited by the length of attribute's payload. memcpy
- Returns
- the number of bytes copied.
Definition at line 382 of file attr.c.
389 minlen = min_t(
int, count,
nla_len(src));
390 memcpy(dest,
nla_data(src), minlen);
References nla_data(), and nla_len().
Referenced by nla_get_u64().
◆ nla_strlcpy()
| size_t nla_strlcpy |
( |
char * |
dst, |
|
|
const struct nlattr * |
nla, |
|
|
size_t |
dstsize |
|
) |
| |
- Parameters
-
| dst | where to copy the string to |
| nla | attribute to copy the string from |
| dstsize | size of destination buffer |
Copies at most dstsize - 1 bytes into the destination buffer. The result is always a valid NUL-terminated string. Unlike strlcpy the destination buffer is always padded out.
- Returns
- the length of the source buffer.
Definition at line 407 of file attr.c.
412 if (srclen > 0 && src[srclen - 1] ==
'\0')
416 size_t len = (srclen >= dstsize) ? dstsize - 1 : srclen;
418 memset(dst, 0, dstsize);
419 memcpy(dst, src, len);
References nla_data(), and nla_len().
◆ nla_memcmp()
| int nla_memcmp |
( |
const struct nlattr * |
nla, |
|
|
const void * |
data, |
|
|
size_t |
size |
|
) |
| |
- Parameters
-
| nla | netlink attribute |
| data | memory area |
| size | size of memory area |
Definition at line 431 of file attr.c.
437 d = memcmp(
nla_data(nla), data, size);
References nla_data(), and nla_len().
◆ nla_strcmp()
| int nla_strcmp |
( |
const struct nlattr * |
nla, |
|
|
const char * |
str |
|
) |
| |
- Parameters
-
| nla | netlink string attribute |
| str | another string |
Definition at line 447 of file attr.c.
449 int len = strlen(str) + 1;
453 d = memcmp(
nla_data(nla), str, len);
References nla_data(), and nla_len().
◆ nla_reserve()
| struct nlattr* nla_reserve |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
int |
attrlen |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| attrlen | length of attribute payload |
Adds a netlink attribute header to a netlink message and reserves room for the payload but does not copy it.
Definition at line 474 of file attr.c.
479 tlen = NLMSG_ALIGN(n->nm_nlh->nlmsg_len) +
nla_total_size(attrlen);
481 if (tlen > n->nm_size) {
486 nla = (
struct nlattr *) nlmsg_tail(n->nm_nlh);
487 nla->nla_type = attrtype;
490 memset((
unsigned char *) nla + nla->nla_len, 0,
nla_padlen(attrlen));
491 n->nm_nlh->nlmsg_len = tlen;
493 NL_DBG(2,
"msg %p: Reserved %d bytes at offset +%td for attr %d "
494 "nlmsg_len=%d\n", n, attrlen,
496 attrtype, n->nm_nlh->nlmsg_len);
References nla_total_size().
Referenced by nla_put().
◆ nla_put()
| int nla_put |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
int |
attrlen, |
|
|
const void * |
data |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| attrlen | length of attribute payload |
| data | head of attribute payload |
- Returns
- -1 if the tailroom of the skb is insufficient to store the attribute header and payload.
Definition at line 511 of file attr.c.
517 return nl_errno(ENOMEM);
519 memcpy(
nla_data(nla), data, attrlen);
520 NL_DBG(2,
"msg %p: Wrote %d bytes at offset +%td for attr %d\n",
521 n, attrlen, (
void *) nla -
nlmsg_data(n->nm_nlh), attrtype);
References nla_data(), nla_reserve(), and nlmsg_data().
Referenced by nla_put_addr(), nla_put_data(), nla_put_flag(), nla_put_nested(), nla_put_string(), nla_put_u16(), nla_put_u32(), nla_put_u64(), and nla_put_u8().
◆ nla_put_nested()
| int nla_put_nested |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
struct nl_msg * |
nested |
|
) |
| |
◆ nla_put_u8()
| int nla_put_u8 |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
uint8_t |
value |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | numeric value |
Definition at line 547 of file attr.c.
549 return nla_put(n, attrtype,
sizeof(uint8_t), &value);
References nla_put().
◆ nla_put_u16()
| int nla_put_u16 |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
uint16_t |
value |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| value | numeric value |
Definition at line 558 of file attr.c.
560 return nla_put(n, attrtype,
sizeof(uint16_t), &value);
References nla_put().
◆ nla_put_u32()
| int nla_put_u32 |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
uint32_t |
value |
|
) |
| |
◆ nla_put_u64()
| int nla_put_u64 |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
uint64_t |
value |
|
) |
| |
◆ nla_put_string()
| int nla_put_string |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
const char * |
str |
|
) |
| |
◆ nla_put_flag()
| int nla_put_flag |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
Definition at line 601 of file attr.c.
603 return nla_put(n, attrtype, 0, NULL);
References nla_put().
◆ nla_put_msecs()
| int nla_put_msecs |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
unsigned long |
msecs |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type |
| msecs | number of msecs |
Definition at line 612 of file attr.c.
References nla_put_u64().
◆ nla_put_data()
| int nla_put_data |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
struct nl_data * |
data |
|
) |
| |
◆ nla_put_addr()
| int nla_put_addr |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype, |
|
|
struct nl_addr * |
addr |
|
) |
| |
◆ nla_nest_start()
| struct nlattr* nla_nest_start |
( |
struct nl_msg * |
n, |
|
|
int |
attrtype |
|
) |
| |
- Parameters
-
| n | netlink message |
| attrtype | attribute type of container |
- Returns
- the container attribute
Definition at line 655 of file attr.c.
657 struct nlattr *start = (
struct nlattr *) nlmsg_tail(n->nm_nlh);
659 if (
nla_put(n, attrtype, 0, NULL) < 0)
Referenced by rtnl_link_build_change_request().
◆ nla_nest_end()
| int nla_nest_end |
( |
struct nl_msg * |
n, |
|
|
struct nlattr * |
start |
|
) |
| |
- Parameters
-
| n | netlink message |
| start | container attribute |
Corrects the container attribute header to include the all appeneded attributes.
- Returns
- the total data length of the skb.
Definition at line 675 of file attr.c.
677 start->nla_len = (
unsigned char *) nlmsg_tail(n->nm_nlh) -
678 (
unsigned char *) start;
Referenced by rtnl_link_build_change_request().
◆ nla_get_u32()
| uint32_t nla_get_u32 |
( |
struct nlattr * |
nla | ) |
|
◆ nla_get_u16()
| uint16_t nla_get_u16 |
( |
struct nlattr * |
nla | ) |
|
◆ nla_get_u8()
| uint8_t nla_get_u8 |
( |
struct nlattr * |
nla | ) |
|
◆ nla_get_u64()
| uint64_t nla_get_u64 |
( |
struct nlattr * |
nla | ) |
|
◆ nla_get_string()
| char* nla_get_string |
( |
struct nlattr * |
nla | ) |
|
- Parameters
-
| nla | string netlink attribute |
Definition at line 733 of file attr.c.
References nla_data().
◆ nla_get_flag()
| int nla_get_flag |
( |
struct nlattr * |
nla | ) |
|
- Parameters
-
| nla | flag netlink attribute |
Definition at line 742 of file attr.c.
◆ nla_get_msecs()
| unsigned long nla_get_msecs |
( |
struct nlattr * |
nla | ) |
|
- Parameters
-
| nla | msecs netlink attribute |
- Returns
- the number of milliseconds.
Definition at line 753 of file attr.c.
References nla_get_u64().
◆ nla_get_addr()
| struct nl_addr* nla_get_addr |
( |
struct nlattr * |
nla, |
|
|
int |
family |
|
) |
| |
◆ nla_get_data()
| struct nl_data* nla_get_data |
( |
struct nlattr * |
nla | ) |
|
void * nlmsg_data(const struct nlmsghdr *nlh)
head of message payload
void * nl_addr_get_binary_addr(struct nl_addr *addr)
Get binary address of abstract address object.
@ NLA_UNSPEC
Unspecified type.
int nla_len(const struct nlattr *nla)
length of payload
int nla_put_nested(struct nl_msg *n, int attrtype, struct nl_msg *nested)
Add a nested netlink attribute to a netlink message.
unsigned int nl_addr_get_len(struct nl_addr *addr)
Get length of binary address of abstract address object.
struct nl_addr * nl_addr_build(int family, void *buf, size_t size)
Allocate new abstract address object based on a binary address.
int nla_put_u64(struct nl_msg *n, int attrtype, uint64_t value)
Add a u64 netlink attribute to a netlink message.
@ NLA_STRING
character string
int nla_memcpy(void *dest, struct nlattr *src, int count)
Copy a netlink attribute into another memory area.
uint64_t nla_get_u64(struct nlattr *nla)
Return payload of u64 attribute.
struct nl_data * nl_data_alloc(void *buf, size_t size)
Allocate a new abstract data object.
size_t nl_data_get_size(struct nl_data *data)
Get size of data buffer of abstract data object.
@ NLA_MSECS
micro seconds (64bit)
#define nla_for_each_attr(pos, head, len, rem)
iterate over a stream of attributes
#define NLA_PUT(n, attrtype, attrlen, data)
Add a netlink attribute to a netlink message.
int nla_put_string(struct nl_msg *n, int attrtype, const char *str)
Add a string netlink attribute to a netlink message.
void nlmsg_free(struct nl_msg *n)
Free a netlink message.
@ NLA_NESTED
nested attributes
struct nl_msg * nlmsg_alloc(void)
Allocate a new netlink message with the default maximum payload size.
int nla_put_u32(struct nl_msg *n, int attrtype, uint32_t value)
Add a u32 netlink attribute to a netlink message.
int nl_send_auto_complete(struct nl_handle *handle, struct nl_msg *msg)
Send netlink message and check & extend header values as needed.
void * nla_data(const struct nlattr *nla)
head of payload
int nla_total_size(int payload)
total length of attribute including padding
int nla_parse(struct nlattr *tb[], int maxtype, struct nlattr *head, int len, struct nla_policy *policy)
Parse a stream of attributes into a tb buffer.
void * nl_data_get(struct nl_data *data)
Get data buffer of abstract data object.
int nla_put(struct nl_msg *, int, int, const void *)
Add a netlink attribute to a netlink message.
struct nlattr * nla_next(const struct nlattr *nla, int *remaining)
next netlink attribte in attribute stream
struct nlattr * nla_reserve(struct nl_msg *n, int attrtype, int attrlen)
reserve room for attribute on the skb
int nlmsg_len(const struct nlmsghdr *nlh)
length of message payload
int nla_type(const struct nlattr *nla)
attribute type
int nla_attr_size(int payload)
length of attribute not including padding
int nla_padlen(int payload)
length of padding at the tail of the attribute