ddbridge-max.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505
  1. /*
  2. * ddbridge-max.c: Digital Devices bridge MAX card support
  3. *
  4. * Copyright (C) 2010-2017 Digital Devices GmbH
  5. * Ralph Metzler <rjkm@metzlerbros.de>
  6. * Marcus Metzler <mocm@metzlerbros.de>
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License
  10. * version 2 only, as published by the Free Software Foundation.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. */
  18. #include <linux/module.h>
  19. #include <linux/init.h>
  20. #include <linux/interrupt.h>
  21. #include <linux/delay.h>
  22. #include <linux/slab.h>
  23. #include <linux/poll.h>
  24. #include <linux/io.h>
  25. #include <linux/pci.h>
  26. #include <linux/pci_ids.h>
  27. #include <linux/timer.h>
  28. #include <linux/i2c.h>
  29. #include <linux/swab.h>
  30. #include <linux/vmalloc.h>
  31. #include "ddbridge.h"
  32. #include "ddbridge-regs.h"
  33. #include "ddbridge-io.h"
  34. #include "ddbridge-mci.h"
  35. #include "ddbridge-max.h"
  36. #include "mxl5xx.h"
  37. /******************************************************************************/
  38. /* MaxS4/8 related modparams */
  39. static int fmode;
  40. module_param(fmode, int, 0444);
  41. MODULE_PARM_DESC(fmode, "frontend emulation mode");
  42. static int fmode_sat = -1;
  43. module_param(fmode_sat, int, 0444);
  44. MODULE_PARM_DESC(fmode_sat, "set frontend emulation mode sat");
  45. static int old_quattro;
  46. module_param(old_quattro, int, 0444);
  47. MODULE_PARM_DESC(old_quattro, "old quattro LNB input order ");
  48. /******************************************************************************/
  49. static int lnb_command(struct ddb *dev, u32 link, u32 lnb, u32 cmd)
  50. {
  51. u32 c, v = 0, tag = DDB_LINK_TAG(link);
  52. v = LNB_TONE & (dev->link[link].lnb.tone << (15 - lnb));
  53. ddbwritel(dev, cmd | v, tag | LNB_CONTROL(lnb));
  54. for (c = 0; c < 10; c++) {
  55. v = ddbreadl(dev, tag | LNB_CONTROL(lnb));
  56. if ((v & LNB_BUSY) == 0)
  57. break;
  58. msleep(20);
  59. }
  60. if (c == 10)
  61. dev_info(dev->dev, "%s lnb = %08x cmd = %08x\n",
  62. __func__, lnb, cmd);
  63. return 0;
  64. }
  65. static int max_send_master_cmd(struct dvb_frontend *fe,
  66. struct dvb_diseqc_master_cmd *cmd)
  67. {
  68. struct ddb_input *input = fe->sec_priv;
  69. struct ddb_port *port = input->port;
  70. struct ddb *dev = port->dev;
  71. struct ddb_dvb *dvb = &port->dvb[input->nr & 1];
  72. u32 tag = DDB_LINK_TAG(port->lnr);
  73. int i;
  74. u32 fmode = dev->link[port->lnr].lnb.fmode;
  75. if (fmode == 2 || fmode == 1)
  76. return 0;
  77. if (dvb->diseqc_send_master_cmd)
  78. dvb->diseqc_send_master_cmd(fe, cmd);
  79. mutex_lock(&dev->link[port->lnr].lnb.lock);
  80. ddbwritel(dev, 0, tag | LNB_BUF_LEVEL(dvb->input));
  81. for (i = 0; i < cmd->msg_len; i++)
  82. ddbwritel(dev, cmd->msg[i], tag | LNB_BUF_WRITE(dvb->input));
  83. lnb_command(dev, port->lnr, dvb->input, LNB_CMD_DISEQC);
  84. mutex_unlock(&dev->link[port->lnr].lnb.lock);
  85. return 0;
  86. }
  87. static int lnb_send_diseqc(struct ddb *dev, u32 link, u32 input,
  88. struct dvb_diseqc_master_cmd *cmd)
  89. {
  90. u32 tag = DDB_LINK_TAG(link);
  91. int i;
  92. ddbwritel(dev, 0, tag | LNB_BUF_LEVEL(input));
  93. for (i = 0; i < cmd->msg_len; i++)
  94. ddbwritel(dev, cmd->msg[i], tag | LNB_BUF_WRITE(input));
  95. lnb_command(dev, link, input, LNB_CMD_DISEQC);
  96. return 0;
  97. }
  98. static int lnb_set_sat(struct ddb *dev, u32 link, u32 input, u32 sat, u32 band,
  99. u32 hor)
  100. {
  101. struct dvb_diseqc_master_cmd cmd = {
  102. .msg = {0xe0, 0x10, 0x38, 0xf0, 0x00, 0x00},
  103. .msg_len = 4
  104. };
  105. cmd.msg[3] = 0xf0 | (((sat << 2) & 0x0c) | (band ? 1 : 0) |
  106. (hor ? 2 : 0));
  107. return lnb_send_diseqc(dev, link, input, &cmd);
  108. }
  109. static int lnb_set_tone(struct ddb *dev, u32 link, u32 input,
  110. enum fe_sec_tone_mode tone)
  111. {
  112. int s = 0;
  113. u32 mask = (1ULL << input);
  114. switch (tone) {
  115. case SEC_TONE_OFF:
  116. if (!(dev->link[link].lnb.tone & mask))
  117. return 0;
  118. dev->link[link].lnb.tone &= ~(1ULL << input);
  119. break;
  120. case SEC_TONE_ON:
  121. if (dev->link[link].lnb.tone & mask)
  122. return 0;
  123. dev->link[link].lnb.tone |= (1ULL << input);
  124. break;
  125. default:
  126. s = -EINVAL;
  127. break;
  128. }
  129. if (!s)
  130. s = lnb_command(dev, link, input, LNB_CMD_NOP);
  131. return s;
  132. }
  133. static int lnb_set_voltage(struct ddb *dev, u32 link, u32 input,
  134. enum fe_sec_voltage voltage)
  135. {
  136. int s = 0;
  137. if (dev->link[link].lnb.oldvoltage[input] == voltage)
  138. return 0;
  139. switch (voltage) {
  140. case SEC_VOLTAGE_OFF:
  141. if (dev->link[link].lnb.voltage[input])
  142. return 0;
  143. lnb_command(dev, link, input, LNB_CMD_OFF);
  144. break;
  145. case SEC_VOLTAGE_13:
  146. lnb_command(dev, link, input, LNB_CMD_LOW);
  147. break;
  148. case SEC_VOLTAGE_18:
  149. lnb_command(dev, link, input, LNB_CMD_HIGH);
  150. break;
  151. default:
  152. s = -EINVAL;
  153. break;
  154. }
  155. dev->link[link].lnb.oldvoltage[input] = voltage;
  156. return s;
  157. }
  158. static int max_set_input_unlocked(struct dvb_frontend *fe, int in)
  159. {
  160. struct ddb_input *input = fe->sec_priv;
  161. struct ddb_port *port = input->port;
  162. struct ddb *dev = port->dev;
  163. struct ddb_dvb *dvb = &port->dvb[input->nr & 1];
  164. int res = 0;
  165. if (in > 3)
  166. return -EINVAL;
  167. if (dvb->input != in) {
  168. u32 bit = (1ULL << input->nr);
  169. u32 obit =
  170. dev->link[port->lnr].lnb.voltage[dvb->input & 3] & bit;
  171. dev->link[port->lnr].lnb.voltage[dvb->input & 3] &= ~bit;
  172. dvb->input = in;
  173. dev->link[port->lnr].lnb.voltage[dvb->input & 3] |= obit;
  174. }
  175. res = dvb->set_input(fe, in);
  176. return res;
  177. }
  178. static int max_set_tone(struct dvb_frontend *fe, enum fe_sec_tone_mode tone)
  179. {
  180. struct ddb_input *input = fe->sec_priv;
  181. struct ddb_port *port = input->port;
  182. struct ddb *dev = port->dev;
  183. struct ddb_dvb *dvb = &port->dvb[input->nr & 1];
  184. int tuner = 0;
  185. int res = 0;
  186. u32 fmode = dev->link[port->lnr].lnb.fmode;
  187. mutex_lock(&dev->link[port->lnr].lnb.lock);
  188. dvb->tone = tone;
  189. switch (fmode) {
  190. default:
  191. case 0:
  192. case 3:
  193. res = lnb_set_tone(dev, port->lnr, dvb->input, tone);
  194. break;
  195. case 1:
  196. case 2:
  197. if (old_quattro) {
  198. if (dvb->tone == SEC_TONE_ON)
  199. tuner |= 2;
  200. if (dvb->voltage == SEC_VOLTAGE_18)
  201. tuner |= 1;
  202. } else {
  203. if (dvb->tone == SEC_TONE_ON)
  204. tuner |= 1;
  205. if (dvb->voltage == SEC_VOLTAGE_18)
  206. tuner |= 2;
  207. }
  208. res = max_set_input_unlocked(fe, tuner);
  209. break;
  210. }
  211. mutex_unlock(&dev->link[port->lnr].lnb.lock);
  212. return res;
  213. }
  214. static int max_set_voltage(struct dvb_frontend *fe, enum fe_sec_voltage voltage)
  215. {
  216. struct ddb_input *input = fe->sec_priv;
  217. struct ddb_port *port = input->port;
  218. struct ddb *dev = port->dev;
  219. struct ddb_dvb *dvb = &port->dvb[input->nr & 1];
  220. int tuner = 0;
  221. u32 nv, ov = dev->link[port->lnr].lnb.voltages;
  222. int res = 0;
  223. u32 fmode = dev->link[port->lnr].lnb.fmode;
  224. mutex_lock(&dev->link[port->lnr].lnb.lock);
  225. dvb->voltage = voltage;
  226. switch (fmode) {
  227. case 3:
  228. default:
  229. case 0:
  230. if (fmode == 3)
  231. max_set_input_unlocked(fe, 0);
  232. if (voltage == SEC_VOLTAGE_OFF)
  233. dev->link[port->lnr].lnb.voltage[dvb->input] &=
  234. ~(1ULL << input->nr);
  235. else
  236. dev->link[port->lnr].lnb.voltage[dvb->input] |=
  237. (1ULL << input->nr);
  238. res = lnb_set_voltage(dev, port->lnr, dvb->input, voltage);
  239. break;
  240. case 1:
  241. case 2:
  242. if (voltage == SEC_VOLTAGE_OFF)
  243. dev->link[port->lnr].lnb.voltages &=
  244. ~(1ULL << input->nr);
  245. else
  246. dev->link[port->lnr].lnb.voltages |=
  247. (1ULL << input->nr);
  248. nv = dev->link[port->lnr].lnb.voltages;
  249. if (old_quattro) {
  250. if (dvb->tone == SEC_TONE_ON)
  251. tuner |= 2;
  252. if (dvb->voltage == SEC_VOLTAGE_18)
  253. tuner |= 1;
  254. } else {
  255. if (dvb->tone == SEC_TONE_ON)
  256. tuner |= 1;
  257. if (dvb->voltage == SEC_VOLTAGE_18)
  258. tuner |= 2;
  259. }
  260. res = max_set_input_unlocked(fe, tuner);
  261. if (nv != ov) {
  262. if (nv) {
  263. lnb_set_voltage(
  264. dev, port->lnr,
  265. 0, SEC_VOLTAGE_13);
  266. if (fmode == 1) {
  267. lnb_set_voltage(
  268. dev, port->lnr,
  269. 0, SEC_VOLTAGE_13);
  270. if (old_quattro) {
  271. lnb_set_voltage(
  272. dev, port->lnr,
  273. 1, SEC_VOLTAGE_18);
  274. lnb_set_voltage(
  275. dev, port->lnr,
  276. 2, SEC_VOLTAGE_13);
  277. } else {
  278. lnb_set_voltage(
  279. dev, port->lnr,
  280. 1, SEC_VOLTAGE_13);
  281. lnb_set_voltage(
  282. dev, port->lnr,
  283. 2, SEC_VOLTAGE_18);
  284. }
  285. lnb_set_voltage(
  286. dev, port->lnr,
  287. 3, SEC_VOLTAGE_18);
  288. }
  289. } else {
  290. lnb_set_voltage(
  291. dev, port->lnr,
  292. 0, SEC_VOLTAGE_OFF);
  293. if (fmode == 1) {
  294. lnb_set_voltage(
  295. dev, port->lnr,
  296. 1, SEC_VOLTAGE_OFF);
  297. lnb_set_voltage(
  298. dev, port->lnr,
  299. 2, SEC_VOLTAGE_OFF);
  300. lnb_set_voltage(
  301. dev, port->lnr,
  302. 3, SEC_VOLTAGE_OFF);
  303. }
  304. }
  305. }
  306. break;
  307. }
  308. mutex_unlock(&dev->link[port->lnr].lnb.lock);
  309. return res;
  310. }
  311. static int max_enable_high_lnb_voltage(struct dvb_frontend *fe, long arg)
  312. {
  313. return 0;
  314. }
  315. static int max_send_burst(struct dvb_frontend *fe, enum fe_sec_mini_cmd burst)
  316. {
  317. return 0;
  318. }
  319. static int mxl_fw_read(void *priv, u8 *buf, u32 len)
  320. {
  321. struct ddb_link *link = priv;
  322. struct ddb *dev = link->dev;
  323. dev_info(dev->dev, "Read mxl_fw from link %u\n", link->nr);
  324. return ddbridge_flashread(dev, link->nr, buf, 0xc0000, len);
  325. }
  326. int ddb_lnb_init_fmode(struct ddb *dev, struct ddb_link *link, u32 fm)
  327. {
  328. u32 l = link->nr;
  329. if (link->lnb.fmode == fm)
  330. return 0;
  331. dev_info(dev->dev, "Set fmode link %u = %u\n", l, fm);
  332. mutex_lock(&link->lnb.lock);
  333. if (fm == 2 || fm == 1) {
  334. if (fmode_sat >= 0) {
  335. lnb_set_sat(dev, l, 0, fmode_sat, 0, 0);
  336. if (old_quattro) {
  337. lnb_set_sat(dev, l, 1, fmode_sat, 0, 1);
  338. lnb_set_sat(dev, l, 2, fmode_sat, 1, 0);
  339. } else {
  340. lnb_set_sat(dev, l, 1, fmode_sat, 1, 0);
  341. lnb_set_sat(dev, l, 2, fmode_sat, 0, 1);
  342. }
  343. lnb_set_sat(dev, l, 3, fmode_sat, 1, 1);
  344. }
  345. lnb_set_tone(dev, l, 0, SEC_TONE_OFF);
  346. if (old_quattro) {
  347. lnb_set_tone(dev, l, 1, SEC_TONE_OFF);
  348. lnb_set_tone(dev, l, 2, SEC_TONE_ON);
  349. } else {
  350. lnb_set_tone(dev, l, 1, SEC_TONE_ON);
  351. lnb_set_tone(dev, l, 2, SEC_TONE_OFF);
  352. }
  353. lnb_set_tone(dev, l, 3, SEC_TONE_ON);
  354. }
  355. link->lnb.fmode = fm;
  356. mutex_unlock(&link->lnb.lock);
  357. return 0;
  358. }
  359. static struct mxl5xx_cfg mxl5xx = {
  360. .adr = 0x60,
  361. .type = 0x01,
  362. .clk = 27000000,
  363. .ts_clk = 139,
  364. .cap = 12,
  365. .fw_read = mxl_fw_read,
  366. };
  367. int ddb_fe_attach_mxl5xx(struct ddb_input *input)
  368. {
  369. struct ddb *dev = input->port->dev;
  370. struct i2c_adapter *i2c = &input->port->i2c->adap;
  371. struct ddb_dvb *dvb = &input->port->dvb[input->nr & 1];
  372. struct ddb_port *port = input->port;
  373. struct ddb_link *link = &dev->link[port->lnr];
  374. struct mxl5xx_cfg cfg;
  375. int demod, tuner;
  376. cfg = mxl5xx;
  377. cfg.fw_priv = link;
  378. dvb->set_input = NULL;
  379. demod = input->nr;
  380. tuner = demod & 3;
  381. if (fmode == 3)
  382. tuner = 0;
  383. dvb->fe = dvb_attach(mxl5xx_attach, i2c, &cfg,
  384. demod, tuner, &dvb->set_input);
  385. if (!dvb->fe) {
  386. dev_err(dev->dev, "No MXL5XX found!\n");
  387. return -ENODEV;
  388. }
  389. if (!dvb->set_input) {
  390. dev_err(dev->dev, "No mxl5xx_set_input function pointer!\n");
  391. return -ENODEV;
  392. }
  393. if (input->nr < 4) {
  394. lnb_command(dev, port->lnr, input->nr, LNB_CMD_INIT);
  395. lnb_set_voltage(dev, port->lnr, input->nr, SEC_VOLTAGE_OFF);
  396. }
  397. ddb_lnb_init_fmode(dev, link, fmode);
  398. dvb->fe->ops.set_voltage = max_set_voltage;
  399. dvb->fe->ops.enable_high_lnb_voltage = max_enable_high_lnb_voltage;
  400. dvb->fe->ops.set_tone = max_set_tone;
  401. dvb->diseqc_send_master_cmd = dvb->fe->ops.diseqc_send_master_cmd;
  402. dvb->fe->ops.diseqc_send_master_cmd = max_send_master_cmd;
  403. dvb->fe->ops.diseqc_send_burst = max_send_burst;
  404. dvb->fe->sec_priv = input;
  405. dvb->input = tuner;
  406. return 0;
  407. }
  408. /******************************************************************************/
  409. /* MAX MCI related functions */
  410. int ddb_fe_attach_mci(struct ddb_input *input, u32 type)
  411. {
  412. struct ddb *dev = input->port->dev;
  413. struct ddb_dvb *dvb = &input->port->dvb[input->nr & 1];
  414. struct ddb_port *port = input->port;
  415. struct ddb_link *link = &dev->link[port->lnr];
  416. int demod, tuner;
  417. struct mci_cfg cfg;
  418. demod = input->nr;
  419. tuner = demod & 3;
  420. switch (type) {
  421. case DDB_TUNER_MCI_SX8:
  422. cfg = ddb_max_sx8_cfg;
  423. if (fmode == 3)
  424. tuner = 0;
  425. break;
  426. default:
  427. return -EINVAL;
  428. }
  429. dvb->fe = ddb_mci_attach(input, &cfg, demod, &dvb->set_input);
  430. if (!dvb->fe) {
  431. dev_err(dev->dev, "No MCI card found!\n");
  432. return -ENODEV;
  433. }
  434. if (!dvb->set_input) {
  435. dev_err(dev->dev, "No MCI set_input function pointer!\n");
  436. return -ENODEV;
  437. }
  438. if (input->nr < 4) {
  439. lnb_command(dev, port->lnr, input->nr, LNB_CMD_INIT);
  440. lnb_set_voltage(dev, port->lnr, input->nr, SEC_VOLTAGE_OFF);
  441. }
  442. ddb_lnb_init_fmode(dev, link, fmode);
  443. dvb->fe->ops.set_voltage = max_set_voltage;
  444. dvb->fe->ops.enable_high_lnb_voltage = max_enable_high_lnb_voltage;
  445. dvb->fe->ops.set_tone = max_set_tone;
  446. dvb->diseqc_send_master_cmd = dvb->fe->ops.diseqc_send_master_cmd;
  447. dvb->fe->ops.diseqc_send_master_cmd = max_send_master_cmd;
  448. dvb->fe->ops.diseqc_send_burst = max_send_burst;
  449. dvb->fe->sec_priv = input;
  450. dvb->input = tuner;
  451. return 0;
  452. }