mirror of https://gitee.com/openkylin/linux.git
V4L/DVB (11880): cx23885: support for card Mygica X8506 DMB-TH
This patch add cx23885 support for card "Mygica X8506 DMB-TH". It should work on "Magic-Pro ProHDTV Extreme" as well, as they are same hardware with different branding. Sign-off-by: David T.L. Wong <davidtlwong@gmail.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
parent
3047a17639
commit
493b7127aa
|
@ -20,3 +20,4 @@
|
||||||
19 -> Hauppauge WinTV-HVR1275 [0070:2215]
|
19 -> Hauppauge WinTV-HVR1275 [0070:2215]
|
||||||
20 -> Hauppauge WinTV-HVR1255 [0070:2251]
|
20 -> Hauppauge WinTV-HVR1255 [0070:2251]
|
||||||
21 -> Hauppauge WinTV-HVR1210 [0070:2291,0070:2295]
|
21 -> Hauppauge WinTV-HVR1210 [0070:2291,0070:2295]
|
||||||
|
22 -> Mygica X8506 DMB-TH [14f1:8651]
|
||||||
|
|
|
@ -197,6 +197,10 @@ struct cx23885_board cx23885_boards[] = {
|
||||||
.name = "Hauppauge WinTV-HVR1210",
|
.name = "Hauppauge WinTV-HVR1210",
|
||||||
.portc = CX23885_MPEG_DVB,
|
.portc = CX23885_MPEG_DVB,
|
||||||
},
|
},
|
||||||
|
[CX23885_BOARD_MYGICA_X8506] = {
|
||||||
|
.name = "Mygica X8506 DMB-TH",
|
||||||
|
.portb = CX23885_MPEG_DVB,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards);
|
const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards);
|
||||||
|
|
||||||
|
@ -316,6 +320,10 @@ struct cx23885_subid cx23885_subids[] = {
|
||||||
.subvendor = 0x0070,
|
.subvendor = 0x0070,
|
||||||
.subdevice = 0x2295,
|
.subdevice = 0x2295,
|
||||||
.card = CX23885_BOARD_HAUPPAUGE_HVR1210,
|
.card = CX23885_BOARD_HAUPPAUGE_HVR1210,
|
||||||
|
}, {
|
||||||
|
.subvendor = 0x14f1,
|
||||||
|
.subdevice = 0x8651,
|
||||||
|
.card = CX23885_BOARD_MYGICA_X8506,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids);
|
const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids);
|
||||||
|
@ -706,6 +714,15 @@ void cx23885_gpio_setup(struct cx23885_dev *dev)
|
||||||
mdelay(20);
|
mdelay(20);
|
||||||
cx23885_gpio_set(dev, GPIO_9);
|
cx23885_gpio_set(dev, GPIO_9);
|
||||||
break;
|
break;
|
||||||
|
case CX23885_BOARD_MYGICA_X8506:
|
||||||
|
/* GPIO-1 reset XC5000 */
|
||||||
|
/* GPIO-2 reset LGS8GL5 */
|
||||||
|
cx_set(GP0_IO, 0x00060000);
|
||||||
|
cx_clear(GP0_IO, 0x00000006);
|
||||||
|
mdelay(100);
|
||||||
|
cx_set(GP0_IO, 0x00060006);
|
||||||
|
mdelay(100);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -809,6 +826,11 @@ void cx23885_card_setup(struct cx23885_dev *dev)
|
||||||
ts2->ts_clk_en_val = 0x1; /* Enable TS_CLK */
|
ts2->ts_clk_en_val = 0x1; /* Enable TS_CLK */
|
||||||
ts2->src_sel_val = CX23885_SRC_SEL_PARALLEL_MPEG_VIDEO;
|
ts2->src_sel_val = CX23885_SRC_SEL_PARALLEL_MPEG_VIDEO;
|
||||||
break;
|
break;
|
||||||
|
case CX23885_BOARD_MYGICA_X8506:
|
||||||
|
ts1->gen_ctrl_val = 0x5; /* Parallel */
|
||||||
|
ts1->ts_clk_en_val = 0x1; /* Enable TS_CLK */
|
||||||
|
ts1->src_sel_val = CX23885_SRC_SEL_PARALLEL_MPEG_VIDEO;
|
||||||
|
break;
|
||||||
case CX23885_BOARD_HAUPPAUGE_HVR1250:
|
case CX23885_BOARD_HAUPPAUGE_HVR1250:
|
||||||
case CX23885_BOARD_HAUPPAUGE_HVR1500:
|
case CX23885_BOARD_HAUPPAUGE_HVR1500:
|
||||||
case CX23885_BOARD_HAUPPAUGE_HVR1500Q:
|
case CX23885_BOARD_HAUPPAUGE_HVR1500Q:
|
||||||
|
|
|
@ -49,6 +49,7 @@
|
||||||
#include "lnbh24.h"
|
#include "lnbh24.h"
|
||||||
#include "cx24116.h"
|
#include "cx24116.h"
|
||||||
#include "cimax2.h"
|
#include "cimax2.h"
|
||||||
|
#include "lgs8gxx.h"
|
||||||
#include "netup-eeprom.h"
|
#include "netup-eeprom.h"
|
||||||
#include "netup-init.h"
|
#include "netup-init.h"
|
||||||
#include "lgdt3305.h"
|
#include "lgdt3305.h"
|
||||||
|
@ -420,10 +421,29 @@ static struct cx24116_config dvbworld_cx24116_config = {
|
||||||
.demod_address = 0x05,
|
.demod_address = 0x05,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct lgs8gxx_config mygica_x8506_lgs8gl5_config = {
|
||||||
|
.prod = LGS8GXX_PROD_LGS8GL5,
|
||||||
|
.demod_address = 0x19,
|
||||||
|
.serial_ts = 0,
|
||||||
|
.ts_clk_pol = 1,
|
||||||
|
.ts_clk_gated = 1,
|
||||||
|
.if_clk_freq = 30400, /* 30.4 MHz */
|
||||||
|
.if_freq = 5380, /* 5.38 MHz */
|
||||||
|
.if_neg_center = 1,
|
||||||
|
.ext_adc = 0,
|
||||||
|
.adc_signed = 0,
|
||||||
|
.if_neg_edge = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct xc5000_config mygica_x8506_xc5000_config = {
|
||||||
|
.i2c_address = 0x61,
|
||||||
|
.if_khz = 5380,
|
||||||
|
};
|
||||||
|
|
||||||
static int dvb_register(struct cx23885_tsport *port)
|
static int dvb_register(struct cx23885_tsport *port)
|
||||||
{
|
{
|
||||||
struct cx23885_dev *dev = port->dev;
|
struct cx23885_dev *dev = port->dev;
|
||||||
struct cx23885_i2c *i2c_bus = NULL;
|
struct cx23885_i2c *i2c_bus = NULL, *i2c_bus2 = NULL;
|
||||||
struct videobuf_dvb_frontend *fe0;
|
struct videobuf_dvb_frontend *fe0;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -745,6 +765,19 @@ static int dvb_register(struct cx23885_tsport *port)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case CX23885_BOARD_MYGICA_X8506:
|
||||||
|
i2c_bus = &dev->i2c_bus[0];
|
||||||
|
i2c_bus2 = &dev->i2c_bus[1];
|
||||||
|
fe0->dvb.frontend = dvb_attach(lgs8gxx_attach,
|
||||||
|
&mygica_x8506_lgs8gl5_config,
|
||||||
|
&i2c_bus->i2c_adap);
|
||||||
|
if (fe0->dvb.frontend != NULL) {
|
||||||
|
dvb_attach(xc5000_attach,
|
||||||
|
fe0->dvb.frontend,
|
||||||
|
&i2c_bus2->i2c_adap,
|
||||||
|
&mygica_x8506_xc5000_config);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
printk(KERN_INFO "%s: The frontend of your DVB/ATSC card "
|
printk(KERN_INFO "%s: The frontend of your DVB/ATSC card "
|
||||||
" isn't supported yet\n",
|
" isn't supported yet\n",
|
||||||
|
|
|
@ -75,6 +75,7 @@
|
||||||
#define CX23885_BOARD_HAUPPAUGE_HVR1275 19
|
#define CX23885_BOARD_HAUPPAUGE_HVR1275 19
|
||||||
#define CX23885_BOARD_HAUPPAUGE_HVR1255 20
|
#define CX23885_BOARD_HAUPPAUGE_HVR1255 20
|
||||||
#define CX23885_BOARD_HAUPPAUGE_HVR1210 21
|
#define CX23885_BOARD_HAUPPAUGE_HVR1210 21
|
||||||
|
#define CX23885_BOARD_MYGICA_X8506 22
|
||||||
|
|
||||||
#define GPIO_0 0x00000001
|
#define GPIO_0 0x00000001
|
||||||
#define GPIO_1 0x00000002
|
#define GPIO_1 0x00000002
|
||||||
|
|
Loading…
Reference in New Issue