af9005-fe.c 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488
  1. /* Frontend part of the Linux driver for the Afatech 9005
  2. * USB1.1 DVB-T receiver.
  3. *
  4. * Copyright (C) 2007 Luca Olivetti (luca@ventoso.org)
  5. *
  6. * Thanks to Afatech who kindly provided information.
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  21. *
  22. * see Documentation/dvb/README.dvb-usb for more information
  23. */
  24. #include "af9005.h"
  25. #include "af9005-script.h"
  26. #include "mt2060.h"
  27. #include "qt1010.h"
  28. #include <asm/div64.h>
  29. struct af9005_fe_state {
  30. struct dvb_usb_device *d;
  31. fe_status_t stat;
  32. /* retraining parameters */
  33. u32 original_fcw;
  34. u16 original_rf_top;
  35. u16 original_if_top;
  36. u16 original_if_min;
  37. u16 original_aci0_if_top;
  38. u16 original_aci1_if_top;
  39. u16 original_aci0_if_min;
  40. u8 original_if_unplug_th;
  41. u8 original_rf_unplug_th;
  42. u8 original_dtop_if_unplug_th;
  43. u8 original_dtop_rf_unplug_th;
  44. /* statistics */
  45. u32 pre_vit_error_count;
  46. u32 pre_vit_bit_count;
  47. u32 ber;
  48. u32 post_vit_error_count;
  49. u32 post_vit_bit_count;
  50. u32 unc;
  51. u16 abort_count;
  52. int opened;
  53. int strong;
  54. unsigned long next_status_check;
  55. struct dvb_frontend frontend;
  56. };
  57. static int af9005_write_word_agc(struct dvb_usb_device *d, u16 reghi,
  58. u16 reglo, u8 pos, u8 len, u16 value)
  59. {
  60. int ret;
  61. u8 temp;
  62. if ((ret = af9005_write_ofdm_register(d, reglo, (u8) (value & 0xff))))
  63. return ret;
  64. temp = (u8) ((value & 0x0300) >> 8);
  65. return af9005_write_register_bits(d, reghi, pos, len,
  66. (u8) ((value & 0x300) >> 8));
  67. }
  68. static int af9005_read_word_agc(struct dvb_usb_device *d, u16 reghi,
  69. u16 reglo, u8 pos, u8 len, u16 * value)
  70. {
  71. int ret;
  72. u8 temp0, temp1;
  73. if ((ret = af9005_read_ofdm_register(d, reglo, &temp0)))
  74. return ret;
  75. if ((ret = af9005_read_ofdm_register(d, reghi, &temp1)))
  76. return ret;
  77. switch (pos) {
  78. case 0:
  79. *value = ((u16) (temp1 & 0x03) << 8) + (u16) temp0;
  80. break;
  81. case 2:
  82. *value = ((u16) (temp1 & 0x0C) << 6) + (u16) temp0;
  83. break;
  84. case 4:
  85. *value = ((u16) (temp1 & 0x30) << 4) + (u16) temp0;
  86. break;
  87. case 6:
  88. *value = ((u16) (temp1 & 0xC0) << 2) + (u16) temp0;
  89. break;
  90. default:
  91. err("invalid pos in read word agc");
  92. return -EINVAL;
  93. }
  94. return 0;
  95. }
  96. static int af9005_is_fecmon_available(struct dvb_frontend *fe, int *available)
  97. {
  98. struct af9005_fe_state *state = fe->demodulator_priv;
  99. int ret;
  100. u8 temp;
  101. *available = false;
  102. ret = af9005_read_register_bits(state->d, xd_p_fec_vtb_rsd_mon_en,
  103. fec_vtb_rsd_mon_en_pos,
  104. fec_vtb_rsd_mon_en_len, &temp);
  105. if (ret)
  106. return ret;
  107. if (temp & 1) {
  108. ret =
  109. af9005_read_register_bits(state->d,
  110. xd_p_reg_ofsm_read_rbc_en,
  111. reg_ofsm_read_rbc_en_pos,
  112. reg_ofsm_read_rbc_en_len, &temp);
  113. if (ret)
  114. return ret;
  115. if ((temp & 1) == 0)
  116. *available = true;
  117. }
  118. return 0;
  119. }
  120. static int af9005_get_post_vit_err_cw_count(struct dvb_frontend *fe,
  121. u32 * post_err_count,
  122. u32 * post_cw_count,
  123. u16 * abort_count)
  124. {
  125. struct af9005_fe_state *state = fe->demodulator_priv;
  126. int ret;
  127. u32 err_count;
  128. u32 cw_count;
  129. u8 temp, temp0, temp1, temp2;
  130. u16 loc_abort_count;
  131. *post_err_count = 0;
  132. *post_cw_count = 0;
  133. /* check if error bit count is ready */
  134. ret =
  135. af9005_read_register_bits(state->d, xd_r_fec_rsd_ber_rdy,
  136. fec_rsd_ber_rdy_pos, fec_rsd_ber_rdy_len,
  137. &temp);
  138. if (ret)
  139. return ret;
  140. if (!temp) {
  141. deb_info("rsd counter not ready\n");
  142. return 100;
  143. }
  144. /* get abort count */
  145. ret =
  146. af9005_read_ofdm_register(state->d,
  147. xd_r_fec_rsd_abort_packet_cnt_7_0,
  148. &temp0);
  149. if (ret)
  150. return ret;
  151. ret =
  152. af9005_read_ofdm_register(state->d,
  153. xd_r_fec_rsd_abort_packet_cnt_15_8,
  154. &temp1);
  155. if (ret)
  156. return ret;
  157. loc_abort_count = ((u16) temp1 << 8) + temp0;
  158. /* get error count */
  159. ret =
  160. af9005_read_ofdm_register(state->d, xd_r_fec_rsd_bit_err_cnt_7_0,
  161. &temp0);
  162. if (ret)
  163. return ret;
  164. ret =
  165. af9005_read_ofdm_register(state->d, xd_r_fec_rsd_bit_err_cnt_15_8,
  166. &temp1);
  167. if (ret)
  168. return ret;
  169. ret =
  170. af9005_read_ofdm_register(state->d, xd_r_fec_rsd_bit_err_cnt_23_16,
  171. &temp2);
  172. if (ret)
  173. return ret;
  174. err_count = ((u32) temp2 << 16) + ((u32) temp1 << 8) + temp0;
  175. *post_err_count = err_count - (u32) loc_abort_count *8 * 8;
  176. /* get RSD packet number */
  177. ret =
  178. af9005_read_ofdm_register(state->d, xd_p_fec_rsd_packet_unit_7_0,
  179. &temp0);
  180. if (ret)
  181. return ret;
  182. ret =
  183. af9005_read_ofdm_register(state->d, xd_p_fec_rsd_packet_unit_15_8,
  184. &temp1);
  185. if (ret)
  186. return ret;
  187. cw_count = ((u32) temp1 << 8) + temp0;
  188. if (cw_count == 0) {
  189. err("wrong RSD packet count");
  190. return -EIO;
  191. }
  192. deb_info("POST abort count %d err count %d rsd packets %d\n",
  193. loc_abort_count, err_count, cw_count);
  194. *post_cw_count = cw_count - (u32) loc_abort_count;
  195. *abort_count = loc_abort_count;
  196. return 0;
  197. }
  198. static int af9005_get_post_vit_ber(struct dvb_frontend *fe,
  199. u32 * post_err_count, u32 * post_cw_count,
  200. u16 * abort_count)
  201. {
  202. u32 loc_cw_count = 0, loc_err_count;
  203. u16 loc_abort_count = 0;
  204. int ret;
  205. ret =
  206. af9005_get_post_vit_err_cw_count(fe, &loc_err_count, &loc_cw_count,
  207. &loc_abort_count);
  208. if (ret)
  209. return ret;
  210. *post_err_count = loc_err_count;
  211. *post_cw_count = loc_cw_count * 204 * 8;
  212. *abort_count = loc_abort_count;
  213. return 0;
  214. }
  215. static int af9005_get_pre_vit_err_bit_count(struct dvb_frontend *fe,
  216. u32 * pre_err_count,
  217. u32 * pre_bit_count)
  218. {
  219. struct af9005_fe_state *state = fe->demodulator_priv;
  220. u8 temp, temp0, temp1, temp2;
  221. u32 super_frame_count, x, bits;
  222. int ret;
  223. ret =
  224. af9005_read_register_bits(state->d, xd_r_fec_vtb_ber_rdy,
  225. fec_vtb_ber_rdy_pos, fec_vtb_ber_rdy_len,
  226. &temp);
  227. if (ret)
  228. return ret;
  229. if (!temp) {
  230. deb_info("viterbi counter not ready\n");
  231. return 101; /* ERR_APO_VTB_COUNTER_NOT_READY; */
  232. }
  233. ret =
  234. af9005_read_ofdm_register(state->d, xd_r_fec_vtb_err_bit_cnt_7_0,
  235. &temp0);
  236. if (ret)
  237. return ret;
  238. ret =
  239. af9005_read_ofdm_register(state->d, xd_r_fec_vtb_err_bit_cnt_15_8,
  240. &temp1);
  241. if (ret)
  242. return ret;
  243. ret =
  244. af9005_read_ofdm_register(state->d, xd_r_fec_vtb_err_bit_cnt_23_16,
  245. &temp2);
  246. if (ret)
  247. return ret;
  248. *pre_err_count = ((u32) temp2 << 16) + ((u32) temp1 << 8) + temp0;
  249. ret =
  250. af9005_read_ofdm_register(state->d, xd_p_fec_super_frm_unit_7_0,
  251. &temp0);
  252. if (ret)
  253. return ret;
  254. ret =
  255. af9005_read_ofdm_register(state->d, xd_p_fec_super_frm_unit_15_8,
  256. &temp1);
  257. if (ret)
  258. return ret;
  259. super_frame_count = ((u32) temp1 << 8) + temp0;
  260. if (super_frame_count == 0) {
  261. deb_info("super frame count 0\n");
  262. return 102;
  263. }
  264. /* read fft mode */
  265. ret =
  266. af9005_read_register_bits(state->d, xd_g_reg_tpsd_txmod,
  267. reg_tpsd_txmod_pos, reg_tpsd_txmod_len,
  268. &temp);
  269. if (ret)
  270. return ret;
  271. if (temp == 0) {
  272. /* 2K */
  273. x = 1512;
  274. } else if (temp == 1) {
  275. /* 8k */
  276. x = 6048;
  277. } else {
  278. err("Invalid fft mode");
  279. return -EINVAL;
  280. }
  281. /* read constellation mode */
  282. ret =
  283. af9005_read_register_bits(state->d, xd_g_reg_tpsd_const,
  284. reg_tpsd_const_pos, reg_tpsd_const_len,
  285. &temp);
  286. if (ret)
  287. return ret;
  288. switch (temp) {
  289. case 0: /* QPSK */
  290. bits = 2;
  291. break;
  292. case 1: /* QAM_16 */
  293. bits = 4;
  294. break;
  295. case 2: /* QAM_64 */
  296. bits = 6;
  297. break;
  298. default:
  299. err("invalid constellation mode");
  300. return -EINVAL;
  301. }
  302. *pre_bit_count = super_frame_count * 68 * 4 * x * bits;
  303. deb_info("PRE err count %d frame count %d bit count %d\n",
  304. *pre_err_count, super_frame_count, *pre_bit_count);
  305. return 0;
  306. }
  307. static int af9005_reset_pre_viterbi(struct dvb_frontend *fe)
  308. {
  309. struct af9005_fe_state *state = fe->demodulator_priv;
  310. int ret;
  311. /* set super frame count to 1 */
  312. ret =
  313. af9005_write_ofdm_register(state->d, xd_p_fec_super_frm_unit_7_0,
  314. 1 & 0xff);
  315. if (ret)
  316. return ret;
  317. ret = af9005_write_ofdm_register(state->d, xd_p_fec_super_frm_unit_15_8,
  318. 1 >> 8);
  319. if (ret)
  320. return ret;
  321. /* reset pre viterbi error count */
  322. ret =
  323. af9005_write_register_bits(state->d, xd_p_fec_vtb_ber_rst,
  324. fec_vtb_ber_rst_pos, fec_vtb_ber_rst_len,
  325. 1);
  326. return ret;
  327. }
  328. static int af9005_reset_post_viterbi(struct dvb_frontend *fe)
  329. {
  330. struct af9005_fe_state *state = fe->demodulator_priv;
  331. int ret;
  332. /* set packet unit */
  333. ret =
  334. af9005_write_ofdm_register(state->d, xd_p_fec_rsd_packet_unit_7_0,
  335. 10000 & 0xff);
  336. if (ret)
  337. return ret;
  338. ret =
  339. af9005_write_ofdm_register(state->d, xd_p_fec_rsd_packet_unit_15_8,
  340. 10000 >> 8);
  341. if (ret)
  342. return ret;
  343. /* reset post viterbi error count */
  344. ret =
  345. af9005_write_register_bits(state->d, xd_p_fec_rsd_ber_rst,
  346. fec_rsd_ber_rst_pos, fec_rsd_ber_rst_len,
  347. 1);
  348. return ret;
  349. }
  350. static int af9005_get_statistic(struct dvb_frontend *fe)
  351. {
  352. struct af9005_fe_state *state = fe->demodulator_priv;
  353. int ret, fecavailable;
  354. u64 numerator, denominator;
  355. deb_info("GET STATISTIC\n");
  356. ret = af9005_is_fecmon_available(fe, &fecavailable);
  357. if (ret)
  358. return ret;
  359. if (!fecavailable) {
  360. deb_info("fecmon not available\n");
  361. return 0;
  362. }
  363. ret = af9005_get_pre_vit_err_bit_count(fe, &state->pre_vit_error_count,
  364. &state->pre_vit_bit_count);
  365. if (ret == 0) {
  366. af9005_reset_pre_viterbi(fe);
  367. if (state->pre_vit_bit_count > 0) {
  368. /* according to v 0.0.4 of the dvb api ber should be a multiple
  369. of 10E-9 so we have to multiply the error count by
  370. 10E9=1000000000 */
  371. numerator =
  372. (u64) state->pre_vit_error_count * (u64) 1000000000;
  373. denominator = (u64) state->pre_vit_bit_count;
  374. state->ber = do_div(numerator, denominator);
  375. } else {
  376. state->ber = 0xffffffff;
  377. }
  378. }
  379. ret = af9005_get_post_vit_ber(fe, &state->post_vit_error_count,
  380. &state->post_vit_bit_count,
  381. &state->abort_count);
  382. if (ret == 0) {
  383. ret = af9005_reset_post_viterbi(fe);
  384. state->unc += state->abort_count;
  385. if (ret)
  386. return ret;
  387. }
  388. return 0;
  389. }
  390. static int af9005_fe_refresh_state(struct dvb_frontend *fe)
  391. {
  392. struct af9005_fe_state *state = fe->demodulator_priv;
  393. if (time_after(jiffies, state->next_status_check)) {
  394. deb_info("REFRESH STATE\n");
  395. /* statistics */
  396. if (af9005_get_statistic(fe))
  397. err("get_statistic_failed");
  398. state->next_status_check = jiffies + 250 * HZ / 1000;
  399. }
  400. return 0;
  401. }
  402. static int af9005_fe_read_status(struct dvb_frontend *fe, fe_status_t * stat)
  403. {
  404. struct af9005_fe_state *state = fe->demodulator_priv;
  405. u8 temp;
  406. int ret;
  407. if (fe->ops.tuner_ops.release == NULL)
  408. return -ENODEV;
  409. *stat = 0;
  410. ret = af9005_read_register_bits(state->d, xd_p_agc_lock,
  411. agc_lock_pos, agc_lock_len, &temp);
  412. if (ret)
  413. return ret;
  414. if (temp)
  415. *stat |= FE_HAS_SIGNAL;
  416. ret = af9005_read_register_bits(state->d, xd_p_fd_tpsd_lock,
  417. fd_tpsd_lock_pos, fd_tpsd_lock_len,
  418. &temp);
  419. if (ret)
  420. return ret;
  421. if (temp)
  422. *stat |= FE_HAS_CARRIER;
  423. ret = af9005_read_register_bits(state->d,
  424. xd_r_mp2if_sync_byte_locked,
  425. mp2if_sync_byte_locked_pos,
  426. mp2if_sync_byte_locked_pos, &temp);
  427. if (ret)
  428. return ret;
  429. if (temp)
  430. *stat |= FE_HAS_SYNC | FE_HAS_VITERBI | FE_HAS_LOCK;
  431. if (state->opened)
  432. af9005_led_control(state->d, *stat & FE_HAS_LOCK);
  433. ret =
  434. af9005_read_register_bits(state->d, xd_p_reg_strong_sginal_detected,
  435. reg_strong_sginal_detected_pos,
  436. reg_strong_sginal_detected_len, &temp);
  437. if (ret)
  438. return ret;
  439. if (temp != state->strong) {
  440. deb_info("adjust for strong signal %d\n", temp);
  441. state->strong = temp;
  442. }
  443. return 0;
  444. }
  445. static int af9005_fe_read_ber(struct dvb_frontend *fe, u32 * ber)
  446. {
  447. struct af9005_fe_state *state = fe->demodulator_priv;
  448. if (fe->ops.tuner_ops.release == NULL)
  449. return -ENODEV;
  450. af9005_fe_refresh_state(fe);
  451. *ber = state->ber;
  452. return 0;
  453. }
  454. static int af9005_fe_read_unc_blocks(struct dvb_frontend *fe, u32 * unc)
  455. {
  456. struct af9005_fe_state *state = fe->demodulator_priv;
  457. if (fe->ops.tuner_ops.release == NULL)
  458. return -ENODEV;
  459. af9005_fe_refresh_state(fe);
  460. *unc = state->unc;
  461. return 0;
  462. }
  463. static int af9005_fe_read_signal_strength(struct dvb_frontend *fe,
  464. u16 * strength)
  465. {
  466. struct af9005_fe_state *state = fe->demodulator_priv;
  467. int ret;
  468. u8 if_gain, rf_gain;
  469. if (fe->ops.tuner_ops.release == NULL)
  470. return -ENODEV;
  471. ret =
  472. af9005_read_ofdm_register(state->d, xd_r_reg_aagc_rf_gain,
  473. &rf_gain);
  474. if (ret)
  475. return ret;
  476. ret =
  477. af9005_read_ofdm_register(state->d, xd_r_reg_aagc_if_gain,
  478. &if_gain);
  479. if (ret)
  480. return ret;
  481. /* this value has no real meaning, but i don't have the tables that relate
  482. the rf and if gain with the dbm, so I just scale the value */
  483. *strength = (512 - rf_gain - if_gain) << 7;
  484. return 0;
  485. }
  486. static int af9005_fe_read_snr(struct dvb_frontend *fe, u16 * snr)
  487. {
  488. /* the snr can be derived from the ber and the constellation
  489. but I don't think this kind of complex calculations belong
  490. in the driver. I may be wrong.... */
  491. return -ENOSYS;
  492. }
  493. static int af9005_fe_program_cfoe(struct dvb_usb_device *d, fe_bandwidth_t bw)
  494. {
  495. u8 temp0, temp1, temp2, temp3, buf[4];
  496. int ret;
  497. u32 NS_coeff1_2048Nu;
  498. u32 NS_coeff1_8191Nu;
  499. u32 NS_coeff1_8192Nu;
  500. u32 NS_coeff1_8193Nu;
  501. u32 NS_coeff2_2k;
  502. u32 NS_coeff2_8k;
  503. switch (bw) {
  504. case BANDWIDTH_6_MHZ:
  505. NS_coeff1_2048Nu = 0x2ADB6DC;
  506. NS_coeff1_8191Nu = 0xAB7313;
  507. NS_coeff1_8192Nu = 0xAB6DB7;
  508. NS_coeff1_8193Nu = 0xAB685C;
  509. NS_coeff2_2k = 0x156DB6E;
  510. NS_coeff2_8k = 0x55B6DC;
  511. break;
  512. case BANDWIDTH_7_MHZ:
  513. NS_coeff1_2048Nu = 0x3200001;
  514. NS_coeff1_8191Nu = 0xC80640;
  515. NS_coeff1_8192Nu = 0xC80000;
  516. NS_coeff1_8193Nu = 0xC7F9C0;
  517. NS_coeff2_2k = 0x1900000;
  518. NS_coeff2_8k = 0x640000;
  519. break;
  520. case BANDWIDTH_8_MHZ:
  521. NS_coeff1_2048Nu = 0x3924926;
  522. NS_coeff1_8191Nu = 0xE4996E;
  523. NS_coeff1_8192Nu = 0xE49249;
  524. NS_coeff1_8193Nu = 0xE48B25;
  525. NS_coeff2_2k = 0x1C92493;
  526. NS_coeff2_8k = 0x724925;
  527. break;
  528. default:
  529. err("Invalid bandwith %d.", bw);
  530. return -EINVAL;
  531. }
  532. /*
  533. * write NS_coeff1_2048Nu
  534. */
  535. temp0 = (u8) (NS_coeff1_2048Nu & 0x000000FF);
  536. temp1 = (u8) ((NS_coeff1_2048Nu & 0x0000FF00) >> 8);
  537. temp2 = (u8) ((NS_coeff1_2048Nu & 0x00FF0000) >> 16);
  538. temp3 = (u8) ((NS_coeff1_2048Nu & 0x03000000) >> 24);
  539. /* big endian to make 8051 happy */
  540. buf[0] = temp3;
  541. buf[1] = temp2;
  542. buf[2] = temp1;
  543. buf[3] = temp0;
  544. /* cfoe_NS_2k_coeff1_25_24 */
  545. ret = af9005_write_ofdm_register(d, 0xAE00, buf[0]);
  546. if (ret)
  547. return ret;
  548. /* cfoe_NS_2k_coeff1_23_16 */
  549. ret = af9005_write_ofdm_register(d, 0xAE01, buf[1]);
  550. if (ret)
  551. return ret;
  552. /* cfoe_NS_2k_coeff1_15_8 */
  553. ret = af9005_write_ofdm_register(d, 0xAE02, buf[2]);
  554. if (ret)
  555. return ret;
  556. /* cfoe_NS_2k_coeff1_7_0 */
  557. ret = af9005_write_ofdm_register(d, 0xAE03, buf[3]);
  558. if (ret)
  559. return ret;
  560. /*
  561. * write NS_coeff2_2k
  562. */
  563. temp0 = (u8) ((NS_coeff2_2k & 0x0000003F));
  564. temp1 = (u8) ((NS_coeff2_2k & 0x00003FC0) >> 6);
  565. temp2 = (u8) ((NS_coeff2_2k & 0x003FC000) >> 14);
  566. temp3 = (u8) ((NS_coeff2_2k & 0x01C00000) >> 22);
  567. /* big endian to make 8051 happy */
  568. buf[0] = temp3;
  569. buf[1] = temp2;
  570. buf[2] = temp1;
  571. buf[3] = temp0;
  572. ret = af9005_write_ofdm_register(d, 0xAE04, buf[0]);
  573. if (ret)
  574. return ret;
  575. ret = af9005_write_ofdm_register(d, 0xAE05, buf[1]);
  576. if (ret)
  577. return ret;
  578. ret = af9005_write_ofdm_register(d, 0xAE06, buf[2]);
  579. if (ret)
  580. return ret;
  581. ret = af9005_write_ofdm_register(d, 0xAE07, buf[3]);
  582. if (ret)
  583. return ret;
  584. /*
  585. * write NS_coeff1_8191Nu
  586. */
  587. temp0 = (u8) ((NS_coeff1_8191Nu & 0x000000FF));
  588. temp1 = (u8) ((NS_coeff1_8191Nu & 0x0000FF00) >> 8);
  589. temp2 = (u8) ((NS_coeff1_8191Nu & 0x00FFC000) >> 16);
  590. temp3 = (u8) ((NS_coeff1_8191Nu & 0x03000000) >> 24);
  591. /* big endian to make 8051 happy */
  592. buf[0] = temp3;
  593. buf[1] = temp2;
  594. buf[2] = temp1;
  595. buf[3] = temp0;
  596. ret = af9005_write_ofdm_register(d, 0xAE08, buf[0]);
  597. if (ret)
  598. return ret;
  599. ret = af9005_write_ofdm_register(d, 0xAE09, buf[1]);
  600. if (ret)
  601. return ret;
  602. ret = af9005_write_ofdm_register(d, 0xAE0A, buf[2]);
  603. if (ret)
  604. return ret;
  605. ret = af9005_write_ofdm_register(d, 0xAE0B, buf[3]);
  606. if (ret)
  607. return ret;
  608. /*
  609. * write NS_coeff1_8192Nu
  610. */
  611. temp0 = (u8) (NS_coeff1_8192Nu & 0x000000FF);
  612. temp1 = (u8) ((NS_coeff1_8192Nu & 0x0000FF00) >> 8);
  613. temp2 = (u8) ((NS_coeff1_8192Nu & 0x00FFC000) >> 16);
  614. temp3 = (u8) ((NS_coeff1_8192Nu & 0x03000000) >> 24);
  615. /* big endian to make 8051 happy */
  616. buf[0] = temp3;
  617. buf[1] = temp2;
  618. buf[2] = temp1;
  619. buf[3] = temp0;
  620. ret = af9005_write_ofdm_register(d, 0xAE0C, buf[0]);
  621. if (ret)
  622. return ret;
  623. ret = af9005_write_ofdm_register(d, 0xAE0D, buf[1]);
  624. if (ret)
  625. return ret;
  626. ret = af9005_write_ofdm_register(d, 0xAE0E, buf[2]);
  627. if (ret)
  628. return ret;
  629. ret = af9005_write_ofdm_register(d, 0xAE0F, buf[3]);
  630. if (ret)
  631. return ret;
  632. /*
  633. * write NS_coeff1_8193Nu
  634. */
  635. temp0 = (u8) ((NS_coeff1_8193Nu & 0x000000FF));
  636. temp1 = (u8) ((NS_coeff1_8193Nu & 0x0000FF00) >> 8);
  637. temp2 = (u8) ((NS_coeff1_8193Nu & 0x00FFC000) >> 16);
  638. temp3 = (u8) ((NS_coeff1_8193Nu & 0x03000000) >> 24);
  639. /* big endian to make 8051 happy */
  640. buf[0] = temp3;
  641. buf[1] = temp2;
  642. buf[2] = temp1;
  643. buf[3] = temp0;
  644. ret = af9005_write_ofdm_register(d, 0xAE10, buf[0]);
  645. if (ret)
  646. return ret;
  647. ret = af9005_write_ofdm_register(d, 0xAE11, buf[1]);
  648. if (ret)
  649. return ret;
  650. ret = af9005_write_ofdm_register(d, 0xAE12, buf[2]);
  651. if (ret)
  652. return ret;
  653. ret = af9005_write_ofdm_register(d, 0xAE13, buf[3]);
  654. if (ret)
  655. return ret;
  656. /*
  657. * write NS_coeff2_8k
  658. */
  659. temp0 = (u8) ((NS_coeff2_8k & 0x0000003F));
  660. temp1 = (u8) ((NS_coeff2_8k & 0x00003FC0) >> 6);
  661. temp2 = (u8) ((NS_coeff2_8k & 0x003FC000) >> 14);
  662. temp3 = (u8) ((NS_coeff2_8k & 0x01C00000) >> 22);
  663. /* big endian to make 8051 happy */
  664. buf[0] = temp3;
  665. buf[1] = temp2;
  666. buf[2] = temp1;
  667. buf[3] = temp0;
  668. ret = af9005_write_ofdm_register(d, 0xAE14, buf[0]);
  669. if (ret)
  670. return ret;
  671. ret = af9005_write_ofdm_register(d, 0xAE15, buf[1]);
  672. if (ret)
  673. return ret;
  674. ret = af9005_write_ofdm_register(d, 0xAE16, buf[2]);
  675. if (ret)
  676. return ret;
  677. ret = af9005_write_ofdm_register(d, 0xAE17, buf[3]);
  678. return ret;
  679. }
  680. static int af9005_fe_select_bw(struct dvb_usb_device *d, fe_bandwidth_t bw)
  681. {
  682. u8 temp;
  683. switch (bw) {
  684. case BANDWIDTH_6_MHZ:
  685. temp = 0;
  686. break;
  687. case BANDWIDTH_7_MHZ:
  688. temp = 1;
  689. break;
  690. case BANDWIDTH_8_MHZ:
  691. temp = 2;
  692. break;
  693. default:
  694. err("Invalid bandwith %d.", bw);
  695. return -EINVAL;
  696. }
  697. return af9005_write_register_bits(d, xd_g_reg_bw, reg_bw_pos,
  698. reg_bw_len, temp);
  699. }
  700. static int af9005_fe_power(struct dvb_frontend *fe, int on)
  701. {
  702. struct af9005_fe_state *state = fe->demodulator_priv;
  703. u8 temp = on;
  704. int ret;
  705. deb_info("power %s tuner\n", on ? "on" : "off");
  706. ret = af9005_send_command(state->d, 0x03, &temp, 1, NULL, 0);
  707. return ret;
  708. }
  709. static struct mt2060_config af9005_mt2060_config = {
  710. 0xC0
  711. };
  712. static struct qt1010_config af9005_qt1010_config = {
  713. 0xC4
  714. };
  715. static int af9005_fe_init(struct dvb_frontend *fe)
  716. {
  717. struct af9005_fe_state *state = fe->demodulator_priv;
  718. struct dvb_usb_adapter *adap = fe->dvb->priv;
  719. int ret, i, scriptlen;
  720. u8 temp, temp0 = 0, temp1 = 0, temp2 = 0;
  721. u8 buf[2];
  722. u16 if1;
  723. deb_info("in af9005_fe_init\n");
  724. /* reset */
  725. deb_info("reset\n");
  726. if ((ret =
  727. af9005_write_register_bits(state->d, xd_I2C_reg_ofdm_rst_en,
  728. 4, 1, 0x01)))
  729. return ret;
  730. if ((ret = af9005_write_ofdm_register(state->d, APO_REG_RESET, 0)))
  731. return ret;
  732. /* clear ofdm reset */
  733. deb_info("clear ofdm reset\n");
  734. for (i = 0; i < 150; i++) {
  735. if ((ret =
  736. af9005_read_ofdm_register(state->d,
  737. xd_I2C_reg_ofdm_rst, &temp)))
  738. return ret;
  739. if (temp & (regmask[reg_ofdm_rst_len - 1] << reg_ofdm_rst_pos))
  740. break;
  741. msleep(10);
  742. }
  743. if (i == 150)
  744. return -ETIMEDOUT;
  745. /*FIXME in the dump
  746. write B200 A9
  747. write xd_g_reg_ofsm_clk 7
  748. read eepr c6 (2)
  749. read eepr c7 (2)
  750. misc ctrl 3 -> 1
  751. read eepr ca (6)
  752. write xd_g_reg_ofsm_clk 0
  753. write B200 a1
  754. */
  755. ret = af9005_write_ofdm_register(state->d, 0xb200, 0xa9);
  756. if (ret)
  757. return ret;
  758. ret = af9005_write_ofdm_register(state->d, xd_g_reg_ofsm_clk, 0x07);
  759. if (ret)
  760. return ret;
  761. temp = 0x01;
  762. ret = af9005_send_command(state->d, 0x03, &temp, 1, NULL, 0);
  763. if (ret)
  764. return ret;
  765. ret = af9005_write_ofdm_register(state->d, xd_g_reg_ofsm_clk, 0x00);
  766. if (ret)
  767. return ret;
  768. ret = af9005_write_ofdm_register(state->d, 0xb200, 0xa1);
  769. if (ret)
  770. return ret;
  771. temp = regmask[reg_ofdm_rst_len - 1] << reg_ofdm_rst_pos;
  772. if ((ret =
  773. af9005_write_register_bits(state->d, xd_I2C_reg_ofdm_rst,
  774. reg_ofdm_rst_pos, reg_ofdm_rst_len, 1)))
  775. return ret;
  776. ret = af9005_write_register_bits(state->d, xd_I2C_reg_ofdm_rst,
  777. reg_ofdm_rst_pos, reg_ofdm_rst_len, 0);
  778. if (ret)
  779. return ret;
  780. /* don't know what register aefc is, but this is what the windows driver does */
  781. ret = af9005_write_ofdm_register(state->d, 0xaefc, 0);
  782. if (ret)
  783. return ret;
  784. /* set stand alone chip */
  785. deb_info("set stand alone chip\n");
  786. if ((ret =
  787. af9005_write_register_bits(state->d, xd_p_reg_dca_stand_alone,
  788. reg_dca_stand_alone_pos,
  789. reg_dca_stand_alone_len, 1)))
  790. return ret;
  791. /* set dca upper & lower chip */
  792. deb_info("set dca upper & lower chip\n");
  793. if ((ret =
  794. af9005_write_register_bits(state->d, xd_p_reg_dca_upper_chip,
  795. reg_dca_upper_chip_pos,
  796. reg_dca_upper_chip_len, 0)))
  797. return ret;
  798. if ((ret =
  799. af9005_write_register_bits(state->d, xd_p_reg_dca_lower_chip,
  800. reg_dca_lower_chip_pos,
  801. reg_dca_lower_chip_len, 0)))
  802. return ret;
  803. /* set 2wire master clock to 0x14 (for 60KHz) */
  804. deb_info("set 2wire master clock to 0x14 (for 60KHz)\n");
  805. if ((ret =
  806. af9005_write_ofdm_register(state->d, xd_I2C_i2c_m_period, 0x14)))
  807. return ret;
  808. /* clear dca enable chip */
  809. deb_info("clear dca enable chip\n");
  810. if ((ret =
  811. af9005_write_register_bits(state->d, xd_p_reg_dca_en,
  812. reg_dca_en_pos, reg_dca_en_len, 0)))
  813. return ret;
  814. /* FIXME these are register bits, but I don't know which ones */
  815. ret = af9005_write_ofdm_register(state->d, 0xa16c, 1);
  816. if (ret)
  817. return ret;
  818. ret = af9005_write_ofdm_register(state->d, 0xa3c1, 0);
  819. if (ret)
  820. return ret;
  821. /* init other parameters: program cfoe and select bandwith */
  822. deb_info("program cfoe\n");
  823. if ((ret = af9005_fe_program_cfoe(state->d, BANDWIDTH_6_MHZ)))
  824. return ret;
  825. /* set read-update bit for constellation */
  826. deb_info("set read-update bit for constellation\n");
  827. if ((ret =
  828. af9005_write_register_bits(state->d, xd_p_reg_feq_read_update,
  829. reg_feq_read_update_pos,
  830. reg_feq_read_update_len, 1)))
  831. return ret;
  832. /* sample code has a set MPEG TS code here
  833. but sniffing reveals that it doesn't do it */
  834. /* set read-update bit to 1 for DCA constellation */
  835. deb_info("set read-update bit 1 for DCA constellation\n");
  836. if ((ret =
  837. af9005_write_register_bits(state->d, xd_p_reg_dca_read_update,
  838. reg_dca_read_update_pos,
  839. reg_dca_read_update_len, 1)))
  840. return ret;
  841. /* enable fec monitor */
  842. deb_info("enable fec monitor\n");
  843. if ((ret =
  844. af9005_write_register_bits(state->d, xd_p_fec_vtb_rsd_mon_en,
  845. fec_vtb_rsd_mon_en_pos,
  846. fec_vtb_rsd_mon_en_len, 1)))
  847. return ret;
  848. /* FIXME should be register bits, I don't know which ones */
  849. ret = af9005_write_ofdm_register(state->d, 0xa601, 0);
  850. /* set api_retrain_never_freeze */
  851. deb_info("set api_retrain_never_freeze\n");
  852. if ((ret = af9005_write_ofdm_register(state->d, 0xaefb, 0x01)))
  853. return ret;
  854. /* load init script */
  855. deb_info("load init script\n");
  856. scriptlen = sizeof(script) / sizeof(RegDesc);
  857. for (i = 0; i < scriptlen; i++) {
  858. if ((ret =
  859. af9005_write_register_bits(state->d, script[i].reg,
  860. script[i].pos,
  861. script[i].len, script[i].val)))
  862. return ret;
  863. /* save 3 bytes of original fcw */
  864. if (script[i].reg == 0xae18)
  865. temp2 = script[i].val;
  866. if (script[i].reg == 0xae19)
  867. temp1 = script[i].val;
  868. if (script[i].reg == 0xae1a)
  869. temp0 = script[i].val;
  870. /* save original unplug threshold */
  871. if (script[i].reg == xd_p_reg_unplug_th)
  872. state->original_if_unplug_th = script[i].val;
  873. if (script[i].reg == xd_p_reg_unplug_rf_gain_th)
  874. state->original_rf_unplug_th = script[i].val;
  875. if (script[i].reg == xd_p_reg_unplug_dtop_if_gain_th)
  876. state->original_dtop_if_unplug_th = script[i].val;
  877. if (script[i].reg == xd_p_reg_unplug_dtop_rf_gain_th)
  878. state->original_dtop_rf_unplug_th = script[i].val;
  879. }
  880. state->original_fcw =
  881. ((u32) temp2 << 16) + ((u32) temp1 << 8) + (u32) temp0;
  882. /* save original TOPs */
  883. deb_info("save original TOPs\n");
  884. /* RF TOP */
  885. ret =
  886. af9005_read_word_agc(state->d,
  887. xd_p_reg_aagc_rf_top_numerator_9_8,
  888. xd_p_reg_aagc_rf_top_numerator_7_0, 0, 2,
  889. &state->original_rf_top);
  890. if (ret)
  891. return ret;
  892. /* IF TOP */
  893. ret =
  894. af9005_read_word_agc(state->d,
  895. xd_p_reg_aagc_if_top_numerator_9_8,
  896. xd_p_reg_aagc_if_top_numerator_7_0, 0, 2,
  897. &state->original_if_top);
  898. if (ret)
  899. return ret;
  900. /* ACI 0 IF TOP */
  901. ret =
  902. af9005_read_word_agc(state->d, 0xA60E, 0xA60A, 4, 2,
  903. &state->original_aci0_if_top);
  904. if (ret)
  905. return ret;
  906. /* ACI 1 IF TOP */
  907. ret =
  908. af9005_read_word_agc(state->d, 0xA60E, 0xA60B, 6, 2,
  909. &state->original_aci1_if_top);
  910. if (ret)
  911. return ret;
  912. /* attach tuner and init */
  913. if (fe->ops.tuner_ops.release == NULL) {
  914. /* read tuner and board id from eeprom */
  915. ret = af9005_read_eeprom(adap->dev, 0xc6, buf, 2);
  916. if (ret) {
  917. err("Impossible to read EEPROM\n");
  918. return ret;
  919. }
  920. deb_info("Tuner id %d, board id %d\n", buf[0], buf[1]);
  921. switch (buf[0]) {
  922. case 2: /* MT2060 */
  923. /* read if1 from eeprom */
  924. ret = af9005_read_eeprom(adap->dev, 0xc8, buf, 2);
  925. if (ret) {
  926. err("Impossible to read EEPROM\n");
  927. return ret;
  928. }
  929. if1 = (u16) (buf[0] << 8) + buf[1];
  930. if (dvb_attach(mt2060_attach, fe, &adap->dev->i2c_adap,
  931. &af9005_mt2060_config, if1) == NULL) {
  932. deb_info("MT2060 attach failed\n");
  933. return -ENODEV;
  934. }
  935. break;
  936. case 3: /* QT1010 */
  937. case 9: /* QT1010B */
  938. if (dvb_attach(qt1010_attach, fe, &adap->dev->i2c_adap,
  939. &af9005_qt1010_config) ==NULL) {
  940. deb_info("QT1010 attach failed\n");
  941. return -ENODEV;
  942. }
  943. break;
  944. default:
  945. err("Unsupported tuner type %d", buf[0]);
  946. return -ENODEV;
  947. }
  948. ret = fe->ops.tuner_ops.init(fe);
  949. if (ret)
  950. return ret;
  951. }
  952. deb_info("profit!\n");
  953. return 0;
  954. }
  955. static int af9005_fe_sleep(struct dvb_frontend *fe)
  956. {
  957. return af9005_fe_power(fe, 0);
  958. }
  959. static int af9005_ts_bus_ctrl(struct dvb_frontend *fe, int acquire)
  960. {
  961. struct af9005_fe_state *state = fe->demodulator_priv;
  962. if (acquire) {
  963. state->opened++;
  964. } else {
  965. state->opened--;
  966. if (!state->opened)
  967. af9005_led_control(state->d, 0);
  968. }
  969. return 0;
  970. }
  971. static int af9005_fe_set_frontend(struct dvb_frontend *fe,
  972. struct dvb_frontend_parameters *fep)
  973. {
  974. struct af9005_fe_state *state = fe->demodulator_priv;
  975. int ret;
  976. u8 temp, temp0, temp1, temp2;
  977. deb_info("af9005_fe_set_frontend freq %d bw %d\n", fep->frequency,
  978. fep->u.ofdm.bandwidth);
  979. if (fe->ops.tuner_ops.release == NULL) {
  980. err("Tuner not attached");
  981. return -ENODEV;
  982. }
  983. deb_info("turn off led\n");
  984. /* not in the log */
  985. ret = af9005_led_control(state->d, 0);
  986. if (ret)
  987. return ret;
  988. /* not sure about the bits */
  989. ret = af9005_write_register_bits(state->d, XD_MP2IF_MISC, 2, 1, 0);
  990. if (ret)
  991. return ret;
  992. /* set FCW to default value */
  993. deb_info("set FCW to default value\n");
  994. temp0 = (u8) (state->original_fcw & 0x000000ff);
  995. temp1 = (u8) ((state->original_fcw & 0x0000ff00) >> 8);
  996. temp2 = (u8) ((state->original_fcw & 0x00ff0000) >> 16);
  997. ret = af9005_write_ofdm_register(state->d, 0xae1a, temp0);
  998. if (ret)
  999. return ret;
  1000. ret = af9005_write_ofdm_register(state->d, 0xae19, temp1);
  1001. if (ret)
  1002. return ret;
  1003. ret = af9005_write_ofdm_register(state->d, 0xae18, temp2);
  1004. if (ret)
  1005. return ret;
  1006. /* restore original TOPs */
  1007. deb_info("restore original TOPs\n");
  1008. ret =
  1009. af9005_write_word_agc(state->d,
  1010. xd_p_reg_aagc_rf_top_numerator_9_8,
  1011. xd_p_reg_aagc_rf_top_numerator_7_0, 0, 2,
  1012. state->original_rf_top);
  1013. if (ret)
  1014. return ret;
  1015. ret =
  1016. af9005_write_word_agc(state->d,
  1017. xd_p_reg_aagc_if_top_numerator_9_8,
  1018. xd_p_reg_aagc_if_top_numerator_7_0, 0, 2,
  1019. state->original_if_top);
  1020. if (ret)
  1021. return ret;
  1022. ret =
  1023. af9005_write_word_agc(state->d, 0xA60E, 0xA60A, 4, 2,
  1024. state->original_aci0_if_top);
  1025. if (ret)
  1026. return ret;
  1027. ret =
  1028. af9005_write_word_agc(state->d, 0xA60E, 0xA60B, 6, 2,
  1029. state->original_aci1_if_top);
  1030. if (ret)
  1031. return ret;
  1032. /* select bandwith */
  1033. deb_info("select bandwidth");
  1034. ret = af9005_fe_select_bw(state->d, fep->u.ofdm.bandwidth);
  1035. if (ret)
  1036. return ret;
  1037. ret = af9005_fe_program_cfoe(state->d, fep->u.ofdm.bandwidth);
  1038. if (ret)
  1039. return ret;
  1040. /* clear easy mode flag */
  1041. deb_info("clear easy mode flag\n");
  1042. ret = af9005_write_ofdm_register(state->d, 0xaefd, 0);
  1043. if (ret)
  1044. return ret;
  1045. /* set unplug threshold to original value */
  1046. deb_info("set unplug threshold to original value\n");
  1047. ret =
  1048. af9005_write_ofdm_register(state->d, xd_p_reg_unplug_th,
  1049. state->original_if_unplug_th);
  1050. if (ret)
  1051. return ret;
  1052. /* set tuner */
  1053. deb_info("set tuner\n");
  1054. ret = fe->ops.tuner_ops.set_params(fe, fep);
  1055. if (ret)
  1056. return ret;
  1057. /* trigger ofsm */
  1058. deb_info("trigger ofsm\n");
  1059. temp = 0;
  1060. ret = af9005_write_tuner_registers(state->d, 0xffff, &temp, 1);
  1061. if (ret)
  1062. return ret;
  1063. /* clear retrain and freeze flag */
  1064. deb_info("clear retrain and freeze flag\n");
  1065. ret =
  1066. af9005_write_register_bits(state->d,
  1067. xd_p_reg_api_retrain_request,
  1068. reg_api_retrain_request_pos, 2, 0);
  1069. if (ret)
  1070. return ret;
  1071. /* reset pre viterbi and post viterbi registers and statistics */
  1072. af9005_reset_pre_viterbi(fe);
  1073. af9005_reset_post_viterbi(fe);
  1074. state->pre_vit_error_count = 0;
  1075. state->pre_vit_bit_count = 0;
  1076. state->ber = 0;
  1077. state->post_vit_error_count = 0;
  1078. /* state->unc = 0; commented out since it should be ever increasing */
  1079. state->abort_count = 0;
  1080. state->next_status_check = jiffies;
  1081. state->strong = -1;
  1082. return 0;
  1083. }
  1084. static int af9005_fe_get_frontend(struct dvb_frontend *fe,
  1085. struct dvb_frontend_parameters *fep)
  1086. {
  1087. struct af9005_fe_state *state = fe->demodulator_priv;
  1088. int ret;
  1089. u8 temp;
  1090. /* mode */
  1091. ret =
  1092. af9005_read_register_bits(state->d, xd_g_reg_tpsd_const,
  1093. reg_tpsd_const_pos, reg_tpsd_const_len,
  1094. &temp);
  1095. if (ret)
  1096. return ret;
  1097. deb_info("===== fe_get_frontend ==============\n");
  1098. deb_info("CONSTELLATION ");
  1099. switch (temp) {
  1100. case 0:
  1101. fep->u.ofdm.constellation = QPSK;
  1102. deb_info("QPSK\n");
  1103. break;
  1104. case 1:
  1105. fep->u.ofdm.constellation = QAM_16;
  1106. deb_info("QAM_16\n");
  1107. break;
  1108. case 2:
  1109. fep->u.ofdm.constellation = QAM_64;
  1110. deb_info("QAM_64\n");
  1111. break;
  1112. }
  1113. /* tps hierarchy and alpha value */
  1114. ret =
  1115. af9005_read_register_bits(state->d, xd_g_reg_tpsd_hier,
  1116. reg_tpsd_hier_pos, reg_tpsd_hier_len,
  1117. &temp);
  1118. if (ret)
  1119. return ret;
  1120. deb_info("HIERARCHY ");
  1121. switch (temp) {
  1122. case 0:
  1123. fep->u.ofdm.hierarchy_information = HIERARCHY_NONE;
  1124. deb_info("NONE\n");
  1125. break;
  1126. case 1:
  1127. fep->u.ofdm.hierarchy_information = HIERARCHY_1;
  1128. deb_info("1\n");
  1129. break;
  1130. case 2:
  1131. fep->u.ofdm.hierarchy_information = HIERARCHY_2;
  1132. deb_info("2\n");
  1133. break;
  1134. case 3:
  1135. fep->u.ofdm.hierarchy_information = HIERARCHY_4;
  1136. deb_info("4\n");
  1137. break;
  1138. }
  1139. /* high/low priority */
  1140. ret =
  1141. af9005_read_register_bits(state->d, xd_g_reg_dec_pri,
  1142. reg_dec_pri_pos, reg_dec_pri_len, &temp);
  1143. if (ret)
  1144. return ret;
  1145. /* if temp is set = high priority */
  1146. deb_info("PRIORITY %s\n", temp ? "high" : "low");
  1147. /* high coderate */
  1148. ret =
  1149. af9005_read_register_bits(state->d, xd_g_reg_tpsd_hpcr,
  1150. reg_tpsd_hpcr_pos, reg_tpsd_hpcr_len,
  1151. &temp);
  1152. if (ret)
  1153. return ret;
  1154. deb_info("CODERATE HP ");
  1155. switch (temp) {
  1156. case 0:
  1157. fep->u.ofdm.code_rate_HP = FEC_1_2;
  1158. deb_info("FEC_1_2\n");
  1159. break;
  1160. case 1:
  1161. fep->u.ofdm.code_rate_HP = FEC_2_3;
  1162. deb_info("FEC_2_3\n");
  1163. break;
  1164. case 2:
  1165. fep->u.ofdm.code_rate_HP = FEC_3_4;
  1166. deb_info("FEC_3_4\n");
  1167. break;
  1168. case 3:
  1169. fep->u.ofdm.code_rate_HP = FEC_5_6;
  1170. deb_info("FEC_5_6\n");
  1171. break;
  1172. case 4:
  1173. fep->u.ofdm.code_rate_HP = FEC_7_8;
  1174. deb_info("FEC_7_8\n");
  1175. break;
  1176. }
  1177. /* low coderate */
  1178. ret =
  1179. af9005_read_register_bits(state->d, xd_g_reg_tpsd_lpcr,
  1180. reg_tpsd_lpcr_pos, reg_tpsd_lpcr_len,
  1181. &temp);
  1182. if (ret)
  1183. return ret;
  1184. deb_info("CODERATE LP ");
  1185. switch (temp) {
  1186. case 0:
  1187. fep->u.ofdm.code_rate_LP = FEC_1_2;
  1188. deb_info("FEC_1_2\n");
  1189. break;
  1190. case 1:
  1191. fep->u.ofdm.code_rate_LP = FEC_2_3;
  1192. deb_info("FEC_2_3\n");
  1193. break;
  1194. case 2:
  1195. fep->u.ofdm.code_rate_LP = FEC_3_4;
  1196. deb_info("FEC_3_4\n");
  1197. break;
  1198. case 3:
  1199. fep->u.ofdm.code_rate_LP = FEC_5_6;
  1200. deb_info("FEC_5_6\n");
  1201. break;
  1202. case 4:
  1203. fep->u.ofdm.code_rate_LP = FEC_7_8;
  1204. deb_info("FEC_7_8\n");
  1205. break;
  1206. }
  1207. /* guard interval */
  1208. ret =
  1209. af9005_read_register_bits(state->d, xd_g_reg_tpsd_gi,
  1210. reg_tpsd_gi_pos, reg_tpsd_gi_len, &temp);
  1211. if (ret)
  1212. return ret;
  1213. deb_info("GUARD INTERVAL ");
  1214. switch (temp) {
  1215. case 0:
  1216. fep->u.ofdm.guard_interval = GUARD_INTERVAL_1_32;
  1217. deb_info("1_32\n");
  1218. break;
  1219. case 1:
  1220. fep->u.ofdm.guard_interval = GUARD_INTERVAL_1_16;
  1221. deb_info("1_16\n");
  1222. break;
  1223. case 2:
  1224. fep->u.ofdm.guard_interval = GUARD_INTERVAL_1_8;
  1225. deb_info("1_8\n");
  1226. break;
  1227. case 3:
  1228. fep->u.ofdm.guard_interval = GUARD_INTERVAL_1_4;
  1229. deb_info("1_4\n");
  1230. break;
  1231. }
  1232. /* fft */
  1233. ret =
  1234. af9005_read_register_bits(state->d, xd_g_reg_tpsd_txmod,
  1235. reg_tpsd_txmod_pos, reg_tpsd_txmod_len,
  1236. &temp);
  1237. if (ret)
  1238. return ret;
  1239. deb_info("TRANSMISSION MODE ");
  1240. switch (temp) {
  1241. case 0:
  1242. fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_2K;
  1243. deb_info("2K\n");
  1244. break;
  1245. case 1:
  1246. fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_8K;
  1247. deb_info("8K\n");
  1248. break;
  1249. }
  1250. /* bandwidth */
  1251. ret =
  1252. af9005_read_register_bits(state->d, xd_g_reg_bw, reg_bw_pos,
  1253. reg_bw_len, &temp);
  1254. deb_info("BANDWIDTH ");
  1255. switch (temp) {
  1256. case 0:
  1257. fep->u.ofdm.bandwidth = BANDWIDTH_6_MHZ;
  1258. deb_info("6\n");
  1259. break;
  1260. case 1:
  1261. fep->u.ofdm.bandwidth = BANDWIDTH_7_MHZ;
  1262. deb_info("7\n");
  1263. break;
  1264. case 2:
  1265. fep->u.ofdm.bandwidth = BANDWIDTH_8_MHZ;
  1266. deb_info("8\n");
  1267. break;
  1268. }
  1269. return 0;
  1270. }
  1271. static void af9005_fe_release(struct dvb_frontend *fe)
  1272. {
  1273. struct af9005_fe_state *state =
  1274. (struct af9005_fe_state *)fe->demodulator_priv;
  1275. kfree(state);
  1276. }
  1277. static struct dvb_frontend_ops af9005_fe_ops;
  1278. struct dvb_frontend *af9005_fe_attach(struct dvb_usb_device *d)
  1279. {
  1280. struct af9005_fe_state *state = NULL;
  1281. /* allocate memory for the internal state */
  1282. state = kzalloc(sizeof(struct af9005_fe_state), GFP_KERNEL);
  1283. if (state == NULL)
  1284. goto error;
  1285. deb_info("attaching frontend af9005\n");
  1286. state->d = d;
  1287. state->opened = 0;
  1288. memcpy(&state->frontend.ops, &af9005_fe_ops,
  1289. sizeof(struct dvb_frontend_ops));
  1290. state->frontend.demodulator_priv = state;
  1291. return &state->frontend;
  1292. error:
  1293. return NULL;
  1294. }
  1295. static struct dvb_frontend_ops af9005_fe_ops = {
  1296. .info = {
  1297. .name = "AF9005 USB DVB-T",
  1298. .type = FE_OFDM,
  1299. .frequency_min = 44250000,
  1300. .frequency_max = 867250000,
  1301. .frequency_stepsize = 250000,
  1302. .caps = FE_CAN_INVERSION_AUTO |
  1303. FE_CAN_FEC_1_2 | FE_CAN_FEC_2_3 | FE_CAN_FEC_3_4 |
  1304. FE_CAN_FEC_5_6 | FE_CAN_FEC_7_8 | FE_CAN_FEC_AUTO |
  1305. FE_CAN_QPSK | FE_CAN_QAM_16 | FE_CAN_QAM_64 |
  1306. FE_CAN_QAM_AUTO | FE_CAN_TRANSMISSION_MODE_AUTO |
  1307. FE_CAN_GUARD_INTERVAL_AUTO | FE_CAN_RECOVER |
  1308. FE_CAN_HIERARCHY_AUTO,
  1309. },
  1310. .release = af9005_fe_release,
  1311. .init = af9005_fe_init,
  1312. .sleep = af9005_fe_sleep,
  1313. .ts_bus_ctrl = af9005_ts_bus_ctrl,
  1314. .set_frontend = af9005_fe_set_frontend,
  1315. .get_frontend = af9005_fe_get_frontend,
  1316. .read_status = af9005_fe_read_status,
  1317. .read_ber = af9005_fe_read_ber,
  1318. .read_signal_strength = af9005_fe_read_signal_strength,
  1319. .read_snr = af9005_fe_read_snr,
  1320. .read_ucblocks = af9005_fe_read_unc_blocks,
  1321. };