af9005-fe.c 36 KB

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