rt2x00lib.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. /*
  2. Copyright (C) 2004 - 2008 rt2x00 SourceForge Project
  3. <http://rt2x00.serialmonkey.com>
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 2 of the License, or
  7. (at your option) any later version.
  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. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the
  14. Free Software Foundation, Inc.,
  15. 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  16. */
  17. /*
  18. Module: rt2x00lib
  19. Abstract: Data structures and definitions for the rt2x00lib module.
  20. */
  21. #ifndef RT2X00LIB_H
  22. #define RT2X00LIB_H
  23. /*
  24. * Interval defines
  25. * Both the link tuner as the rfkill will be called once per second.
  26. */
  27. #define LINK_TUNE_INTERVAL ( round_jiffies_relative(HZ) )
  28. #define RFKILL_POLL_INTERVAL ( 1000 )
  29. /*
  30. * rt2x00_rate: Per rate device information
  31. */
  32. struct rt2x00_rate {
  33. unsigned short flags;
  34. #define DEV_RATE_CCK 0x0001
  35. #define DEV_RATE_OFDM 0x0002
  36. #define DEV_RATE_SHORT_PREAMBLE 0x0004
  37. #define DEV_RATE_BASIC 0x0008
  38. unsigned short bitrate; /* In 100kbit/s */
  39. unsigned short ratemask;
  40. unsigned short plcp;
  41. };
  42. extern const struct rt2x00_rate rt2x00_supported_rates[12];
  43. static inline u16 rt2x00_create_rate_hw_value(const u16 index,
  44. const u16 short_preamble)
  45. {
  46. return (short_preamble << 8) | (index & 0xff);
  47. }
  48. static inline const struct rt2x00_rate *rt2x00_get_rate(const u16 hw_value)
  49. {
  50. return &rt2x00_supported_rates[hw_value & 0xff];
  51. }
  52. static inline int rt2x00_get_rate_preamble(const u16 hw_value)
  53. {
  54. return (hw_value & 0xff00);
  55. }
  56. /*
  57. * Radio control handlers.
  58. */
  59. int rt2x00lib_enable_radio(struct rt2x00_dev *rt2x00dev);
  60. void rt2x00lib_disable_radio(struct rt2x00_dev *rt2x00dev);
  61. void rt2x00lib_toggle_rx(struct rt2x00_dev *rt2x00dev, enum dev_state state);
  62. void rt2x00lib_reset_link_tuner(struct rt2x00_dev *rt2x00dev);
  63. /*
  64. * Initialization handlers.
  65. */
  66. int rt2x00lib_start(struct rt2x00_dev *rt2x00dev);
  67. void rt2x00lib_stop(struct rt2x00_dev *rt2x00dev);
  68. /*
  69. * Configuration handlers.
  70. */
  71. void rt2x00lib_config_intf(struct rt2x00_dev *rt2x00dev,
  72. struct rt2x00_intf *intf,
  73. enum ieee80211_if_types type,
  74. u8 *mac, u8 *bssid);
  75. void rt2x00lib_config_erp(struct rt2x00_dev *rt2x00dev,
  76. struct rt2x00_intf *intf,
  77. struct ieee80211_bss_conf *conf);
  78. void rt2x00lib_config_antenna(struct rt2x00_dev *rt2x00dev,
  79. enum antenna rx, enum antenna tx);
  80. void rt2x00lib_config(struct rt2x00_dev *rt2x00dev,
  81. struct ieee80211_conf *conf, const int force_config);
  82. /*
  83. * Queue handlers.
  84. */
  85. void rt2x00queue_init_rx(struct rt2x00_dev *rt2x00dev);
  86. void rt2x00queue_init_tx(struct rt2x00_dev *rt2x00dev);
  87. int rt2x00queue_initialize(struct rt2x00_dev *rt2x00dev);
  88. void rt2x00queue_uninitialize(struct rt2x00_dev *rt2x00dev);
  89. int rt2x00queue_allocate(struct rt2x00_dev *rt2x00dev);
  90. void rt2x00queue_free(struct rt2x00_dev *rt2x00dev);
  91. /*
  92. * Firmware handlers.
  93. */
  94. #ifdef CONFIG_RT2X00_LIB_FIRMWARE
  95. int rt2x00lib_load_firmware(struct rt2x00_dev *rt2x00dev);
  96. void rt2x00lib_free_firmware(struct rt2x00_dev *rt2x00dev);
  97. #else
  98. static inline int rt2x00lib_load_firmware(struct rt2x00_dev *rt2x00dev)
  99. {
  100. return 0;
  101. }
  102. static inline void rt2x00lib_free_firmware(struct rt2x00_dev *rt2x00dev)
  103. {
  104. }
  105. #endif /* CONFIG_RT2X00_LIB_FIRMWARE */
  106. /*
  107. * Debugfs handlers.
  108. */
  109. #ifdef CONFIG_RT2X00_LIB_DEBUGFS
  110. void rt2x00debug_register(struct rt2x00_dev *rt2x00dev);
  111. void rt2x00debug_deregister(struct rt2x00_dev *rt2x00dev);
  112. void rt2x00debug_dump_frame(struct rt2x00_dev *rt2x00dev, struct sk_buff *skb);
  113. #else
  114. static inline void rt2x00debug_register(struct rt2x00_dev *rt2x00dev)
  115. {
  116. }
  117. static inline void rt2x00debug_deregister(struct rt2x00_dev *rt2x00dev)
  118. {
  119. }
  120. static inline void rt2x00debug_dump_frame(struct rt2x00_dev *rt2x00dev,
  121. struct sk_buff *skb)
  122. {
  123. }
  124. #endif /* CONFIG_RT2X00_LIB_DEBUGFS */
  125. /*
  126. * RFkill handlers.
  127. */
  128. #ifdef CONFIG_RT2X00_LIB_RFKILL
  129. void rt2x00rfkill_register(struct rt2x00_dev *rt2x00dev);
  130. void rt2x00rfkill_unregister(struct rt2x00_dev *rt2x00dev);
  131. void rt2x00rfkill_allocate(struct rt2x00_dev *rt2x00dev);
  132. void rt2x00rfkill_free(struct rt2x00_dev *rt2x00dev);
  133. void rt2x00rfkill_suspend(struct rt2x00_dev *rt2x00dev);
  134. void rt2x00rfkill_resume(struct rt2x00_dev *rt2x00dev);
  135. #else
  136. static inline void rt2x00rfkill_register(struct rt2x00_dev *rt2x00dev)
  137. {
  138. }
  139. static inline void rt2x00rfkill_unregister(struct rt2x00_dev *rt2x00dev)
  140. {
  141. }
  142. static inline void rt2x00rfkill_allocate(struct rt2x00_dev *rt2x00dev)
  143. {
  144. }
  145. static inline void rt2x00rfkill_free(struct rt2x00_dev *rt2x00dev)
  146. {
  147. }
  148. static inline void rt2x00rfkill_suspend(struct rt2x00_dev *rt2x00dev)
  149. {
  150. }
  151. static inline void rt2x00rfkill_resume(struct rt2x00_dev *rt2x00dev)
  152. {
  153. }
  154. #endif /* CONFIG_RT2X00_LIB_RFKILL */
  155. /*
  156. * LED handlers
  157. */
  158. #ifdef CONFIG_RT2X00_LIB_LEDS
  159. void rt2x00leds_led_quality(struct rt2x00_dev *rt2x00dev, int rssi);
  160. void rt2x00leds_led_assoc(struct rt2x00_dev *rt2x00dev, bool enabled);
  161. void rt2x00leds_led_radio(struct rt2x00_dev *rt2x00dev, bool enabled);
  162. void rt2x00leds_register(struct rt2x00_dev *rt2x00dev);
  163. void rt2x00leds_unregister(struct rt2x00_dev *rt2x00dev);
  164. void rt2x00leds_suspend(struct rt2x00_dev *rt2x00dev);
  165. void rt2x00leds_resume(struct rt2x00_dev *rt2x00dev);
  166. #else
  167. static inline void rt2x00leds_led_quality(struct rt2x00_dev *rt2x00dev,
  168. int rssi)
  169. {
  170. }
  171. static inline void rt2x00leds_led_assoc(struct rt2x00_dev *rt2x00dev,
  172. bool enabled)
  173. {
  174. }
  175. static inline void rt2x00leds_led_radio(struct rt2x00_dev *rt2x00dev,
  176. bool enabled)
  177. {
  178. }
  179. static inline void rt2x00leds_register(struct rt2x00_dev *rt2x00dev)
  180. {
  181. }
  182. static inline void rt2x00leds_unregister(struct rt2x00_dev *rt2x00dev)
  183. {
  184. }
  185. static inline void rt2x00leds_suspend(struct rt2x00_dev *rt2x00dev)
  186. {
  187. }
  188. static inline void rt2x00leds_resume(struct rt2x00_dev *rt2x00dev)
  189. {
  190. }
  191. #endif /* CONFIG_RT2X00_LIB_LEDS */
  192. #endif /* RT2X00LIB_H */