Adds support for the Mygica T230C2 into the "dvbsky" driver. A small enhancement is also needed in the "si2168" demodulator driver, and a USB device ID in dvb-usb-ids.h . The T230C2 hardware uses a manual clock mode of the si2168 chip, for which the si2168 driver previously had no explicit support. And, the frequency manually configured is 10 MHz. This patch uses a specific measure to only configure this on the T230C2 hardware - see the flag passed via the ts_mode attribute and its dependency on USB_PID_MYGICA_T230C2 . This is v3 of the proposed patch, based on feedback from Sean Young. Tested by patch author on a T230C2 and on a T230. Tested by Frank Rysanek on a T230C2: can tune into locally available DVB-T and DVB-T2 muxes, video and audio playback works. Applies cleanly against Linux 5.1.7. Checkpatch.pl warns about 1 line longer than 80 characters. Ahh well. Signed-off-by: Jan Pieter van Woerkom <jp@xxxxxxx> Tested-by: Frank Rysanek <Frantisek.Rysanek@xxxxxxx> --- diff -uprN a/drivers/media/dvb-frontends/si2168.c b/drivers/media/dvb-frontends/si2168.c --- a/drivers/media/dvb-frontends/si2168.c 2019-06-09 10:47:30.353289411 +0200 +++ b/drivers/media/dvb-frontends/si2168.c 2019-06-09 10:48:18.849568333 +0200 @@ -91,8 +91,18 @@ static int si2168_ts_bus_ctrl(struct dvb dev_dbg(&client->dev, "%s acquire: %d\n", __func__, acquire); + /* set ts clock freq to 10Mhz */ + if (dev->ts_mode | SI2168_TS_CLOCK_MANUAL) { + memcpy(cmd.args, "\x14\x00\x0d\x10\xe8\x03", 6); + cmd.wlen = 6; + cmd.rlen = 4; + ret = si2168_cmd_execute(client, &cmd); + if (ret) + return ret; + } /* set TS_MODE property */ - memcpy(cmd.args, "\x14\x00\x01\x10\x10\x00", 6); + memcpy(cmd.args, "\x14\x00\x01\x10\x00\x00", 6); + cmd.args[4] = dev->ts_mode & (SI2168_TS_CLOCK_AUTO|SI2168_TS_CLOCK_MANUAL); if (acquire) cmd.args[4] |= dev->ts_mode; else diff -uprN a/drivers/media/dvb-frontends/si2168.h b/drivers/media/dvb-frontends/si2168.h --- a/drivers/media/dvb-frontends/si2168.h 2019-06-09 10:47:30.813292446 +0200 +++ b/drivers/media/dvb-frontends/si2168.h 2019-06-09 10:01:29.200647903 +0200 @@ -39,6 +39,8 @@ struct si2168_config { #define SI2168_TS_PARALLEL 0x06 #define SI2168_TS_SERIAL 0x03 #define SI2168_TS_TRISTATE 0x00 +#define SI2168_TS_CLOCK_AUTO 0x10 +#define SI2168_TS_CLOCK_MANUAL 0x20 u8 ts_mode; /* TS clock inverted */ diff -uprN a/drivers/media/usb/dvb-usb-v2/dvbsky.c b/drivers/media/usb/dvb-usb-v2/dvbsky.c --- a/drivers/media/usb/dvb-usb-v2/dvbsky.c 2019-06-09 10:47:31.169294788 +0200 +++ b/drivers/media/usb/dvb-usb-v2/dvbsky.c 2019-06-09 10:01:29.204647956 +0200 @@ -560,6 +560,8 @@ static int dvbsky_mygica_t230c_attach(st si2168_config.i2c_adapter = &i2c_adapter; si2168_config.fe = &adap->fe[0]; si2168_config.ts_mode = SI2168_TS_PARALLEL; + if (le16_to_cpu(d->udev->descriptor.idProduct) == USB_PID_MYGICA_T230C2) + si2168_config.ts_mode |= SI2168_TS_CLOCK_MANUAL; si2168_config.ts_clock_inv = 1; state->i2c_client_demod = dvb_module_probe("si2168", NULL, @@ -799,6 +801,9 @@ static const struct usb_device_id dvbsky { DVB_USB_DEVICE(USB_VID_CONEXANT, USB_PID_MYGICA_T230C, &mygica_t230c_props, "MyGica Mini DVB-T2 USB Stick T230C", RC_MAP_TOTAL_MEDIA_IN_HAND_02) }, + { DVB_USB_DEVICE(USB_VID_CONEXANT, USB_PID_MYGICA_T230C2, + &mygica_t230c_props, "MyGica Mini DVB-T2 USB Stick T230C2", + RC_MAP_TOTAL_MEDIA_IN_HAND_02) }, { } }; MODULE_DEVICE_TABLE(usb, dvbsky_id_table); diff -uprN a/include/media/dvb-usb-ids.h b/include/media/dvb-usb-ids.h --- a/include/media/dvb-usb-ids.h 2019-06-09 10:47:31.521297095 +0200 +++ b/include/media/dvb-usb-ids.h 2019-06-09 10:01:29.204647956 +0200 @@ -387,6 +387,7 @@ #define USB_PID_MYGICA_D689 0xd811 #define USB_PID_MYGICA_T230 0xc688 #define USB_PID_MYGICA_T230C 0xc689 +#define USB_PID_MYGICA_T230C2 0xc68a #define USB_PID_ELGATO_EYETV_DIVERSITY 0x0011 #define USB_PID_ELGATO_EYETV_DTT 0x0021 #define USB_PID_ELGATO_EYETV_DTT_2 0x003f