mac802154.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /*
  2. * Copyright (C) 2007-2012 Siemens AG
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2
  6. * as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License along
  14. * with this program; if not, write to the Free Software Foundation, Inc.,
  15. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  16. *
  17. * Written by:
  18. * Pavel Smolenskiy <pavel.smolenskiy@gmail.com>
  19. * Maxim Gorbachyov <maxim.gorbachev@siemens.com>
  20. * Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
  21. * Alexander Smirnov <alex.bluesman.smirnov@gmail.com>
  22. */
  23. #ifndef MAC802154_H
  24. #define MAC802154_H
  25. /* mac802154 device private data */
  26. struct mac802154_priv {
  27. struct ieee802154_dev hw;
  28. struct ieee802154_ops *ops;
  29. /* ieee802154 phy */
  30. struct wpan_phy *phy;
  31. int open_count;
  32. /* As in mac80211 slaves list is modified:
  33. * 1) under the RTNL
  34. * 2) protected by slaves_mtx;
  35. * 3) in an RCU manner
  36. *
  37. * So atomic readers can use any of this protection methods.
  38. */
  39. struct list_head slaves;
  40. struct mutex slaves_mtx;
  41. /* This one is used for scanning and other jobs not to be interfered
  42. * with serial driver.
  43. */
  44. struct workqueue_struct *dev_workqueue;
  45. /* SoftMAC device is registered and running. One can add subinterfaces.
  46. * This flag should be modified under slaves_mtx and RTNL, so you can
  47. * read them using any of protection methods.
  48. */
  49. bool running;
  50. };
  51. #define MAC802154_DEVICE_STOPPED 0x00
  52. #define MAC802154_DEVICE_RUN 0x01
  53. /* Slave interface definition.
  54. *
  55. * Slaves represent typical network interfaces available from userspace.
  56. * Each ieee802154 device/transceiver may have several slaves and able
  57. * to be associated with several networks at the same time.
  58. */
  59. struct mac802154_sub_if_data {
  60. struct list_head list; /* the ieee802154_priv->slaves list */
  61. struct mac802154_priv *hw;
  62. struct net_device *dev;
  63. int type;
  64. spinlock_t mib_lock;
  65. __le16 pan_id;
  66. __le16 short_addr;
  67. u8 chan;
  68. u8 page;
  69. /* MAC BSN field */
  70. u8 bsn;
  71. /* MAC DSN field */
  72. u8 dsn;
  73. };
  74. #define mac802154_to_priv(_hw) container_of(_hw, struct mac802154_priv, hw)
  75. #define MAC802154_MAX_XMIT_ATTEMPTS 3
  76. #define MAC802154_CHAN_NONE (~(u8)0) /* No channel is assigned */
  77. extern struct ieee802154_reduced_mlme_ops mac802154_mlme_reduced;
  78. extern struct ieee802154_mlme_ops mac802154_mlme_wpan;
  79. int mac802154_slave_open(struct net_device *dev);
  80. int mac802154_slave_close(struct net_device *dev);
  81. void mac802154_monitors_rx(struct mac802154_priv *priv, struct sk_buff *skb);
  82. void mac802154_monitor_setup(struct net_device *dev);
  83. void mac802154_wpans_rx(struct mac802154_priv *priv, struct sk_buff *skb);
  84. void mac802154_wpan_setup(struct net_device *dev);
  85. netdev_tx_t mac802154_tx(struct mac802154_priv *priv, struct sk_buff *skb,
  86. u8 page, u8 chan);
  87. /* MIB callbacks */
  88. void mac802154_dev_set_short_addr(struct net_device *dev, u16 val);
  89. u16 mac802154_dev_get_short_addr(const struct net_device *dev);
  90. void mac802154_dev_set_ieee_addr(struct net_device *dev);
  91. u16 mac802154_dev_get_pan_id(const struct net_device *dev);
  92. void mac802154_dev_set_pan_id(struct net_device *dev, u16 val);
  93. void mac802154_dev_set_page_channel(struct net_device *dev, u8 page, u8 chan);
  94. #endif /* MAC802154_H */