blob: b2155a123f6c88980c180eeb7b4ffdcf68bea4fb [file] [log] [blame]
Alexander Aring4a9a8162014-11-02 04:18:38 +01001#ifndef __CFG802154_RDEV_OPS
2#define __CFG802154_RDEV_OPS
3
4#include <net/cfg802154.h>
5
6#include "core.h"
Guido Günther1cc800e2015-04-30 17:44:55 +02007#include "trace.h"
Alexander Aring4a9a8162014-11-02 04:18:38 +01008
9static inline struct net_device *
10rdev_add_virtual_intf_deprecated(struct cfg802154_registered_device *rdev,
Varka Bhadram5b4a10392015-04-30 17:44:57 +020011 const char *name,
12 unsigned char name_assign_type,
13 int type)
Alexander Aring4a9a8162014-11-02 04:18:38 +010014{
15 return rdev->ops->add_virtual_intf_deprecated(&rdev->wpan_phy, name,
Varka Bhadram5b4a10392015-04-30 17:44:57 +020016 name_assign_type, type);
Alexander Aring4a9a8162014-11-02 04:18:38 +010017}
18
19static inline void
20rdev_del_virtual_intf_deprecated(struct cfg802154_registered_device *rdev,
21 struct net_device *dev)
22{
23 rdev->ops->del_virtual_intf_deprecated(&rdev->wpan_phy, dev);
24}
25
Alexander Aringab0bd562014-11-12 03:36:55 +010026static inline int
Alexander Aringf3ea5e42014-11-17 08:20:51 +010027rdev_add_virtual_intf(struct cfg802154_registered_device *rdev, char *name,
Varka Bhadram5b4a10392015-04-30 17:44:57 +020028 unsigned char name_assign_type,
Alexander Aring0e575472014-11-17 08:20:52 +010029 enum nl802154_iftype type, __le64 extended_addr)
Alexander Aringf3ea5e42014-11-17 08:20:51 +010030{
Guido Günther1cc800e2015-04-30 17:44:55 +020031 int ret;
32
33 trace_802154_rdev_add_virtual_intf(&rdev->wpan_phy, name, type,
Alexander Aring0e575472014-11-17 08:20:52 +010034 extended_addr);
Varka Bhadram5b4a10392015-04-30 17:44:57 +020035 ret = rdev->ops->add_virtual_intf(&rdev->wpan_phy, name,
36 name_assign_type, type,
Guido Günther1cc800e2015-04-30 17:44:55 +020037 extended_addr);
38 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
39 return ret;
Alexander Aringf3ea5e42014-11-17 08:20:51 +010040}
41
42static inline int
Alexander Aringb821ecd2014-11-17 08:20:53 +010043rdev_del_virtual_intf(struct cfg802154_registered_device *rdev,
44 struct wpan_dev *wpan_dev)
45{
Guido Günther1cc800e2015-04-30 17:44:55 +020046 int ret;
47
48 trace_802154_rdev_del_virtual_intf(&rdev->wpan_phy, wpan_dev);
49 ret = rdev->ops->del_virtual_intf(&rdev->wpan_phy, wpan_dev);
50 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
51 return ret;
Alexander Aringb821ecd2014-11-17 08:20:53 +010052}
53
54static inline int
Alexander Aring628b1e12014-11-17 08:20:47 +010055rdev_set_channel(struct cfg802154_registered_device *rdev, u8 page, u8 channel)
Alexander Aringab0bd562014-11-12 03:36:55 +010056{
Guido Günther1cc800e2015-04-30 17:44:55 +020057 int ret;
58
59 trace_802154_rdev_set_channel(&rdev->wpan_phy, page, channel);
60 ret = rdev->ops->set_channel(&rdev->wpan_phy, page, channel);
61 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
62 return ret;
Alexander Aringab0bd562014-11-12 03:36:55 +010063}
64
Alexander Aring702bf372014-11-12 03:36:57 +010065static inline int
Alexander Aringba2a9502014-12-10 15:33:13 +010066rdev_set_cca_mode(struct cfg802154_registered_device *rdev,
67 const struct wpan_phy_cca *cca)
68{
Guido Günther1cc800e2015-04-30 17:44:55 +020069 int ret;
70
71 trace_802154_rdev_set_cca_mode(&rdev->wpan_phy, cca);
72 ret = rdev->ops->set_cca_mode(&rdev->wpan_phy, cca);
73 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
74 return ret;
Alexander Aringba2a9502014-12-10 15:33:13 +010075}
76
77static inline int
Alexander Aringb69644c2015-05-27 13:42:10 +020078rdev_set_cca_ed_level(struct cfg802154_registered_device *rdev, s32 ed_level)
79{
80 int ret;
81
82 trace_802154_rdev_set_cca_ed_level(&rdev->wpan_phy, ed_level);
83 ret = rdev->ops->set_cca_ed_level(&rdev->wpan_phy, ed_level);
84 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
85 return ret;
86}
87
88static inline int
Varka Bhadram0f999b02015-05-27 09:10:54 +053089rdev_set_tx_power(struct cfg802154_registered_device *rdev,
90 s32 power)
91{
92 int ret;
93
94 trace_802154_rdev_set_tx_power(&rdev->wpan_phy, power);
95 ret = rdev->ops->set_tx_power(&rdev->wpan_phy, power);
96 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
97 return ret;
98}
99
100static inline int
Alexander Aring702bf372014-11-12 03:36:57 +0100101rdev_set_pan_id(struct cfg802154_registered_device *rdev,
Alexander Aringee7b9052014-11-17 08:20:55 +0100102 struct wpan_dev *wpan_dev, __le16 pan_id)
Alexander Aring702bf372014-11-12 03:36:57 +0100103{
Guido Günther1cc800e2015-04-30 17:44:55 +0200104 int ret;
105
106 trace_802154_rdev_set_pan_id(&rdev->wpan_phy, wpan_dev, pan_id);
107 ret = rdev->ops->set_pan_id(&rdev->wpan_phy, wpan_dev, pan_id);
108 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
109 return ret;
Alexander Aring702bf372014-11-12 03:36:57 +0100110}
111
Alexander Aring9830c622014-11-12 03:36:58 +0100112static inline int
113rdev_set_short_addr(struct cfg802154_registered_device *rdev,
Alexander Aringee7b9052014-11-17 08:20:55 +0100114 struct wpan_dev *wpan_dev, __le16 short_addr)
Alexander Aring9830c622014-11-12 03:36:58 +0100115{
Guido Günther1cc800e2015-04-30 17:44:55 +0200116 int ret;
117
118 trace_802154_rdev_set_short_addr(&rdev->wpan_phy, wpan_dev, short_addr);
119 ret = rdev->ops->set_short_addr(&rdev->wpan_phy, wpan_dev, short_addr);
120 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
121 return ret;
Alexander Aring9830c622014-11-12 03:36:58 +0100122}
123
Alexander Aring656a9992014-11-12 03:36:59 +0100124static inline int
125rdev_set_backoff_exponent(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100126 struct wpan_dev *wpan_dev, u8 min_be, u8 max_be)
Alexander Aring656a9992014-11-12 03:36:59 +0100127{
Guido Günther1cc800e2015-04-30 17:44:55 +0200128 int ret;
129
130 trace_802154_rdev_set_backoff_exponent(&rdev->wpan_phy, wpan_dev,
Alexander Aring656a9992014-11-12 03:36:59 +0100131 min_be, max_be);
Guido Günther1cc800e2015-04-30 17:44:55 +0200132 ret = rdev->ops->set_backoff_exponent(&rdev->wpan_phy, wpan_dev,
133 min_be, max_be);
134 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
135 return ret;
Alexander Aring656a9992014-11-12 03:36:59 +0100136}
137
Alexander Aringa01ba762014-11-12 03:37:01 +0100138static inline int
139rdev_set_max_csma_backoffs(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100140 struct wpan_dev *wpan_dev, u8 max_csma_backoffs)
Alexander Aringa01ba762014-11-12 03:37:01 +0100141{
Guido Günther1cc800e2015-04-30 17:44:55 +0200142 int ret;
143
144 trace_802154_rdev_set_csma_backoffs(&rdev->wpan_phy, wpan_dev,
145 max_csma_backoffs);
146 ret = rdev->ops->set_max_csma_backoffs(&rdev->wpan_phy, wpan_dev,
147 max_csma_backoffs);
148 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
149 return ret;
Alexander Aringa01ba762014-11-12 03:37:01 +0100150}
151
Alexander Aring17a3a462014-11-12 03:37:03 +0100152static inline int
153rdev_set_max_frame_retries(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100154 struct wpan_dev *wpan_dev, s8 max_frame_retries)
Alexander Aring17a3a462014-11-12 03:37:03 +0100155{
Guido Günther1cc800e2015-04-30 17:44:55 +0200156 int ret;
157
158 trace_802154_rdev_set_max_frame_retries(&rdev->wpan_phy, wpan_dev,
Alexander Aring17a3a462014-11-12 03:37:03 +0100159 max_frame_retries);
Guido Günther1cc800e2015-04-30 17:44:55 +0200160 ret = rdev->ops->set_max_frame_retries(&rdev->wpan_phy, wpan_dev,
161 max_frame_retries);
162 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
163 return ret;
Alexander Aring17a3a462014-11-12 03:37:03 +0100164}
165
Alexander Aringc8937a1d2014-11-12 03:37:05 +0100166static inline int
167rdev_set_lbt_mode(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100168 struct wpan_dev *wpan_dev, bool mode)
Alexander Aringc8937a1d2014-11-12 03:37:05 +0100169{
Guido Günther1cc800e2015-04-30 17:44:55 +0200170 int ret;
171
172 trace_802154_rdev_set_lbt_mode(&rdev->wpan_phy, wpan_dev, mode);
173 ret = rdev->ops->set_lbt_mode(&rdev->wpan_phy, wpan_dev, mode);
174 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
175 return ret;
Alexander Aringc8937a1d2014-11-12 03:37:05 +0100176}
177
Alexander Aring4a9a8162014-11-02 04:18:38 +0100178#endif /* __CFG802154_RDEV_OPS */