diff options
-rw-r--r-- | include/net/cfg802154.h | 3 | ||||
-rw-r--r-- | net/ieee802154/nl802154.c | 32 | ||||
-rw-r--r-- | net/ieee802154/rdev-ops.h | 9 | ||||
-rw-r--r-- | net/mac802154/cfg.c | 16 |
4 files changed, 60 insertions, 0 deletions
diff --git a/include/net/cfg802154.h b/include/net/cfg802154.h index 79b9ae0abb3b..5c3bc12706c2 100644 --- a/include/net/cfg802154.h +++ b/include/net/cfg802154.h | |||
@@ -48,6 +48,9 @@ struct cfg802154_ops { | |||
48 | int (*set_max_csma_backoffs)(struct wpan_phy *wpan_phy, | 48 | int (*set_max_csma_backoffs)(struct wpan_phy *wpan_phy, |
49 | struct wpan_dev *wpan_dev, | 49 | struct wpan_dev *wpan_dev, |
50 | u8 max_csma_backoffs); | 50 | u8 max_csma_backoffs); |
51 | int (*set_max_frame_retries)(struct wpan_phy *wpan_phy, | ||
52 | struct wpan_dev *wpan_dev, | ||
53 | s8 max_frame_retries); | ||
51 | }; | 54 | }; |
52 | 55 | ||
53 | struct wpan_phy { | 56 | struct wpan_phy { |
diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c index af383553bdd2..0e272c67c49b 100644 --- a/net/ieee802154/nl802154.c +++ b/net/ieee802154/nl802154.c | |||
@@ -667,6 +667,30 @@ nl802154_set_max_csma_backoffs(struct sk_buff *skb, struct genl_info *info) | |||
667 | return rdev_set_max_csma_backoffs(rdev, wpan_dev, max_csma_backoffs); | 667 | return rdev_set_max_csma_backoffs(rdev, wpan_dev, max_csma_backoffs); |
668 | } | 668 | } |
669 | 669 | ||
670 | static int | ||
671 | nl802154_set_max_frame_retries(struct sk_buff *skb, struct genl_info *info) | ||
672 | { | ||
673 | struct cfg802154_registered_device *rdev = info->user_ptr[0]; | ||
674 | struct net_device *dev = info->user_ptr[1]; | ||
675 | struct wpan_dev *wpan_dev = dev->ieee802154_ptr; | ||
676 | s8 max_frame_retries; | ||
677 | |||
678 | if (netif_running(dev)) | ||
679 | return -EBUSY; | ||
680 | |||
681 | if (!info->attrs[NL802154_ATTR_MAX_FRAME_RETRIES]) | ||
682 | return -EINVAL; | ||
683 | |||
684 | max_frame_retries = nla_get_s8( | ||
685 | info->attrs[NL802154_ATTR_MAX_FRAME_RETRIES]); | ||
686 | |||
687 | /* check 802.15.4 constraints */ | ||
688 | if (max_frame_retries < -1 || max_frame_retries > 7) | ||
689 | return -EINVAL; | ||
690 | |||
691 | return rdev_set_max_frame_retries(rdev, wpan_dev, max_frame_retries); | ||
692 | } | ||
693 | |||
670 | #define NL802154_FLAG_NEED_WPAN_PHY 0x01 | 694 | #define NL802154_FLAG_NEED_WPAN_PHY 0x01 |
671 | #define NL802154_FLAG_NEED_NETDEV 0x02 | 695 | #define NL802154_FLAG_NEED_NETDEV 0x02 |
672 | #define NL802154_FLAG_NEED_RTNL 0x04 | 696 | #define NL802154_FLAG_NEED_RTNL 0x04 |
@@ -817,6 +841,14 @@ static const struct genl_ops nl802154_ops[] = { | |||
817 | .internal_flags = NL802154_FLAG_NEED_NETDEV | | 841 | .internal_flags = NL802154_FLAG_NEED_NETDEV | |
818 | NL802154_FLAG_NEED_RTNL, | 842 | NL802154_FLAG_NEED_RTNL, |
819 | }, | 843 | }, |
844 | { | ||
845 | .cmd = NL802154_CMD_SET_MAX_FRAME_RETRIES, | ||
846 | .doit = nl802154_set_max_frame_retries, | ||
847 | .policy = nl802154_policy, | ||
848 | .flags = GENL_ADMIN_PERM, | ||
849 | .internal_flags = NL802154_FLAG_NEED_NETDEV | | ||
850 | NL802154_FLAG_NEED_RTNL, | ||
851 | }, | ||
820 | }; | 852 | }; |
821 | 853 | ||
822 | /* initialisation/exit functions */ | 854 | /* initialisation/exit functions */ |
diff --git a/net/ieee802154/rdev-ops.h b/net/ieee802154/rdev-ops.h index 263095c8686c..f9171aaf985e 100644 --- a/net/ieee802154/rdev-ops.h +++ b/net/ieee802154/rdev-ops.h | |||
@@ -59,4 +59,13 @@ rdev_set_max_csma_backoffs(struct cfg802154_registered_device *rdev, | |||
59 | max_csma_backoffs); | 59 | max_csma_backoffs); |
60 | } | 60 | } |
61 | 61 | ||
62 | static inline int | ||
63 | rdev_set_max_frame_retries(struct cfg802154_registered_device *rdev, | ||
64 | struct wpan_dev *wpan_dev, | ||
65 | const s8 max_frame_retries) | ||
66 | { | ||
67 | return rdev->ops->set_max_frame_retries(&rdev->wpan_phy, wpan_dev, | ||
68 | max_frame_retries); | ||
69 | } | ||
70 | |||
62 | #endif /* __CFG802154_RDEV_OPS */ | 71 | #endif /* __CFG802154_RDEV_OPS */ |
diff --git a/net/mac802154/cfg.c b/net/mac802154/cfg.c index d72feebb939d..a8f6eaa76d4d 100644 --- a/net/mac802154/cfg.c +++ b/net/mac802154/cfg.c | |||
@@ -140,6 +140,21 @@ static int ieee802154_set_max_csma_backoffs(struct wpan_phy *wpan_phy, | |||
140 | return 0; | 140 | return 0; |
141 | } | 141 | } |
142 | 142 | ||
143 | static int ieee802154_set_max_frame_retries(struct wpan_phy *wpan_phy, | ||
144 | struct wpan_dev *wpan_dev, | ||
145 | const s8 max_frame_retries) | ||
146 | { | ||
147 | struct ieee802154_local *local = wpan_phy_priv(wpan_phy); | ||
148 | |||
149 | ASSERT_RTNL(); | ||
150 | |||
151 | if (!(local->hw.flags & IEEE802154_HW_FRAME_RETRIES)) | ||
152 | return -EOPNOTSUPP; | ||
153 | |||
154 | wpan_dev->frame_retries = max_frame_retries; | ||
155 | return 0; | ||
156 | } | ||
157 | |||
143 | const struct cfg802154_ops mac802154_config_ops = { | 158 | const struct cfg802154_ops mac802154_config_ops = { |
144 | .add_virtual_intf_deprecated = ieee802154_add_iface_deprecated, | 159 | .add_virtual_intf_deprecated = ieee802154_add_iface_deprecated, |
145 | .del_virtual_intf_deprecated = ieee802154_del_iface_deprecated, | 160 | .del_virtual_intf_deprecated = ieee802154_del_iface_deprecated, |
@@ -148,4 +163,5 @@ const struct cfg802154_ops mac802154_config_ops = { | |||
148 | .set_short_addr = ieee802154_set_short_addr, | 163 | .set_short_addr = ieee802154_set_short_addr, |
149 | .set_backoff_exponent = ieee802154_set_backoff_exponent, | 164 | .set_backoff_exponent = ieee802154_set_backoff_exponent, |
150 | .set_max_csma_backoffs = ieee802154_set_max_csma_backoffs, | 165 | .set_max_csma_backoffs = ieee802154_set_max_csma_backoffs, |
166 | .set_max_frame_retries = ieee802154_set_max_frame_retries, | ||
151 | }; | 167 | }; |