xref: /freebsd/sys/netlink/netlink.h (revision 7e5bf68495cc0a8c9793a338a8a02009a7f6dbb6)
1*7e5bf684SAlexander V. Chernikov /*-
2*7e5bf684SAlexander V. Chernikov  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3*7e5bf684SAlexander V. Chernikov  *
4*7e5bf684SAlexander V. Chernikov  * Copyright (c) 2021 Ng Peng Nam Sean
5*7e5bf684SAlexander V. Chernikov  * Copyright (c) 2022 Alexander V. Chernikov <melifaro@FreeBSD.org>
6*7e5bf684SAlexander V. Chernikov  *
7*7e5bf684SAlexander V. Chernikov  * Redistribution and use in source and binary forms, with or without
8*7e5bf684SAlexander V. Chernikov  * modification, are permitted provided that the following conditions
9*7e5bf684SAlexander V. Chernikov  * are met:
10*7e5bf684SAlexander V. Chernikov  * 1. Redistributions of source code must retain the above copyright
11*7e5bf684SAlexander V. Chernikov  *    notice, this list of conditions and the following disclaimer.
12*7e5bf684SAlexander V. Chernikov  * 2. Redistributions in binary form must reproduce the above copyright
13*7e5bf684SAlexander V. Chernikov  *    notice, this list of conditions and the following disclaimer in the
14*7e5bf684SAlexander V. Chernikov  *    documentation and/or other materials provided with the distribution.
15*7e5bf684SAlexander V. Chernikov  *
16*7e5bf684SAlexander V. Chernikov  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17*7e5bf684SAlexander V. Chernikov  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*7e5bf684SAlexander V. Chernikov  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*7e5bf684SAlexander V. Chernikov  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20*7e5bf684SAlexander V. Chernikov  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21*7e5bf684SAlexander V. Chernikov  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22*7e5bf684SAlexander V. Chernikov  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23*7e5bf684SAlexander V. Chernikov  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24*7e5bf684SAlexander V. Chernikov  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25*7e5bf684SAlexander V. Chernikov  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*7e5bf684SAlexander V. Chernikov  * SUCH DAMAGE.
27*7e5bf684SAlexander V. Chernikov  *
28*7e5bf684SAlexander V. Chernikov  * Copyright (C) The Internet Society (2003).  All Rights Reserved.
29*7e5bf684SAlexander V. Chernikov  *
30*7e5bf684SAlexander V. Chernikov  * This document and translations of it may be copied and furnished to
31*7e5bf684SAlexander V. Chernikov  * others, and derivative works that comment on or otherwise explain it
32*7e5bf684SAlexander V. Chernikov  * or assist in its implementation may be prepared, copied, published
33*7e5bf684SAlexander V. Chernikov  * and distributed, in whole or in part, without restriction of any
34*7e5bf684SAlexander V. Chernikov  * kind, provided that the above copyright notice and this paragraph are
35*7e5bf684SAlexander V. Chernikov  * included on all such copies and derivative works.  However, this
36*7e5bf684SAlexander V. Chernikov  * document itself may not be modified in any way, such as by removing
37*7e5bf684SAlexander V. Chernikov  * the copyright notice or references to the Internet Society or other
38*7e5bf684SAlexander V. Chernikov  * Internet organizations, except as needed for the purpose of
39*7e5bf684SAlexander V. Chernikov  * developing Internet standards in which case the procedures for
40*7e5bf684SAlexander V. Chernikov  * copyrights defined in the Internet Standards process must be
41*7e5bf684SAlexander V. Chernikov  * followed, or as required to translate it into languages other than
42*7e5bf684SAlexander V. Chernikov  * English.
43*7e5bf684SAlexander V. Chernikov  *
44*7e5bf684SAlexander V. Chernikov  * The limited permissions granted above are perpetual and will not be
45*7e5bf684SAlexander V. Chernikov  * revoked by the Internet Society or its successors or assignees.
46*7e5bf684SAlexander V. Chernikov  *
47*7e5bf684SAlexander V. Chernikov  * This document and the information contained herein is provided on an
48*7e5bf684SAlexander V. Chernikov  * "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
49*7e5bf684SAlexander V. Chernikov  * TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
50*7e5bf684SAlexander V. Chernikov  * BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
51*7e5bf684SAlexander V. Chernikov  * HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
52*7e5bf684SAlexander V. Chernikov  * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
53*7e5bf684SAlexander V. Chernikov 
54*7e5bf684SAlexander V. Chernikov  */
55*7e5bf684SAlexander V. Chernikov 
56*7e5bf684SAlexander V. Chernikov /*
57*7e5bf684SAlexander V. Chernikov  * This file contains structures and constants for RFC 3549 (Netlink)
58*7e5bf684SAlexander V. Chernikov  * protocol. Some values have been taken from Linux implementation.
59*7e5bf684SAlexander V. Chernikov  */
60*7e5bf684SAlexander V. Chernikov 
61*7e5bf684SAlexander V. Chernikov #ifndef _NETLINK_NETLINK_H_
62*7e5bf684SAlexander V. Chernikov #define _NETLINK_NETLINK_H_
63*7e5bf684SAlexander V. Chernikov 
64*7e5bf684SAlexander V. Chernikov #include <sys/types.h>
65*7e5bf684SAlexander V. Chernikov #include <sys/socket.h>
66*7e5bf684SAlexander V. Chernikov 
67*7e5bf684SAlexander V. Chernikov struct sockaddr_nl {
68*7e5bf684SAlexander V. Chernikov 	uint8_t		nl_len;		/* sizeof(sockaddr_nl) */
69*7e5bf684SAlexander V. Chernikov 	sa_family_t	nl_family;	/* netlink family */
70*7e5bf684SAlexander V. Chernikov 	uint16_t	nl_pad;		/* reserved, set to 0 */
71*7e5bf684SAlexander V. Chernikov 	uint32_t	nl_pid;		/* desired port ID, 0 for auto-select */
72*7e5bf684SAlexander V. Chernikov 	uint32_t	nl_groups;	/* multicast groups mask to bind to */
73*7e5bf684SAlexander V. Chernikov };
74*7e5bf684SAlexander V. Chernikov 
75*7e5bf684SAlexander V. Chernikov #define	SOL_NETLINK			270
76*7e5bf684SAlexander V. Chernikov 
77*7e5bf684SAlexander V. Chernikov /* Netlink socket options */
78*7e5bf684SAlexander V. Chernikov #define NETLINK_ADD_MEMBERSHIP		1 /* Subscribe for the specified group notifications */
79*7e5bf684SAlexander V. Chernikov #define NETLINK_DROP_MEMBERSHIP		2 /* Unsubscribe from the specified group */
80*7e5bf684SAlexander V. Chernikov #define NETLINK_PKTINFO			3 /* XXX: not supported */
81*7e5bf684SAlexander V. Chernikov #define NETLINK_BROADCAST_ERROR		4 /* XXX: not supported */
82*7e5bf684SAlexander V. Chernikov #define NETLINK_NO_ENOBUFS		5 /* XXX: not supported */
83*7e5bf684SAlexander V. Chernikov #define NETLINK_RX_RING			6 /* XXX: not supported */
84*7e5bf684SAlexander V. Chernikov #define NETLINK_TX_RING			7 /* XXX: not supported */
85*7e5bf684SAlexander V. Chernikov #define NETLINK_LISTEN_ALL_NSID		8 /* XXX: not supported */
86*7e5bf684SAlexander V. Chernikov 
87*7e5bf684SAlexander V. Chernikov #define NETLINK_LIST_MEMBERSHIPS	9
88*7e5bf684SAlexander V. Chernikov #define NETLINK_CAP_ACK			10 /* Send only original message header in the reply */
89*7e5bf684SAlexander V. Chernikov #define NETLINK_EXT_ACK			11 /* Ack support for receiving additional TLVs in ack */
90*7e5bf684SAlexander V. Chernikov #define NETLINK_GET_STRICT_CHK		12 /* Strict header checking */
91*7e5bf684SAlexander V. Chernikov 
92*7e5bf684SAlexander V. Chernikov 
93*7e5bf684SAlexander V. Chernikov /*
94*7e5bf684SAlexander V. Chernikov  * RFC 3549, 2.3.2 Netlink Message Header
95*7e5bf684SAlexander V. Chernikov  */
96*7e5bf684SAlexander V. Chernikov struct nlmsghdr {
97*7e5bf684SAlexander V. Chernikov 	uint32_t nlmsg_len;   /* Length of message including header */
98*7e5bf684SAlexander V. Chernikov 	uint16_t nlmsg_type;  /* Message type identifier */
99*7e5bf684SAlexander V. Chernikov 	uint16_t nlmsg_flags; /* Flags (NLM_F_) */
100*7e5bf684SAlexander V. Chernikov 	uint32_t nlmsg_seq;   /* Sequence number */
101*7e5bf684SAlexander V. Chernikov 	uint32_t nlmsg_pid;   /* Sending process port ID */
102*7e5bf684SAlexander V. Chernikov };
103*7e5bf684SAlexander V. Chernikov 
104*7e5bf684SAlexander V. Chernikov /*
105*7e5bf684SAlexander V. Chernikov  * RFC 3549, 2.3.2 standard flag bits (nlmsg_flags)
106*7e5bf684SAlexander V. Chernikov  */
107*7e5bf684SAlexander V. Chernikov #define NLM_F_REQUEST		0x01	/* Indicateds request to kernel */
108*7e5bf684SAlexander V. Chernikov #define NLM_F_MULTI		0x02	/* Message is part of a group terminated by NLMSG_DONE msg */
109*7e5bf684SAlexander V. Chernikov #define NLM_F_ACK		0x04	/* Reply with ack message containing resulting error code */
110*7e5bf684SAlexander V. Chernikov #define NLM_F_ECHO		0x08	/* (not supported) Echo this request back */
111*7e5bf684SAlexander V. Chernikov #define NLM_F_DUMP_INTR		0x10	/* Dump was inconsistent due to sequence change */
112*7e5bf684SAlexander V. Chernikov #define NLM_F_DUMP_FILTERED	0x20	/* Dump was filtered as requested */
113*7e5bf684SAlexander V. Chernikov 
114*7e5bf684SAlexander V. Chernikov /*
115*7e5bf684SAlexander V. Chernikov  * RFC 3549, 2.3.2 Additional flag bits for GET requests
116*7e5bf684SAlexander V. Chernikov  */
117*7e5bf684SAlexander V. Chernikov #define NLM_F_ROOT		0x100	/* Return the complete table */
118*7e5bf684SAlexander V. Chernikov #define NLM_F_MATCH		0x200	/* Return all entries matching criteria */
119*7e5bf684SAlexander V. Chernikov #define NLM_F_ATOMIC		0x400	/* Return an atomic snapshot (ignored) */
120*7e5bf684SAlexander V. Chernikov #define NLM_F_DUMP		(NLM_F_ROOT | NLM_F_MATCH)
121*7e5bf684SAlexander V. Chernikov 
122*7e5bf684SAlexander V. Chernikov /*
123*7e5bf684SAlexander V. Chernikov  * RFC 3549, 2.3.2 Additional flag bits for NEW requests
124*7e5bf684SAlexander V. Chernikov  */
125*7e5bf684SAlexander V. Chernikov #define NLM_F_REPLACE		0x100	/* Replace existing matching config object */
126*7e5bf684SAlexander V. Chernikov #define NLM_F_EXCL		0x200	/* Don't replace the object if exists */
127*7e5bf684SAlexander V. Chernikov #define NLM_F_CREATE		0x400	/* Create if it does not exist */
128*7e5bf684SAlexander V. Chernikov #define NLM_F_APPEND		0x800	/* Add to end of list */
129*7e5bf684SAlexander V. Chernikov 
130*7e5bf684SAlexander V. Chernikov /* Modifiers to DELETE requests */
131*7e5bf684SAlexander V. Chernikov #define NLM_F_NONREC		0x100	/* Do not delete recursively */
132*7e5bf684SAlexander V. Chernikov 
133*7e5bf684SAlexander V. Chernikov /* Flags for ACK message */
134*7e5bf684SAlexander V. Chernikov #define NLM_F_CAPPED		0x100	/* request was capped */
135*7e5bf684SAlexander V. Chernikov #define NLM_F_ACK_TLVS		0x200	/* extended ACK TVLs were included */
136*7e5bf684SAlexander V. Chernikov 
137*7e5bf684SAlexander V. Chernikov /*
138*7e5bf684SAlexander V. Chernikov  * RFC 3549, 2.3.2 standard message types (nlmsg_type).
139*7e5bf684SAlexander V. Chernikov  */
140*7e5bf684SAlexander V. Chernikov #define NLMSG_NOOP		0x1	/* Message is ignored. */
141*7e5bf684SAlexander V. Chernikov #define NLMSG_ERROR		0x2	/* reply error code reporting */
142*7e5bf684SAlexander V. Chernikov #define NLMSG_DONE		0x3	/* Message terminates a multipart message. */
143*7e5bf684SAlexander V. Chernikov #define NLMSG_OVERRUN		0x4	/* overrun detected, data is lost */
144*7e5bf684SAlexander V. Chernikov 
145*7e5bf684SAlexander V. Chernikov #define NLMSG_MIN_TYPE		0x10	/* < 0x10: reserved control messages */
146*7e5bf684SAlexander V. Chernikov 
147*7e5bf684SAlexander V. Chernikov /*
148*7e5bf684SAlexander V. Chernikov  * Defition of numbers assigned to the netlink subsystems.
149*7e5bf684SAlexander V. Chernikov  */
150*7e5bf684SAlexander V. Chernikov #define NETLINK_ROUTE		0	/* Routing/device hook */
151*7e5bf684SAlexander V. Chernikov #define NETLINK_UNUSED		1	/* not supported */
152*7e5bf684SAlexander V. Chernikov #define NETLINK_USERSOCK	2	/* not supported */
153*7e5bf684SAlexander V. Chernikov #define NETLINK_FIREWALL	3	/* not supported */
154*7e5bf684SAlexander V. Chernikov #define NETLINK_SOCK_DIAG	4	/* not supported */
155*7e5bf684SAlexander V. Chernikov #define NETLINK_NFLOG		5	/* not supported */
156*7e5bf684SAlexander V. Chernikov #define NETLINK_XFRM		6	/* (not supported) PF_SETKEY */
157*7e5bf684SAlexander V. Chernikov #define NETLINK_SELINUX		7	/* not supported */
158*7e5bf684SAlexander V. Chernikov #define NETLINK_ISCSI		8	/* not supported */
159*7e5bf684SAlexander V. Chernikov #define NETLINK_AUDIT		9	/* not supported */
160*7e5bf684SAlexander V. Chernikov #define NETLINK_FIB_LOOKUP	10	/* not supported */
161*7e5bf684SAlexander V. Chernikov #define NETLINK_CONNECTOR	11	/* not supported */
162*7e5bf684SAlexander V. Chernikov #define NETLINK_NETFILTER	12	/* not supported */
163*7e5bf684SAlexander V. Chernikov #define NETLINK_IP6_FW		13	/* not supported  */
164*7e5bf684SAlexander V. Chernikov #define NETLINK_DNRTMSG		14	/* not supported */
165*7e5bf684SAlexander V. Chernikov #define NETLINK_KOBJECT_UEVENT	15	/* not supported */
166*7e5bf684SAlexander V. Chernikov #define NETLINK_GENERIC		16	/* Generic netlink (dynamic families) */
167*7e5bf684SAlexander V. Chernikov 
168*7e5bf684SAlexander V. Chernikov /*
169*7e5bf684SAlexander V. Chernikov  * RFC 3549, 2.3.2.2 The ACK Netlink Message
170*7e5bf684SAlexander V. Chernikov  */
171*7e5bf684SAlexander V. Chernikov struct nlmsgerr {
172*7e5bf684SAlexander V. Chernikov 	int	error;
173*7e5bf684SAlexander V. Chernikov 	struct	nlmsghdr msg;
174*7e5bf684SAlexander V. Chernikov };
175*7e5bf684SAlexander V. Chernikov 
176*7e5bf684SAlexander V. Chernikov enum nlmsgerr_attrs {
177*7e5bf684SAlexander V. Chernikov 	NLMSGERR_ATTR_UNUSED,
178*7e5bf684SAlexander V. Chernikov 	NLMSGERR_ATTR_MSG	= 1, /* string, error message */
179*7e5bf684SAlexander V. Chernikov 	NLMSGERR_ATTR_OFFS	= 2, /* u32, offset of the invalid attr from nl header */
180*7e5bf684SAlexander V. Chernikov 	NLMSGERR_ATTR_COOKIE	= 3, /* binary, data to pass to userland */
181*7e5bf684SAlexander V. Chernikov 	NLMSGERR_ATTR_POLICY	= 4, /* not supported */
182*7e5bf684SAlexander V. Chernikov 	__NLMSGERR_ATTR_MAX,
183*7e5bf684SAlexander V. Chernikov 	NLMSGERR_ATTR_MAX = __NLMSGERR_ATTR_MAX - 1
184*7e5bf684SAlexander V. Chernikov };
185*7e5bf684SAlexander V. Chernikov 
186*7e5bf684SAlexander V. Chernikov 
187*7e5bf684SAlexander V. Chernikov #ifndef roundup2
188*7e5bf684SAlexander V. Chernikov #define	roundup2(x, y)	(((x)+((y)-1))&(~((y)-1))) /* if y is powers of two */
189*7e5bf684SAlexander V. Chernikov #endif
190*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_ALIGN_SIZE		sizeof(uint32_t)
191*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_ALIGN(_len)		roundup2(_len, NL_ITEM_ALIGN_SIZE)
192*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_DATA(_ptr, _off)	((void *)((char *)(_ptr) + _off))
193*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_DATA_CONST(_ptr, _off)	((const void *)((const char *)(_ptr) + _off))
194*7e5bf684SAlexander V. Chernikov 
195*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_OK(_ptr, _len, _hlen, _LEN_M)	\
196*7e5bf684SAlexander V. Chernikov 	((_len) >= _hlen && _LEN_M(_ptr) >= _hlen && _LEN_M(_ptr) <= (_len))
197*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_NEXT(_ptr, _LEN_M)	((typeof(_ptr))((char *)(_ptr) + _LEN_M(_ptr)))
198*7e5bf684SAlexander V. Chernikov #define	NL_ITEM_ITER(_ptr, _len, _LEN_MACRO)	\
199*7e5bf684SAlexander V. Chernikov 	((_len) -= _LEN_MACRO(_ptr), NL_ITEM_NEXT(_ptr, _LEN_MACRO))
200*7e5bf684SAlexander V. Chernikov 
201*7e5bf684SAlexander V. Chernikov 
202*7e5bf684SAlexander V. Chernikov #ifndef _KERNEL
203*7e5bf684SAlexander V. Chernikov /* part of netlink(3) API */
204*7e5bf684SAlexander V. Chernikov #define NLMSG_ALIGNTO			NL_ITEM_ALIGN_SIZE
205*7e5bf684SAlexander V. Chernikov #define NLMSG_ALIGN(_len)		NL_ITEM_ALIGN(_len)
206*7e5bf684SAlexander V. Chernikov #define NLMSG_HDRLEN			((int)sizeof(struct nlmsghdr))
207*7e5bf684SAlexander V. Chernikov #define NLMSG_LENGTH(_len)		((_len) + NLMSG_HDRLEN)
208*7e5bf684SAlexander V. Chernikov #define NLMSG_SPACE(len)		NLMSG_ALIGN(NLMSG_LENGTH(_len))
209*7e5bf684SAlexander V. Chernikov #define NLMSG_DATA(_hdr)		NL_ITEM_DATA(_hdr, NLMSG_HDRLEN)
210*7e5bf684SAlexander V. Chernikov #define	_NLMSG_LEN(_hdr)		((int)(_hdr)->nlmsg_len)
211*7e5bf684SAlexander V. Chernikov #define	_NLMSG_ALIGNED_LEN(_hdr)	NLMSG_ALIGN(_NLMSG_LEN(_hdr))
212*7e5bf684SAlexander V. Chernikov #define	NLMSG_OK(_hdr, _len)		NL_ITEM_OK(_hdr, _len, NLMSG_HDRLEN, _NLMSG_LEN)
213*7e5bf684SAlexander V. Chernikov #define NLMSG_PAYLOAD(_hdr,_len)	(_NLMSG_LEN(_hdr) - NLMSG_SPACE((_len)))
214*7e5bf684SAlexander V. Chernikov #define	NLMSG_NEXT(_hdr, _len)		NL_ITEM_ITER(_hdr, _len, _NLMSG_ALIGNED_LEN)
215*7e5bf684SAlexander V. Chernikov 
216*7e5bf684SAlexander V. Chernikov #else
217*7e5bf684SAlexander V. Chernikov #define NLMSG_ALIGNTO 4U
218*7e5bf684SAlexander V. Chernikov #define NLMSG_ALIGN(len) (((len) + NLMSG_ALIGNTO - 1) & ~(NLMSG_ALIGNTO - 1))
219*7e5bf684SAlexander V. Chernikov #define NLMSG_HDRLEN ((int)NLMSG_ALIGN(sizeof(struct nlmsghdr)))
220*7e5bf684SAlexander V. Chernikov #endif
221*7e5bf684SAlexander V. Chernikov 
222*7e5bf684SAlexander V. Chernikov /*
223*7e5bf684SAlexander V. Chernikov  * Base netlink attribute TLV header.
224*7e5bf684SAlexander V. Chernikov  */
225*7e5bf684SAlexander V. Chernikov struct nlattr {
226*7e5bf684SAlexander V. Chernikov 	uint16_t nla_len;	/* Total attribute length */
227*7e5bf684SAlexander V. Chernikov 	uint16_t nla_type;	/* Attribute type */
228*7e5bf684SAlexander V. Chernikov };
229*7e5bf684SAlexander V. Chernikov 
230*7e5bf684SAlexander V. Chernikov /*
231*7e5bf684SAlexander V. Chernikov  *
232*7e5bf684SAlexander V. Chernikov  * nl_type field enconding:
233*7e5bf684SAlexander V. Chernikov  *
234*7e5bf684SAlexander V. Chernikov  * 0                   1
235*7e5bf684SAlexander V. Chernikov  * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6
236*7e5bf684SAlexander V. Chernikov  * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
237*7e5bf684SAlexander V. Chernikov  * |N|O|  Attribute type           |
238*7e5bf684SAlexander V. Chernikov  * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
239*7e5bf684SAlexander V. Chernikov  * N - attribute contains other attributes (mostly unused)
240*7e5bf684SAlexander V. Chernikov  * O - encoded in network byte order (mostly unused)
241*7e5bf684SAlexander V. Chernikov  * Note: N & O are mutually exclusive
242*7e5bf684SAlexander V. Chernikov  *
243*7e5bf684SAlexander V. Chernikov  * Note: attribute type value scope normally is either parent attribute
244*7e5bf684SAlexander V. Chernikov  * or the message/message group.
245*7e5bf684SAlexander V. Chernikov  */
246*7e5bf684SAlexander V. Chernikov 
247*7e5bf684SAlexander V. Chernikov #define NLA_F_NESTED (1 << 15)
248*7e5bf684SAlexander V. Chernikov #define NLA_F_NET_BYTEORDER (1 << 14)
249*7e5bf684SAlexander V. Chernikov #define NLA_TYPE_MASK ~(NLA_F_NESTED | NLA_F_NET_BYTEORDER)
250*7e5bf684SAlexander V. Chernikov 
251*7e5bf684SAlexander V. Chernikov #ifndef _KERNEL
252*7e5bf684SAlexander V. Chernikov #define	NLA_ALIGNTO	NL_ITEM_ALIGN_SIZE
253*7e5bf684SAlexander V. Chernikov #define	NLA_ALIGN(_len)	NL_ITEM_ALIGN(_len)
254*7e5bf684SAlexander V. Chernikov #define	NLA_HDRLEN	((int)sizeof(struct nlattr))
255*7e5bf684SAlexander V. Chernikov #endif
256*7e5bf684SAlexander V. Chernikov 
257*7e5bf684SAlexander V. Chernikov #endif
258