|
@@ -696,6 +696,11 @@ struct cx23885_board cx23885_boards[] = {
|
|
.name = "DVBSky S950",
|
|
.name = "DVBSky S950",
|
|
.portb = CX23885_MPEG_DVB,
|
|
.portb = CX23885_MPEG_DVB,
|
|
},
|
|
},
|
|
|
|
+ [CX23885_BOARD_DVBSKY_S952] = {
|
|
|
|
+ .name = "DVBSky S952",
|
|
|
|
+ .portb = CX23885_MPEG_DVB,
|
|
|
|
+ .portc = CX23885_MPEG_DVB,
|
|
|
|
+ },
|
|
};
|
|
};
|
|
const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards);
|
|
const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards);
|
|
|
|
|
|
@@ -971,6 +976,10 @@ struct cx23885_subid cx23885_subids[] = {
|
|
.subvendor = 0x4254,
|
|
.subvendor = 0x4254,
|
|
.subdevice = 0x0950,
|
|
.subdevice = 0x0950,
|
|
.card = CX23885_BOARD_DVBSKY_S950,
|
|
.card = CX23885_BOARD_DVBSKY_S950,
|
|
|
|
+ }, {
|
|
|
|
+ .subvendor = 0x4254,
|
|
|
|
+ .subdevice = 0x0952,
|
|
|
|
+ .card = CX23885_BOARD_DVBSKY_S952,
|
|
},
|
|
},
|
|
};
|
|
};
|
|
const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids);
|
|
const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids);
|
|
@@ -1566,6 +1575,7 @@ void cx23885_gpio_setup(struct cx23885_dev *dev)
|
|
mdelay(60);
|
|
mdelay(60);
|
|
break;
|
|
break;
|
|
case CX23885_BOARD_DVBSKY_T9580:
|
|
case CX23885_BOARD_DVBSKY_T9580:
|
|
|
|
+ case CX23885_BOARD_DVBSKY_S952:
|
|
/* enable GPIO3-18 pins */
|
|
/* enable GPIO3-18 pins */
|
|
cx_write(MC417_CTL, 0x00000037);
|
|
cx_write(MC417_CTL, 0x00000037);
|
|
cx23885_gpio_enable(dev, GPIO_2 | GPIO_11, 1);
|
|
cx23885_gpio_enable(dev, GPIO_2 | GPIO_11, 1);
|
|
@@ -1697,6 +1707,7 @@ int cx23885_ir_init(struct cx23885_dev *dev)
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
|
|
+ case CX23885_BOARD_DVBSKY_S952:
|
|
if (!enable_885_ir)
|
|
if (!enable_885_ir)
|
|
break;
|
|
break;
|
|
dev->sd_ir = cx23885_find_hw(dev, CX23885_HW_AV_CORE);
|
|
dev->sd_ir = cx23885_find_hw(dev, CX23885_HW_AV_CORE);
|
|
@@ -1748,6 +1759,7 @@ void cx23885_ir_fini(struct cx23885_dev *dev)
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
|
|
+ case CX23885_BOARD_DVBSKY_S952:
|
|
cx23885_irq_remove(dev, PCI_MSK_AV_CORE);
|
|
cx23885_irq_remove(dev, PCI_MSK_AV_CORE);
|
|
/* sd_ir is a duplicate pointer to the AV Core, just clear it */
|
|
/* sd_ir is a duplicate pointer to the AV Core, just clear it */
|
|
dev->sd_ir = NULL;
|
|
dev->sd_ir = NULL;
|
|
@@ -1800,6 +1812,7 @@ void cx23885_ir_pci_int_enable(struct cx23885_dev *dev)
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
|
|
+ case CX23885_BOARD_DVBSKY_S952:
|
|
if (dev->sd_ir)
|
|
if (dev->sd_ir)
|
|
cx23885_irq_add_enable(dev, PCI_MSK_AV_CORE);
|
|
cx23885_irq_add_enable(dev, PCI_MSK_AV_CORE);
|
|
break;
|
|
break;
|
|
@@ -1962,6 +1975,14 @@ 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_DVBSKY_S952:
|
|
|
|
+ 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;
|
|
|
|
+ ts2->gen_ctrl_val = 0xe; /* Serial bus */
|
|
|
|
+ ts2->ts_clk_en_val = 0x1; /* Enable TS_CLK */
|
|
|
|
+ ts2->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:
|
|
@@ -2029,6 +2050,7 @@ void cx23885_card_setup(struct cx23885_dev *dev)
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_DVBSKY_S950C:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_TT_CT2_4500_CI:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
case CX23885_BOARD_DVBSKY_S950:
|
|
|
|
+ case CX23885_BOARD_DVBSKY_S952:
|
|
dev->sd_cx25840 = v4l2_i2c_new_subdev(&dev->v4l2_dev,
|
|
dev->sd_cx25840 = v4l2_i2c_new_subdev(&dev->v4l2_dev,
|
|
&dev->i2c_bus[2].i2c_adap,
|
|
&dev->i2c_bus[2].i2c_adap,
|
|
"cx25840", 0x88 >> 1, NULL);
|
|
"cx25840", 0x88 >> 1, NULL);
|