rt2x00lib.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  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. unsigned short bitrate; /* In 100kbit/s */
  38. unsigned short ratemask;
  39. #define DEV_RATEMASK_1MB ( (1 << 1) - 1 )
  40. #define DEV_RATEMASK_2MB ( (1 << 2) - 1 )
  41. #define DEV_RATEMASK_5_5MB ( (1 << 3) - 1 )
  42. #define DEV_RATEMASK_11MB ( (1 << 4) - 1 )
  43. #define DEV_RATEMASK_6MB ( (1 << 5) - 1 )
  44. #define DEV_RATEMASK_9MB ( (1 << 6) - 1 )
  45. #define DEV_RATEMASK_12MB ( (1 << 7) - 1 )
  46. #define DEV_RATEMASK_18MB ( (1 << 8) - 1 )
  47. #define DEV_RATEMASK_24MB ( (1 << 9) - 1 )
  48. #define DEV_RATEMASK_36MB ( (1 << 10) - 1 )
  49. #define DEV_RATEMASK_48MB ( (1 << 11) - 1 )
  50. #define DEV_RATEMASK_54MB ( (1 << 12) - 1 )
  51. unsigned short plcp;
  52. };
  53. extern const struct rt2x00_rate rt2x00_supported_rates[12];
  54. static inline u16 rt2x00_create_rate_hw_value(const u16 index,
  55. const u16 short_preamble)
  56. {
  57. return (short_preamble << 8) | (index & 0xff);
  58. }
  59. static inline const struct rt2x00_rate *rt2x00_get_rate(const u16 hw_value)
  60. {
  61. return &rt2x00_supported_rates[hw_value & 0xff];
  62. }
  63. static inline int rt2x00_get_rate_preamble(const u16 hw_value)
  64. {
  65. return (hw_value & 0xff00);
  66. }
  67. /*
  68. * Radio control handlers.
  69. */
  70. int rt2x00lib_enable_radio(struct rt2x00_dev *rt2x00dev);
  71. void rt2x00lib_disable_radio(struct rt2x00_dev *rt2x00dev);
  72. void rt2x00lib_toggle_rx(struct rt2x00_dev *rt2x00dev, enum dev_state state);
  73. void rt2x00lib_reset_link_tuner(struct rt2x00_dev *rt2x00dev);
  74. /*
  75. * Initialization handlers.
  76. */
  77. int rt2x00lib_start(struct rt2x00_dev *rt2x00dev);
  78. void rt2x00lib_stop(struct rt2x00_dev *rt2x00dev);
  79. /*
  80. * Configuration handlers.
  81. */
  82. void rt2x00lib_config_intf(struct rt2x00_dev *rt2x00dev,
  83. struct rt2x00_intf *intf,
  84. enum ieee80211_if_types type,
  85. u8 *mac, u8 *bssid);
  86. void rt2x00lib_config_preamble(struct rt2x00_dev *rt2x00dev,
  87. struct rt2x00_intf *intf,
  88. const unsigned int short_preamble);
  89. void rt2x00lib_config_antenna(struct rt2x00_dev *rt2x00dev,
  90. enum antenna rx, enum antenna tx);
  91. void rt2x00lib_config(struct rt2x00_dev *rt2x00dev,
  92. struct ieee80211_conf *conf, const int force_config);
  93. /*
  94. * Queue handlers.
  95. */
  96. void rt2x00queue_init_rx(struct rt2x00_dev *rt2x00dev);
  97. void rt2x00queue_init_tx(struct rt2x00_dev *rt2x00dev);
  98. int rt2x00queue_initialize(struct rt2x00_dev *rt2x00dev);
  99. void rt2x00queue_uninitialize(struct rt2x00_dev *rt2x00dev);
  100. int rt2x00queue_allocate(struct rt2x00_dev *rt2x00dev);
  101. void rt2x00queue_free(struct rt2x00_dev *rt2x00dev);
  102. /*
  103. * Firmware handlers.
  104. */
  105. #ifdef CONFIG_RT2X00_LIB_FIRMWARE
  106. int rt2x00lib_load_firmware(struct rt2x00_dev *rt2x00dev);
  107. void rt2x00lib_free_firmware(struct rt2x00_dev *rt2x00dev);
  108. #else
  109. static inline int rt2x00lib_load_firmware(struct rt2x00_dev *rt2x00dev)
  110. {
  111. return 0;
  112. }
  113. static inline void rt2x00lib_free_firmware(struct rt2x00_dev *rt2x00dev)
  114. {
  115. }
  116. #endif /* CONFIG_RT2X00_LIB_FIRMWARE */
  117. /*
  118. * Debugfs handlers.
  119. */
  120. #ifdef CONFIG_RT2X00_LIB_DEBUGFS
  121. void rt2x00debug_register(struct rt2x00_dev *rt2x00dev);
  122. void rt2x00debug_deregister(struct rt2x00_dev *rt2x00dev);
  123. void rt2x00debug_dump_frame(struct rt2x00_dev *rt2x00dev, struct sk_buff *skb);
  124. #else
  125. static inline void rt2x00debug_register(struct rt2x00_dev *rt2x00dev)
  126. {
  127. }
  128. static inline void rt2x00debug_deregister(struct rt2x00_dev *rt2x00dev)
  129. {
  130. }
  131. static inline void rt2x00debug_dump_frame(struct rt2x00_dev *rt2x00dev,
  132. struct sk_buff *skb)
  133. {
  134. }
  135. #endif /* CONFIG_RT2X00_LIB_DEBUGFS */
  136. /*
  137. * RFkill handlers.
  138. */
  139. #ifdef CONFIG_RT2X00_LIB_RFKILL
  140. int rt2x00rfkill_register(struct rt2x00_dev *rt2x00dev);
  141. void rt2x00rfkill_unregister(struct rt2x00_dev *rt2x00dev);
  142. int rt2x00rfkill_allocate(struct rt2x00_dev *rt2x00dev);
  143. void rt2x00rfkill_free(struct rt2x00_dev *rt2x00dev);
  144. #else
  145. static inline int rt2x00rfkill_register(struct rt2x00_dev *rt2x00dev)
  146. {
  147. return 0;
  148. }
  149. static inline void rt2x00rfkill_unregister(struct rt2x00_dev *rt2x00dev)
  150. {
  151. }
  152. static inline int rt2x00rfkill_allocate(struct rt2x00_dev *rt2x00dev)
  153. {
  154. return 0;
  155. }
  156. static inline void rt2x00rfkill_free(struct rt2x00_dev *rt2x00dev)
  157. {
  158. }
  159. #endif /* CONFIG_RT2X00_LIB_RFKILL */
  160. /*
  161. * LED handlers
  162. */
  163. #ifdef CONFIG_RT2X00_LIB_LEDS
  164. void rt2x00leds_led_quality(struct rt2x00_dev *rt2x00dev, int rssi);
  165. int rt2x00leds_register(struct rt2x00_dev *rt2x00dev);
  166. void rt2x00leds_unregister(struct rt2x00_dev *rt2x00dev);
  167. void rt2x00leds_suspend(struct rt2x00_dev *rt2x00dev);
  168. void rt2x00leds_resume(struct rt2x00_dev *rt2x00dev);
  169. #else
  170. static inline void rt2x00leds_led_quality(struct rt2x00_dev *rt2x00dev,
  171. int rssi)
  172. {
  173. }
  174. static inline int rt2x00leds_register(struct rt2x00_dev *rt2x00dev)
  175. {
  176. return 0;
  177. }
  178. static inline void rt2x00leds_unregister(struct rt2x00_dev *rt2x00dev)
  179. {
  180. }
  181. static inline void rt2x00leds_suspend(struct rt2x00_dev *rt2x00dev)
  182. {
  183. }
  184. static inline void rt2x00leds_resume(struct rt2x00_dev *rt2x00dev)
  185. {
  186. }
  187. #endif /* CONFIG_RT2X00_LIB_LEDS */
  188. #endif /* RT2X00LIB_H */