priv_netlink.h revision 8d520ff1dc2da35cdca849e982051b86468016d8
1/*
2 * wpa_supplicant - Private copy of Linux netlink/rtnetlink definitions.
3 * Copyright (c) 2003-2005, Jouni Malinen <j@w1.fi>
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
8 *
9 * Alternatively, this software may be distributed under the terms of BSD
10 * license.
11 *
12 * See README and COPYING for more details.
13 */
14
15#ifndef PRIV_NETLINK_H
16#define PRIV_NETLINK_H
17
18/*
19 * This should be replaced with user space header once one is available with C
20 * library, etc..
21 */
22
23#ifndef IFF_LOWER_UP
24#define IFF_LOWER_UP   0x10000         /* driver signals L1 up         */
25#endif
26#ifndef IFF_DORMANT
27#define IFF_DORMANT    0x20000         /* driver signals dormant       */
28#endif
29
30#ifndef IFLA_IFNAME
31#define IFLA_IFNAME 3
32#endif
33#ifndef IFLA_WIRELESS
34#define IFLA_WIRELESS 11
35#endif
36#ifndef IFLA_OPERSTATE
37#define IFLA_OPERSTATE 16
38#endif
39#ifndef IFLA_LINKMODE
40#define IFLA_LINKMODE 17
41#define IF_OPER_DORMANT 5
42#define IF_OPER_UP 6
43#endif
44
45#define NLM_F_REQUEST 1
46
47#define NETLINK_ROUTE 0
48#define RTMGRP_LINK 1
49#define RTM_BASE 0x10
50#define RTM_NEWLINK (RTM_BASE + 0)
51#define RTM_DELLINK (RTM_BASE + 1)
52#define RTM_SETLINK (RTM_BASE + 3)
53
54#define NLMSG_ALIGNTO 4
55#define NLMSG_ALIGN(len) (((len) + NLMSG_ALIGNTO - 1) & ~(NLMSG_ALIGNTO - 1))
56#define NLMSG_HDRLEN ((int) NLMSG_ALIGN(sizeof(struct nlmsghdr)))
57#define NLMSG_LENGTH(len) ((len) + NLMSG_ALIGN(sizeof(struct nlmsghdr)))
58#define NLMSG_SPACE(len) NLMSG_ALIGN(NLMSG_LENGTH(len))
59#define NLMSG_DATA(nlh) ((void*) (((char*) nlh) + NLMSG_LENGTH(0)))
60#define NLMSG_NEXT(nlh,len) ((len) -= NLMSG_ALIGN((nlh)->nlmsg_len), \
61			     (struct nlmsghdr *) \
62			     (((char *)(nlh)) + NLMSG_ALIGN((nlh)->nlmsg_len)))
63#define NLMSG_OK(nlh,len) ((len) >= (int) sizeof(struct nlmsghdr) && \
64			   (nlh)->nlmsg_len >= sizeof(struct nlmsghdr) && \
65			   (int) (nlh)->nlmsg_len <= (len))
66#define NLMSG_PAYLOAD(nlh,len) ((nlh)->nlmsg_len - NLMSG_SPACE((len)))
67
68#define RTA_ALIGNTO 4
69#define RTA_ALIGN(len) (((len) + RTA_ALIGNTO - 1) & ~(RTA_ALIGNTO - 1))
70#define RTA_OK(rta,len) \
71((len) > 0 && (rta)->rta_len >= sizeof(struct rtattr) && \
72(rta)->rta_len <= (len))
73#define RTA_NEXT(rta,attrlen) \
74((attrlen) -= RTA_ALIGN((rta)->rta_len), \
75(struct rtattr *) (((char *)(rta)) + RTA_ALIGN((rta)->rta_len)))
76#define RTA_LENGTH(len) (RTA_ALIGN(sizeof(struct rtattr)) + (len))
77#define RTA_DATA(rta) ((void *) (((char *) (rta)) + RTA_LENGTH(0)))
78
79
80struct sockaddr_nl
81{
82	sa_family_t nl_family;
83	unsigned short nl_pad;
84	u32 nl_pid;
85	u32 nl_groups;
86};
87
88struct nlmsghdr
89{
90	u32 nlmsg_len;
91	u16 nlmsg_type;
92	u16 nlmsg_flags;
93	u32 nlmsg_seq;
94	u32 nlmsg_pid;
95};
96
97struct ifinfomsg
98{
99	unsigned char ifi_family;
100	unsigned char __ifi_pad;
101	unsigned short ifi_type;
102	int ifi_index;
103	unsigned ifi_flags;
104	unsigned ifi_change;
105};
106
107struct rtattr
108{
109	unsigned short rta_len;
110	unsigned short rta_type;
111};
112
113#endif /* PRIV_NETLINK_H */
114