zd_rf_rf2959.c 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. /* ZD1211 USB-WLAN driver for Linux
  2. *
  3. * Copyright (C) 2005-2007 Ulrich Kunitz <kune@deine-taler.de>
  4. * Copyright (C) 2006-2007 Daniel Drake <dsd@gentoo.org>
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  19. */
  20. #include <linux/kernel.h>
  21. #include "zd_rf.h"
  22. #include "zd_usb.h"
  23. #include "zd_chip.h"
  24. static const u32 rf2959_table[][2] = {
  25. RF_CHANNEL( 1) = { 0x181979, 0x1e6666 },
  26. RF_CHANNEL( 2) = { 0x181989, 0x1e6666 },
  27. RF_CHANNEL( 3) = { 0x181999, 0x1e6666 },
  28. RF_CHANNEL( 4) = { 0x1819a9, 0x1e6666 },
  29. RF_CHANNEL( 5) = { 0x1819b9, 0x1e6666 },
  30. RF_CHANNEL( 6) = { 0x1819c9, 0x1e6666 },
  31. RF_CHANNEL( 7) = { 0x1819d9, 0x1e6666 },
  32. RF_CHANNEL( 8) = { 0x1819e9, 0x1e6666 },
  33. RF_CHANNEL( 9) = { 0x1819f9, 0x1e6666 },
  34. RF_CHANNEL(10) = { 0x181a09, 0x1e6666 },
  35. RF_CHANNEL(11) = { 0x181a19, 0x1e6666 },
  36. RF_CHANNEL(12) = { 0x181a29, 0x1e6666 },
  37. RF_CHANNEL(13) = { 0x181a39, 0x1e6666 },
  38. RF_CHANNEL(14) = { 0x181a60, 0x1c0000 },
  39. };
  40. #if 0
  41. static int bits(u32 rw, int from, int to)
  42. {
  43. rw &= ~(0xffffffffU << (to+1));
  44. rw >>= from;
  45. return rw;
  46. }
  47. static int bit(u32 rw, int bit)
  48. {
  49. return bits(rw, bit, bit);
  50. }
  51. static void dump_regwrite(u32 rw)
  52. {
  53. int reg = bits(rw, 18, 22);
  54. int rw_flag = bits(rw, 23, 23);
  55. PDEBUG("rf2959 %#010x reg %d rw %d", rw, reg, rw_flag);
  56. switch (reg) {
  57. case 0:
  58. PDEBUG("reg0 CFG1 ref_sel %d hybernate %d rf_vco_reg_en %d"
  59. " if_vco_reg_en %d if_vga_en %d",
  60. bits(rw, 14, 15), bit(rw, 3), bit(rw, 2), bit(rw, 1),
  61. bit(rw, 0));
  62. break;
  63. case 1:
  64. PDEBUG("reg1 IFPLL1 pll_en1 %d kv_en1 %d vtc_en1 %d lpf1 %d"
  65. " cpl1 %d pdp1 %d autocal_en1 %d ld_en1 %d ifloopr %d"
  66. " ifloopc %d dac1 %d",
  67. bit(rw, 17), bit(rw, 16), bit(rw, 15), bit(rw, 14),
  68. bit(rw, 13), bit(rw, 12), bit(rw, 11), bit(rw, 10),
  69. bits(rw, 7, 9), bits(rw, 4, 6), bits(rw, 0, 3));
  70. break;
  71. case 2:
  72. PDEBUG("reg2 IFPLL2 n1 %d num1 %d",
  73. bits(rw, 6, 17), bits(rw, 0, 5));
  74. break;
  75. case 3:
  76. PDEBUG("reg3 IFPLL3 num %d", bits(rw, 0, 17));
  77. break;
  78. case 4:
  79. PDEBUG("reg4 IFPLL4 dn1 %#04x ct_def1 %d kv_def1 %d",
  80. bits(rw, 8, 16), bits(rw, 4, 7), bits(rw, 0, 3));
  81. break;
  82. case 5:
  83. PDEBUG("reg5 RFPLL1 pll_en %d kv_en %d vtc_en %d lpf %d cpl %d"
  84. " pdp %d autocal_en %d ld_en %d rfloopr %d rfloopc %d"
  85. " dac %d",
  86. bit(rw, 17), bit(rw, 16), bit(rw, 15), bit(rw, 14),
  87. bit(rw, 13), bit(rw, 12), bit(rw, 11), bit(rw, 10),
  88. bits(rw, 7, 9), bits(rw, 4, 6), bits(rw, 0,3));
  89. break;
  90. case 6:
  91. PDEBUG("reg6 RFPLL2 n %d num %d",
  92. bits(rw, 6, 17), bits(rw, 0, 5));
  93. break;
  94. case 7:
  95. PDEBUG("reg7 RFPLL3 num2 %d", bits(rw, 0, 17));
  96. break;
  97. case 8:
  98. PDEBUG("reg8 RFPLL4 dn %#06x ct_def %d kv_def %d",
  99. bits(rw, 8, 16), bits(rw, 4, 7), bits(rw, 0, 3));
  100. break;
  101. case 9:
  102. PDEBUG("reg9 CAL1 tvco %d tlock %d m_ct_value %d ld_window %d",
  103. bits(rw, 13, 17), bits(rw, 8, 12), bits(rw, 3, 7),
  104. bits(rw, 0, 2));
  105. break;
  106. case 10:
  107. PDEBUG("reg10 TXRX1 rxdcfbbyps %d pcontrol %d txvgc %d"
  108. " rxlpfbw %d txlpfbw %d txdiffmode %d txenmode %d"
  109. " intbiasen %d tybypass %d",
  110. bit(rw, 17), bits(rw, 15, 16), bits(rw, 10, 14),
  111. bits(rw, 7, 9), bits(rw, 4, 6), bit(rw, 3), bit(rw, 2),
  112. bit(rw, 1), bit(rw, 0));
  113. break;
  114. case 11:
  115. PDEBUG("reg11 PCNT1 mid_bias %d p_desired %d pc_offset %d"
  116. " tx_delay %d",
  117. bits(rw, 15, 17), bits(rw, 9, 14), bits(rw, 3, 8),
  118. bits(rw, 0, 2));
  119. break;
  120. case 12:
  121. PDEBUG("reg12 PCNT2 max_power %d mid_power %d min_power %d",
  122. bits(rw, 12, 17), bits(rw, 6, 11), bits(rw, 0, 5));
  123. break;
  124. case 13:
  125. PDEBUG("reg13 VCOT1 rfpll vco comp %d ifpll vco comp %d"
  126. " lobias %d if_biasbuf %d if_biasvco %d rf_biasbuf %d"
  127. " rf_biasvco %d",
  128. bit(rw, 17), bit(rw, 16), bit(rw, 15),
  129. bits(rw, 8, 9), bits(rw, 5, 7), bits(rw, 3, 4),
  130. bits(rw, 0, 2));
  131. break;
  132. case 14:
  133. PDEBUG("reg14 IQCAL rx_acal %d rx_pcal %d"
  134. " tx_acal %d tx_pcal %d",
  135. bits(rw, 13, 17), bits(rw, 9, 12), bits(rw, 4, 8),
  136. bits(rw, 0, 3));
  137. break;
  138. }
  139. }
  140. #endif /* 0 */
  141. static int rf2959_init_hw(struct zd_rf *rf)
  142. {
  143. int r;
  144. struct zd_chip *chip = zd_rf_to_chip(rf);
  145. static const struct zd_ioreq16 ioreqs[] = {
  146. { CR2, 0x1E }, { CR9, 0x20 }, { CR10, 0x89 },
  147. { CR11, 0x00 }, { CR15, 0xD0 }, { CR17, 0x68 },
  148. { CR19, 0x4a }, { CR20, 0x0c }, { CR21, 0x0E },
  149. { CR23, 0x48 },
  150. /* normal size for cca threshold */
  151. { CR24, 0x14 },
  152. /* { CR24, 0x20 }, */
  153. { CR26, 0x90 }, { CR27, 0x30 }, { CR29, 0x20 },
  154. { CR31, 0xb2 }, { CR32, 0x43 }, { CR33, 0x28 },
  155. { CR38, 0x30 }, { CR34, 0x0f }, { CR35, 0xF0 },
  156. { CR41, 0x2a }, { CR46, 0x7F }, { CR47, 0x1E },
  157. { CR51, 0xc5 }, { CR52, 0xc5 }, { CR53, 0xc5 },
  158. { CR79, 0x58 }, { CR80, 0x30 }, { CR81, 0x30 },
  159. { CR82, 0x00 }, { CR83, 0x24 }, { CR84, 0x04 },
  160. { CR85, 0x00 }, { CR86, 0x10 }, { CR87, 0x2A },
  161. { CR88, 0x10 }, { CR89, 0x24 }, { CR90, 0x18 },
  162. /* { CR91, 0x18 }, */
  163. /* should solve continous CTS frame problems */
  164. { CR91, 0x00 },
  165. { CR92, 0x0a }, { CR93, 0x00 }, { CR94, 0x01 },
  166. { CR95, 0x00 }, { CR96, 0x40 }, { CR97, 0x37 },
  167. { CR98, 0x05 }, { CR99, 0x28 }, { CR100, 0x00 },
  168. { CR101, 0x13 }, { CR102, 0x27 }, { CR103, 0x27 },
  169. { CR104, 0x18 }, { CR105, 0x12 },
  170. /* normal size */
  171. { CR106, 0x1a },
  172. /* { CR106, 0x22 }, */
  173. { CR107, 0x24 }, { CR108, 0x0a }, { CR109, 0x13 },
  174. { CR110, 0x2F }, { CR111, 0x27 }, { CR112, 0x27 },
  175. { CR113, 0x27 }, { CR114, 0x27 }, { CR115, 0x40 },
  176. { CR116, 0x40 }, { CR117, 0xF0 }, { CR118, 0xF0 },
  177. { CR119, 0x16 },
  178. /* no TX continuation */
  179. { CR122, 0x00 },
  180. /* { CR122, 0xff }, */
  181. { CR127, 0x03 }, { CR131, 0x08 }, { CR138, 0x28 },
  182. { CR148, 0x44 }, { CR150, 0x10 }, { CR169, 0xBB },
  183. { CR170, 0xBB },
  184. };
  185. static const u32 rv[] = {
  186. 0x000007, /* REG0(CFG1) */
  187. 0x07dd43, /* REG1(IFPLL1) */
  188. 0x080959, /* REG2(IFPLL2) */
  189. 0x0e6666,
  190. 0x116a57, /* REG4 */
  191. 0x17dd43, /* REG5 */
  192. 0x1819f9, /* REG6 */
  193. 0x1e6666,
  194. 0x214554,
  195. 0x25e7fa,
  196. 0x27fffa,
  197. /* The Zydas driver somehow forgets to set this value. It's
  198. * only set for Japan. We are using internal power control
  199. * for now.
  200. */
  201. 0x294128, /* internal power */
  202. /* 0x28252c, */ /* External control TX power */
  203. /* CR31_CCK, CR51_6-36M, CR52_48M, CR53_54M */
  204. 0x2c0000,
  205. 0x300000,
  206. 0x340000, /* REG13(0xD) */
  207. 0x381e0f, /* REG14(0xE) */
  208. /* Bogus, RF2959's data sheet doesn't know register 27, which is
  209. * actually referenced here. The commented 0x11 is 17.
  210. */
  211. 0x6c180f, /* REG27(0x11) */
  212. };
  213. r = zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
  214. if (r)
  215. return r;
  216. return zd_rfwritev_locked(chip, rv, ARRAY_SIZE(rv), RF_RV_BITS);
  217. }
  218. static int rf2959_set_channel(struct zd_rf *rf, u8 channel)
  219. {
  220. int i, r;
  221. const u32 *rv = rf2959_table[channel-1];
  222. struct zd_chip *chip = zd_rf_to_chip(rf);
  223. for (i = 0; i < 2; i++) {
  224. r = zd_rfwrite_locked(chip, rv[i], RF_RV_BITS);
  225. if (r)
  226. return r;
  227. }
  228. return 0;
  229. }
  230. static int rf2959_switch_radio_on(struct zd_rf *rf)
  231. {
  232. static const struct zd_ioreq16 ioreqs[] = {
  233. { CR10, 0x89 },
  234. { CR11, 0x00 },
  235. };
  236. struct zd_chip *chip = zd_rf_to_chip(rf);
  237. return zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
  238. }
  239. static int rf2959_switch_radio_off(struct zd_rf *rf)
  240. {
  241. static const struct zd_ioreq16 ioreqs[] = {
  242. { CR10, 0x15 },
  243. { CR11, 0x81 },
  244. };
  245. struct zd_chip *chip = zd_rf_to_chip(rf);
  246. return zd_iowrite16a_locked(chip, ioreqs, ARRAY_SIZE(ioreqs));
  247. }
  248. int zd_rf_init_rf2959(struct zd_rf *rf)
  249. {
  250. struct zd_chip *chip = zd_rf_to_chip(rf);
  251. if (zd_chip_is_zd1211b(chip)) {
  252. dev_err(zd_chip_dev(chip),
  253. "RF2959 is currently not supported for ZD1211B"
  254. " devices\n");
  255. return -ENODEV;
  256. }
  257. rf->init_hw = rf2959_init_hw;
  258. rf->set_channel = rf2959_set_channel;
  259. rf->switch_radio_on = rf2959_switch_radio_on;
  260. rf->switch_radio_off = rf2959_switch_radio_off;
  261. return 0;
  262. }