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