blob: 36456118a6ecafb12847f699374e1fe29d3359af [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
Varka Bhadram0f999b02015-05-27 09:10:54 +053078rdev_set_tx_power(struct cfg802154_registered_device *rdev,
79 s32 power)
80{
81 int ret;
82
83 trace_802154_rdev_set_tx_power(&rdev->wpan_phy, power);
84 ret = rdev->ops->set_tx_power(&rdev->wpan_phy, power);
85 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
86 return ret;
87}
88
89static inline int
Alexander Aring702bf372014-11-12 03:36:57 +010090rdev_set_pan_id(struct cfg802154_registered_device *rdev,
Alexander Aringee7b9052014-11-17 08:20:55 +010091 struct wpan_dev *wpan_dev, __le16 pan_id)
Alexander Aring702bf372014-11-12 03:36:57 +010092{
Guido Günther1cc800e2015-04-30 17:44:55 +020093 int ret;
94
95 trace_802154_rdev_set_pan_id(&rdev->wpan_phy, wpan_dev, pan_id);
96 ret = rdev->ops->set_pan_id(&rdev->wpan_phy, wpan_dev, pan_id);
97 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
98 return ret;
Alexander Aring702bf372014-11-12 03:36:57 +010099}
100
Alexander Aring9830c622014-11-12 03:36:58 +0100101static inline int
102rdev_set_short_addr(struct cfg802154_registered_device *rdev,
Alexander Aringee7b9052014-11-17 08:20:55 +0100103 struct wpan_dev *wpan_dev, __le16 short_addr)
Alexander Aring9830c622014-11-12 03:36:58 +0100104{
Guido Günther1cc800e2015-04-30 17:44:55 +0200105 int ret;
106
107 trace_802154_rdev_set_short_addr(&rdev->wpan_phy, wpan_dev, short_addr);
108 ret = rdev->ops->set_short_addr(&rdev->wpan_phy, wpan_dev, short_addr);
109 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
110 return ret;
Alexander Aring9830c622014-11-12 03:36:58 +0100111}
112
Alexander Aring656a9992014-11-12 03:36:59 +0100113static inline int
114rdev_set_backoff_exponent(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100115 struct wpan_dev *wpan_dev, u8 min_be, u8 max_be)
Alexander Aring656a9992014-11-12 03:36:59 +0100116{
Guido Günther1cc800e2015-04-30 17:44:55 +0200117 int ret;
118
119 trace_802154_rdev_set_backoff_exponent(&rdev->wpan_phy, wpan_dev,
Alexander Aring656a9992014-11-12 03:36:59 +0100120 min_be, max_be);
Guido Günther1cc800e2015-04-30 17:44:55 +0200121 ret = rdev->ops->set_backoff_exponent(&rdev->wpan_phy, wpan_dev,
122 min_be, max_be);
123 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
124 return ret;
Alexander Aring656a9992014-11-12 03:36:59 +0100125}
126
Alexander Aringa01ba762014-11-12 03:37:01 +0100127static inline int
128rdev_set_max_csma_backoffs(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100129 struct wpan_dev *wpan_dev, u8 max_csma_backoffs)
Alexander Aringa01ba762014-11-12 03:37:01 +0100130{
Guido Günther1cc800e2015-04-30 17:44:55 +0200131 int ret;
132
133 trace_802154_rdev_set_csma_backoffs(&rdev->wpan_phy, wpan_dev,
134 max_csma_backoffs);
135 ret = rdev->ops->set_max_csma_backoffs(&rdev->wpan_phy, wpan_dev,
136 max_csma_backoffs);
137 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
138 return ret;
Alexander Aringa01ba762014-11-12 03:37:01 +0100139}
140
Alexander Aring17a3a462014-11-12 03:37:03 +0100141static inline int
142rdev_set_max_frame_retries(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100143 struct wpan_dev *wpan_dev, s8 max_frame_retries)
Alexander Aring17a3a462014-11-12 03:37:03 +0100144{
Guido Günther1cc800e2015-04-30 17:44:55 +0200145 int ret;
146
147 trace_802154_rdev_set_max_frame_retries(&rdev->wpan_phy, wpan_dev,
Alexander Aring17a3a462014-11-12 03:37:03 +0100148 max_frame_retries);
Guido Günther1cc800e2015-04-30 17:44:55 +0200149 ret = rdev->ops->set_max_frame_retries(&rdev->wpan_phy, wpan_dev,
150 max_frame_retries);
151 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
152 return ret;
Alexander Aring17a3a462014-11-12 03:37:03 +0100153}
154
Alexander Aringc8937a1d2014-11-12 03:37:05 +0100155static inline int
156rdev_set_lbt_mode(struct cfg802154_registered_device *rdev,
Alexander Aring628b1e12014-11-17 08:20:47 +0100157 struct wpan_dev *wpan_dev, bool mode)
Alexander Aringc8937a1d2014-11-12 03:37:05 +0100158{
Guido Günther1cc800e2015-04-30 17:44:55 +0200159 int ret;
160
161 trace_802154_rdev_set_lbt_mode(&rdev->wpan_phy, wpan_dev, mode);
162 ret = rdev->ops->set_lbt_mode(&rdev->wpan_phy, wpan_dev, mode);
163 trace_802154_rdev_return_int(&rdev->wpan_phy, ret);
164 return ret;
Alexander Aringc8937a1d2014-11-12 03:37:05 +0100165}
166
Alexander Aring4a9a8162014-11-02 04:18:38 +0100167#endif /* __CFG802154_RDEV_OPS */