xref: /openbmc/linux/include/net/ieee802154_netdev.h (revision 74a02fcf77dd760176418e1641a8624b26b357a2)
1f0166e5eSDmitry Eremin-Solenikov /*
2f0166e5eSDmitry Eremin-Solenikov  * An interface between IEEE802.15.4 device and rest of the kernel.
3f0166e5eSDmitry Eremin-Solenikov  *
4*74a02fcfSalex.bluesman.smirnov@gmail.com  * Copyright (C) 2007-2012 Siemens AG
5f0166e5eSDmitry Eremin-Solenikov  *
6f0166e5eSDmitry Eremin-Solenikov  * This program is free software; you can redistribute it and/or modify
7f0166e5eSDmitry Eremin-Solenikov  * it under the terms of the GNU General Public License version 2
8f0166e5eSDmitry Eremin-Solenikov  * as published by the Free Software Foundation.
9f0166e5eSDmitry Eremin-Solenikov  *
10f0166e5eSDmitry Eremin-Solenikov  * This program is distributed in the hope that it will be useful,
11f0166e5eSDmitry Eremin-Solenikov  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12f0166e5eSDmitry Eremin-Solenikov  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13f0166e5eSDmitry Eremin-Solenikov  * GNU General Public License for more details.
14f0166e5eSDmitry Eremin-Solenikov  *
15f0166e5eSDmitry Eremin-Solenikov  * You should have received a copy of the GNU General Public License along
16f0166e5eSDmitry Eremin-Solenikov  * with this program; if not, write to the Free Software Foundation, Inc.,
17f0166e5eSDmitry Eremin-Solenikov  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18f0166e5eSDmitry Eremin-Solenikov  *
19f0166e5eSDmitry Eremin-Solenikov  * Written by:
20f0166e5eSDmitry Eremin-Solenikov  * Pavel Smolenskiy <pavel.smolenskiy@gmail.com>
21f0166e5eSDmitry Eremin-Solenikov  * Maxim Gorbachyov <maxim.gorbachev@siemens.com>
22f0166e5eSDmitry Eremin-Solenikov  * Maxim Osipov <maxim.osipov@siemens.com>
23f0166e5eSDmitry Eremin-Solenikov  * Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
24*74a02fcfSalex.bluesman.smirnov@gmail.com  * Alexander Smirnov <alex.bluesman.smirnov@gmail.com>
25f0166e5eSDmitry Eremin-Solenikov  */
26f0166e5eSDmitry Eremin-Solenikov 
27f0166e5eSDmitry Eremin-Solenikov #ifndef IEEE802154_NETDEVICE_H
28f0166e5eSDmitry Eremin-Solenikov #define IEEE802154_NETDEVICE_H
29f0166e5eSDmitry Eremin-Solenikov 
301cd829c8Salex.bluesman.smirnov@gmail.com #include <net/af_ieee802154.h>
311cd829c8Salex.bluesman.smirnov@gmail.com 
32f0166e5eSDmitry Eremin-Solenikov /*
33f0166e5eSDmitry Eremin-Solenikov  * A control block of skb passed between the ARPHRD_IEEE802154 device
34f0166e5eSDmitry Eremin-Solenikov  * and other stack parts.
35f0166e5eSDmitry Eremin-Solenikov  */
36f0166e5eSDmitry Eremin-Solenikov struct ieee802154_mac_cb {
37f0166e5eSDmitry Eremin-Solenikov 	u8 lqi;
38f0166e5eSDmitry Eremin-Solenikov 	struct ieee802154_addr sa;
39f0166e5eSDmitry Eremin-Solenikov 	struct ieee802154_addr da;
40f0166e5eSDmitry Eremin-Solenikov 	u8 flags;
41f0166e5eSDmitry Eremin-Solenikov 	u8 seq;
42f0166e5eSDmitry Eremin-Solenikov };
43f0166e5eSDmitry Eremin-Solenikov 
44f0166e5eSDmitry Eremin-Solenikov static inline struct ieee802154_mac_cb *mac_cb(struct sk_buff *skb)
45f0166e5eSDmitry Eremin-Solenikov {
46f0166e5eSDmitry Eremin-Solenikov 	return (struct ieee802154_mac_cb *)skb->cb;
47f0166e5eSDmitry Eremin-Solenikov }
48f0166e5eSDmitry Eremin-Solenikov 
49f0166e5eSDmitry Eremin-Solenikov #define MAC_CB_FLAG_TYPEMASK		((1 << 3) - 1)
50f0166e5eSDmitry Eremin-Solenikov 
51f0166e5eSDmitry Eremin-Solenikov #define MAC_CB_FLAG_ACKREQ		(1 << 3)
52f0166e5eSDmitry Eremin-Solenikov #define MAC_CB_FLAG_SECEN		(1 << 4)
53f0166e5eSDmitry Eremin-Solenikov #define MAC_CB_FLAG_INTRAPAN		(1 << 5)
54f0166e5eSDmitry Eremin-Solenikov 
55f0166e5eSDmitry Eremin-Solenikov static inline int mac_cb_is_ackreq(struct sk_buff *skb)
56f0166e5eSDmitry Eremin-Solenikov {
57f0166e5eSDmitry Eremin-Solenikov 	return mac_cb(skb)->flags & MAC_CB_FLAG_ACKREQ;
58f0166e5eSDmitry Eremin-Solenikov }
59f0166e5eSDmitry Eremin-Solenikov 
60f0166e5eSDmitry Eremin-Solenikov static inline int mac_cb_is_secen(struct sk_buff *skb)
61f0166e5eSDmitry Eremin-Solenikov {
62f0166e5eSDmitry Eremin-Solenikov 	return mac_cb(skb)->flags & MAC_CB_FLAG_SECEN;
63f0166e5eSDmitry Eremin-Solenikov }
64f0166e5eSDmitry Eremin-Solenikov 
65f0166e5eSDmitry Eremin-Solenikov static inline int mac_cb_is_intrapan(struct sk_buff *skb)
66f0166e5eSDmitry Eremin-Solenikov {
67f0166e5eSDmitry Eremin-Solenikov 	return mac_cb(skb)->flags & MAC_CB_FLAG_INTRAPAN;
68f0166e5eSDmitry Eremin-Solenikov }
69f0166e5eSDmitry Eremin-Solenikov 
70f0166e5eSDmitry Eremin-Solenikov static inline int mac_cb_type(struct sk_buff *skb)
71f0166e5eSDmitry Eremin-Solenikov {
72f0166e5eSDmitry Eremin-Solenikov 	return mac_cb(skb)->flags & MAC_CB_FLAG_TYPEMASK;
73f0166e5eSDmitry Eremin-Solenikov }
74f0166e5eSDmitry Eremin-Solenikov 
75f0166e5eSDmitry Eremin-Solenikov #define IEEE802154_MAC_SCAN_ED		0
76f0166e5eSDmitry Eremin-Solenikov #define IEEE802154_MAC_SCAN_ACTIVE	1
77f0166e5eSDmitry Eremin-Solenikov #define IEEE802154_MAC_SCAN_PASSIVE	2
78f0166e5eSDmitry Eremin-Solenikov #define IEEE802154_MAC_SCAN_ORPHAN	3
79f0166e5eSDmitry Eremin-Solenikov 
8042723448SDmitry Eremin-Solenikov struct wpan_phy;
81f0166e5eSDmitry Eremin-Solenikov /*
82f0166e5eSDmitry Eremin-Solenikov  * This should be located at net_device->ml_priv
8342723448SDmitry Eremin-Solenikov  *
8442723448SDmitry Eremin-Solenikov  * get_phy should increment the reference counting on returned phy.
8542723448SDmitry Eremin-Solenikov  * Use wpan_wpy_put to put that reference.
86f0166e5eSDmitry Eremin-Solenikov  */
87f0166e5eSDmitry Eremin-Solenikov struct ieee802154_mlme_ops {
88f0166e5eSDmitry Eremin-Solenikov 	int (*assoc_req)(struct net_device *dev,
89f0166e5eSDmitry Eremin-Solenikov 			struct ieee802154_addr *addr,
9016eea493SDmitry Eremin-Solenikov 			u8 channel, u8 page, u8 cap);
91f0166e5eSDmitry Eremin-Solenikov 	int (*assoc_resp)(struct net_device *dev,
92f0166e5eSDmitry Eremin-Solenikov 			struct ieee802154_addr *addr,
93f0166e5eSDmitry Eremin-Solenikov 			u16 short_addr, u8 status);
94f0166e5eSDmitry Eremin-Solenikov 	int (*disassoc_req)(struct net_device *dev,
95f0166e5eSDmitry Eremin-Solenikov 			struct ieee802154_addr *addr,
96f0166e5eSDmitry Eremin-Solenikov 			u8 reason);
97f0166e5eSDmitry Eremin-Solenikov 	int (*start_req)(struct net_device *dev,
98f0166e5eSDmitry Eremin-Solenikov 			struct ieee802154_addr *addr,
9916eea493SDmitry Eremin-Solenikov 			u8 channel, u8 page, u8 bcn_ord, u8 sf_ord,
100f0166e5eSDmitry Eremin-Solenikov 			u8 pan_coord, u8 blx, u8 coord_realign);
101f0166e5eSDmitry Eremin-Solenikov 	int (*scan_req)(struct net_device *dev,
10216eea493SDmitry Eremin-Solenikov 			u8 type, u32 channels, u8 page, u8 duration);
103f0166e5eSDmitry Eremin-Solenikov 
10442723448SDmitry Eremin-Solenikov 	struct wpan_phy *(*get_phy)(const struct net_device *dev);
10542723448SDmitry Eremin-Solenikov 
106f0166e5eSDmitry Eremin-Solenikov 	/*
107f0166e5eSDmitry Eremin-Solenikov 	 * FIXME: these should become the part of PIB/MIB interface.
108f0166e5eSDmitry Eremin-Solenikov 	 * However we still don't have IB interface of any kind
109f0166e5eSDmitry Eremin-Solenikov 	 */
110a9966b58SDmitry Eremin-Solenikov 	u16 (*get_pan_id)(const struct net_device *dev);
111a9966b58SDmitry Eremin-Solenikov 	u16 (*get_short_addr)(const struct net_device *dev);
112a9966b58SDmitry Eremin-Solenikov 	u8 (*get_dsn)(const struct net_device *dev);
113a9966b58SDmitry Eremin-Solenikov 	u8 (*get_bsn)(const struct net_device *dev);
114f0166e5eSDmitry Eremin-Solenikov };
115f0166e5eSDmitry Eremin-Solenikov 
116*74a02fcfSalex.bluesman.smirnov@gmail.com /* The IEEE 802.15.4 standard defines 2 type of the devices:
117*74a02fcfSalex.bluesman.smirnov@gmail.com  * - FFD - full functionality device
118*74a02fcfSalex.bluesman.smirnov@gmail.com  * - RFD - reduce functionality device
119*74a02fcfSalex.bluesman.smirnov@gmail.com  *
120*74a02fcfSalex.bluesman.smirnov@gmail.com  * So 2 sets of mlme operations are needed
121*74a02fcfSalex.bluesman.smirnov@gmail.com  */
122*74a02fcfSalex.bluesman.smirnov@gmail.com struct ieee802154_reduced_mlme_ops {
123*74a02fcfSalex.bluesman.smirnov@gmail.com 	struct wpan_phy *(*get_phy)(const struct net_device *dev);
124*74a02fcfSalex.bluesman.smirnov@gmail.com };
125*74a02fcfSalex.bluesman.smirnov@gmail.com 
126*74a02fcfSalex.bluesman.smirnov@gmail.com static inline struct ieee802154_mlme_ops *
127*74a02fcfSalex.bluesman.smirnov@gmail.com ieee802154_mlme_ops(const struct net_device *dev)
128*74a02fcfSalex.bluesman.smirnov@gmail.com {
129*74a02fcfSalex.bluesman.smirnov@gmail.com 	return dev->ml_priv;
130*74a02fcfSalex.bluesman.smirnov@gmail.com }
131*74a02fcfSalex.bluesman.smirnov@gmail.com 
132*74a02fcfSalex.bluesman.smirnov@gmail.com static inline struct ieee802154_reduced_mlme_ops *
133*74a02fcfSalex.bluesman.smirnov@gmail.com ieee802154_reduced_mlme_ops(const struct net_device *dev)
134f0166e5eSDmitry Eremin-Solenikov {
135f0166e5eSDmitry Eremin-Solenikov 	return dev->ml_priv;
136f0166e5eSDmitry Eremin-Solenikov }
137f0166e5eSDmitry Eremin-Solenikov 
138f0166e5eSDmitry Eremin-Solenikov #endif
139