summaryrefslogtreecommitdiff
path: root/linux/drivers/media/video/ngene
diff options
context:
space:
mode:
Diffstat (limited to 'linux/drivers/media/video/ngene')
-rw-r--r--linux/drivers/media/video/ngene/ngene-core.c1996
1 files changed, 1013 insertions, 983 deletions
diff --git a/linux/drivers/media/video/ngene/ngene-core.c b/linux/drivers/media/video/ngene/ngene-core.c
index 2a73c6c86..0fad67e17 100644
--- a/linux/drivers/media/video/ngene/ngene-core.c
+++ b/linux/drivers/media/video/ngene/ngene-core.c
@@ -714,15 +714,17 @@ static void FillTSBuffer(void *Buffer, int Length, u32 Flags)
}
}
-//static void clear_tsin(struct ngene_channel *chan)
-//{
-// struct SBufferHeader *Cur = chan->nextBuffer;
-//
-// do {
-// memset(&Cur->ngeneBuffer.SR, 0, sizeof(Cur->ngeneBuffer.SR));
-// Cur = Cur->Next;
-// } while (Cur != chan->nextBuffer);
-//}
+#if 0
+static void clear_tsin(struct ngene_channel *chan)
+{
+ struct SBufferHeader *Cur = chan->nextBuffer;
+
+ do {
+ memset(&Cur->ngeneBuffer.SR, 0, sizeof(Cur->ngeneBuffer.SR));
+ Cur = Cur->Next;
+ } while (Cur != chan->nextBuffer);
+}
+#endif
static void flush_buffers(struct ngene_channel *chan)
@@ -1076,15 +1078,17 @@ struct i2c_algorithm ngene_i2c_algo = {
.functionality = ngene_i2c_functionality,
};
-//static int ngene_i2c_attach(struct i2c_client *client)
-//{
-// return 0;
-//}
-//
-//static int ngene_i2c_detach(struct i2c_client *client)
-//{
-// return 0;
-//}
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,30)
+static int ngene_i2c_attach(struct i2c_client *client)
+{
+ return 0;
+}
+
+static int ngene_i2c_detach(struct i2c_client *client)
+{
+ return 0;
+}
+#endif
static int ngene_i2c_init(struct ngene *dev, int dev_nr)
{
@@ -1104,8 +1108,10 @@ static int ngene_i2c_init(struct ngene *dev, int dev_nr)
#else
adap->id=I2C_HW_SAA7146;
#endif
-// adap->client_register=ngene_i2c_attach;
-// adap->client_unregister=ngene_i2c_detach;
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,30)
+ adap->client_register=ngene_i2c_attach;
+ adap->client_unregister=ngene_i2c_detach;
+#endif
adap->algo=&ngene_i2c_algo;
adap->algo_data=(void *)&(dev->channel[dev_nr]);
@@ -1129,19 +1135,21 @@ int i2c_write(struct i2c_adapter *adapter, u8 adr, u8 data)
return 0;
}
-//static int i2c_write_register(struct i2c_adapter *adapter,
-// u8 adr, u8 reg, u8 data)
-//{
-// u8 m[2]={reg, data};
-// struct i2c_msg msg={.addr=adr, .flags=0, .buf=m, .len=2};
-//
-// if (i2c_transfer(adapter, &msg, 1)!=1) {
-// printk("Failed to write to I2C register %02x@%02x!\n",
-// reg, adr);
-// return -1;
-// }
-// return 0;
-//}
+#if 0
+static int i2c_write_register(struct i2c_adapter *adapter,
+ u8 adr, u8 reg, u8 data)
+{
+ u8 m[2]={reg, data};
+ struct i2c_msg msg={.addr=adr, .flags=0, .buf=m, .len=2};
+
+ if (i2c_transfer(adapter, &msg, 1)!=1) {
+ printk("Failed to write to I2C register %02x@%02x!\n",
+ reg, adr);
+ return -1;
+ }
+ return 0;
+}
+#endif
static int i2c_write_read(struct i2c_adapter *adapter,
u8 adr, u8 *w, u8 wlen, u8 *r, u8 rlen)
@@ -1246,144 +1254,146 @@ static int i2c_read_eeprom(struct i2c_adapter *adapter,
return 0;
}
-//static int ReadEEProm(struct i2c_adapter *adapter,
-// u16 Tag, u32 MaxLen, u8 *data, u32 *pLength)
-//{
-// int status=0;
-// u16 Addr=MICNG_EE_START, Length, tag=0;
-// u8 EETag[3];
-//
-// while (Addr+sizeof(u16)+1<MICNG_EE_END) {
-// if (i2c_read_eeprom(adapter, 0x50, Addr, EETag,
-// sizeof(EETag)))
-// return -1;
-// tag=(EETag[0]<<8)|EETag[1];
-// if (tag==MICNG_EETAG_END0 || tag==MICNG_EETAG_END1)
-// return -1;
-// if (tag==Tag)
-// break;
-// Addr+=sizeof(u16)+1+EETag[2];
-// }
-// if (Addr+sizeof(u16)+1+EETag[2]>MICNG_EE_END) {
-// printk(DEVICE_NAME
-// ": Reached EOEE @ Tag = %04x Length = %3d\n",
-// tag, EETag[2]);
-// return -1;
-// }
-// Length=EETag[2];
-// if (Length>MaxLen)
-// Length=(u16)MaxLen;
-// if (Length>0) {
-// Addr+=sizeof(u16)+1;
-// if (!(status=i2c_read_eeprom(adapter, 0x50,
-// Addr, data, Length))) {
-// *pLength=EETag[2];
-// if (Length<EETag[2])
-// ;/*status=STATUS_BUFFER_OVERFLOW;*/
-// }
-// }
-// return status;
-//}
-//
-//static int WriteEEProm(struct i2c_adapter *adapter,
-// u16 Tag, u32 Length, u8 *data)
-//{
-// int status=0;
-// u16 Addr=MICNG_EE_START;
-// u8 EETag[3];
-// u16 tag=0;
-// int retry,i;
-//
-// while (Addr+sizeof(u16)+1<MICNG_EE_END) {
-// if (i2c_read_eeprom(adapter, 0x50,
-// Addr, EETag, sizeof(EETag)))
-// return -1;
-// tag=(EETag[0]<<8)|EETag[1];
-// if (tag==MICNG_EETAG_END0 || tag==MICNG_EETAG_END1)
-// return -1;
-// if (tag==Tag)
-// break;
-// Addr+=sizeof(u16)+1+EETag[2];
-// }
-// if (Addr+sizeof(u16)+1+EETag[2]>MICNG_EE_END) {
-// printk(DEVICE_NAME
-// ": Reached EOEE @ Tag = %04x Length = %3d\n",
-// tag, EETag[2]);
-// return -1;
-// }
-//
-// if (Length>EETag[2])
-// return -EINVAL;
-// /* Note: We write the data one byte at a time to avoid
-// issues with page sizes. (which are different for
-// each manufacture and eeprom size)
-// */
-// Addr+=sizeof(u16)+1;
-// for (i=0; i<Length; i++, Addr++) {
-// status=i2c_write_eeprom(adapter, 0x50, Addr, data[i]);
-//
-// if (status)
-// break;
-//
-// /* Poll for finishing write cycle */
-// retry=10;
-// while (retry) {
-// u8 Tmp;
-//
-// msleep(50);
-// status=i2c_read_eeprom(adapter, 0x50, Addr, &Tmp, 1);
-// if (status)
-// break;
-// if (Tmp!=data[i])
-// printk("eeprom write error\n");
-// retry-=1;
-// }
-// if (status) {
-// printk(DEVICE_NAME ": Timeout polling eeprom\n");
-// break;
-// }
-// }
-// return status;
-//}
-//
-//static void i2c_init_eeprom(struct i2c_adapter *adapter)
-//{
-// u8 tags[]={ 0x10, 0x00, 0x02, 0x00, 0x00,
-// 0x10, 0x01, 0x02, 0x00, 0x00,
-// 0x00, 0x00, 0x00 };
-//
-// int i;
-//
-// for (i=0; i<sizeof(tags); i++)
-// i2c_write_eeprom(adapter, 0x50, 0x0100+i, tags[i]);
-//}
-//
-//static int eeprom_read_ushort(struct i2c_adapter *adapter, u16 tag, u16 *data)
-//{
-// int stat;
-// u8 buf[2];
-// u32 len=0;
-//
-// if ((stat=ReadEEProm(adapter, tag, 2, buf, &len)))
-// return stat;
-// if (len!=2)
-// return -EINVAL;
-//
-// *data=(buf[0]<<8)|buf[1];
-// return 0;
-//}
-//
-//static int eeprom_write_ushort(struct i2c_adapter *adapter, u16 tag, u16 data)
-//{
-// int stat;
-// u8 buf[2];
-//
-// buf[0]=data>>8;
-// buf[1]=data&0xff;
-// if ((stat=WriteEEProm(adapter, tag, 2, buf)))
-// return stat;
-// return 0;
-//}
+#if 0
+static int ReadEEProm(struct i2c_adapter *adapter,
+ u16 Tag, u32 MaxLen, u8 *data, u32 *pLength)
+{
+ int status=0;
+ u16 Addr=MICNG_EE_START, Length, tag=0;
+ u8 EETag[3];
+
+ while (Addr+sizeof(u16)+1<MICNG_EE_END) {
+ if (i2c_read_eeprom(adapter, 0x50, Addr, EETag,
+ sizeof(EETag)))
+ return -1;
+ tag=(EETag[0]<<8)|EETag[1];
+ if (tag==MICNG_EETAG_END0 || tag==MICNG_EETAG_END1)
+ return -1;
+ if (tag==Tag)
+ break;
+ Addr+=sizeof(u16)+1+EETag[2];
+ }
+ if (Addr+sizeof(u16)+1+EETag[2]>MICNG_EE_END) {
+ printk(DEVICE_NAME
+ ": Reached EOEE @ Tag = %04x Length = %3d\n",
+ tag, EETag[2]);
+ return -1;
+ }
+ Length=EETag[2];
+ if (Length>MaxLen)
+ Length=(u16)MaxLen;
+ if (Length>0) {
+ Addr+=sizeof(u16)+1;
+ if (!(status=i2c_read_eeprom(adapter, 0x50,
+ Addr, data, Length))) {
+ *pLength=EETag[2];
+ if (Length<EETag[2])
+ ;/*status=STATUS_BUFFER_OVERFLOW;*/
+ }
+ }
+ return status;
+}
+
+static int WriteEEProm(struct i2c_adapter *adapter,
+ u16 Tag, u32 Length, u8 *data)
+{
+ int status=0;
+ u16 Addr=MICNG_EE_START;
+ u8 EETag[3];
+ u16 tag=0;
+ int retry,i;
+
+ while (Addr+sizeof(u16)+1<MICNG_EE_END) {
+ if (i2c_read_eeprom(adapter, 0x50,
+ Addr, EETag, sizeof(EETag)))
+ return -1;
+ tag=(EETag[0]<<8)|EETag[1];
+ if (tag==MICNG_EETAG_END0 || tag==MICNG_EETAG_END1)
+ return -1;
+ if (tag==Tag)
+ break;
+ Addr+=sizeof(u16)+1+EETag[2];
+ }
+ if (Addr+sizeof(u16)+1+EETag[2]>MICNG_EE_END) {
+ printk(DEVICE_NAME
+ ": Reached EOEE @ Tag = %04x Length = %3d\n",
+ tag, EETag[2]);
+ return -1;
+ }
+
+ if (Length>EETag[2])
+ return -EINVAL;
+ /* Note: We write the data one byte at a time to avoid
+ issues with page sizes. (which are different for
+ each manufacture and eeprom size)
+ */
+ Addr+=sizeof(u16)+1;
+ for (i=0; i<Length; i++, Addr++) {
+ status=i2c_write_eeprom(adapter, 0x50, Addr, data[i]);
+
+ if (status)
+ break;
+
+ /* Poll for finishing write cycle */
+ retry=10;
+ while (retry) {
+ u8 Tmp;
+
+ msleep(50);
+ status=i2c_read_eeprom(adapter, 0x50, Addr, &Tmp, 1);
+ if (status)
+ break;
+ if (Tmp!=data[i])
+ printk("eeprom write error\n");
+ retry-=1;
+ }
+ if (status) {
+ printk(DEVICE_NAME ": Timeout polling eeprom\n");
+ break;
+ }
+ }
+ return status;
+}
+
+static void i2c_init_eeprom(struct i2c_adapter *adapter)
+{
+ u8 tags[]={ 0x10, 0x00, 0x02, 0x00, 0x00,
+ 0x10, 0x01, 0x02, 0x00, 0x00,
+ 0x00, 0x00, 0x00 };
+
+ int i;
+
+ for (i=0; i<sizeof(tags); i++)
+ i2c_write_eeprom(adapter, 0x50, 0x0100+i, tags[i]);
+}
+
+static int eeprom_read_ushort(struct i2c_adapter *adapter, u16 tag, u16 *data)
+{
+ int stat;
+ u8 buf[2];
+ u32 len=0;
+
+ if ((stat=ReadEEProm(adapter, tag, 2, buf, &len)))
+ return stat;
+ if (len!=2)
+ return -EINVAL;
+
+ *data=(buf[0]<<8)|buf[1];
+ return 0;
+}
+
+static int eeprom_write_ushort(struct i2c_adapter *adapter, u16 tag, u16 data)
+{
+ int stat;
+ u8 buf[2];
+
+ buf[0]=data>>8;
+ buf[1]=data&0xff;
+ if ((stat=WriteEEProm(adapter, tag, 2, buf)))
+ return stat;
+ return 0;
+}
+#endif
static int i2c_dump_eeprom(struct i2c_adapter *adapter, u8 adr)
{
@@ -1641,48 +1651,50 @@ static int send_cli_val(struct ngene *dev, char *cmd, u32 val)
return write_uart(dev, s, strlen(s));
}
-//static int ngene_command_write_uart_user(struct ngene *dev,
-// const u8 *data, int len)
-//{
-// struct ngene_command com;
-//
-// dev->tx_busy=1;
-// com.cmd.hdr.Opcode=CMD_WRITE_UART;
-// com.cmd.hdr.Length=len;
-//
-// if (copy_from_user(com.cmd.WriteUart.Data, data, len))
-// return -EFAULT;
-// com.in_len=len;
-// com.out_len=0;
-//
-// if (ngene_command(dev, &com)<0)
-// return -EIO;
-//
-// return 0;
-//}
-//
-//static ssize_t uart_write(struct file *file, const char *buf,
-// size_t count, loff_t *ppos)
-//{
-// struct dvb_device *dvbdev=file->private_data;
-// struct ngene_channel *chan=dvbdev->priv;
-// struct ngene *dev=chan->dev;
-// int len, ret=0;
-// size_t left=count;
-//
-// while (left) {
-// len=left;
-// if (len>250)
-// len=250;
-// ret=wait_event_interruptible(dev->tx_wq, dev->tx_busy==0);
-// if (ret<0)
-// return ret;
-// ngene_command_write_uart_user(dev, buf, len);
-// left-=len;
-// buf+=len;
-// }
-// return count;
-//}
+#if 0
+static int ngene_command_write_uart_user(struct ngene *dev,
+ const u8 *data, int len)
+{
+ struct ngene_command com;
+
+ dev->tx_busy=1;
+ com.cmd.hdr.Opcode=CMD_WRITE_UART;
+ com.cmd.hdr.Length=len;
+
+ if (copy_from_user(com.cmd.WriteUart.Data, data, len))
+ return -EFAULT;
+ com.in_len=len;
+ com.out_len=0;
+
+ if (ngene_command(dev, &com)<0)
+ return -EIO;
+
+ return 0;
+}
+
+static ssize_t uart_write(struct file *file, const char *buf,
+ size_t count, loff_t *ppos)
+{
+ struct dvb_device *dvbdev=file->private_data;
+ struct ngene_channel *chan=dvbdev->priv;
+ struct ngene *dev=chan->dev;
+ int len, ret=0;
+ size_t left=count;
+
+ while (left) {
+ len=left;
+ if (len>250)
+ len=250;
+ ret=wait_event_interruptible(dev->tx_wq, dev->tx_busy==0);
+ if (ret<0)
+ return ret;
+ ngene_command_write_uart_user(dev, buf, len);
+ left-=len;
+ buf+=len;
+ }
+ return count;
+}
+#endif
static ssize_t ts_write(struct file *file, const char *buf,
size_t count, loff_t *ppos)
@@ -1853,15 +1865,17 @@ static void *tsout_exchange(void *priv, void *buf, u32 len,
return buf;
}
-//static void set_dto(struct ngene_channel *chan, u32 rate)
-//{
-// u64 val=rate*0x89705f41ULL; /* times val for 2^26 Hz */
-//
-// val=((val>>25)+1)>>1;
-// chan->AudioDTOValue=(u32)val;
-// //chan->AudioDTOUpdated=1;
-// //printk("Setting DTO to %08x\n", val);
-//}
+#if 0
+static void set_dto(struct ngene_channel *chan, u32 rate)
+{
+ u64 val=rate*0x89705f41ULL; /* times val for 2^26 Hz */
+
+ val=((val>>25)+1)>>1;
+ chan->AudioDTOValue=(u32)val;
+ //chan->AudioDTOUpdated=1;
+ //printk("Setting DTO to %08x\n", val);
+}
+#endif
static void set_transfer(struct ngene_channel *chan, int state)
{
@@ -2007,196 +2021,198 @@ static int ngene_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
return 0;
}
-//static int write_demod(struct i2c_adapter *adapter,
-// u8 adr, u16 reg, u16 data)
-//{
-// u8 mm[5]={0x10, (reg>>8)&0xff, reg&0xff,
-// (data>>8)&0xff, data&0xff};
-// struct i2c_msg msg={.addr=adr, .flags=0, .buf=mm, .len=5};
-//
-// if (i2c_transfer(adapter, &msg, 1)!=1) {
-// printk("error in write_demod\n");
-// return -1;
-// }
-// return 0;
-//}
-//
-//#if 0
-//static int read_demod(struct i2c_adapter *adapter,
-// u8 adr, u16 reg, u16 *data)
-//{
-// u8 msg[3] = {0x11, (reg>>8)&0xff, reg&0xff};
-// u8 val[2];
-// struct i2c_msg msgs[2]={{.addr=adr, .flags=0,
-// .buf=msg, .len=3 },
-// {.addr=adr, .flags=I2C_M_RD,
-// .buf=val, .len=2 }};
-//
-// if (i2c_transfer(adapter, msgs, 2)!=2) {
-// printk("error in read_demod\n");
-// return -1;
-// }
-// *data=(val[0]<<8)|val[1];
-// return 0;
-//}
-//#endif
-//
-//static int ngene_drxd_pll_set(struct ngene_channel *chan,
-// u8 *pll, u8 *aux, u8 plladr)
-//{
-// struct i2c_adapter *adap=&chan->i2c_adapter;
-// struct i2c_msg msg_pll={.addr=plladr, .flags=0, .buf=pll, .len=4};
-// struct i2c_msg msg_aux={.addr=plladr, .flags=0, .buf=aux, .len=2};
-// int err=0;
-//
-// if (chan->dev->card_info->i2c_access&1)
-// down(&chan->dev->pll_mutex);
-//
-//#if 1
-// chan->fe->ops.i2c_gate_ctrl(chan->fe, 1);
-//#else
-// drxd_config_i2c(chan->fe, 1);
-//#endif
-// if ((err=i2c_transfer(adap, &msg_pll, 1))!=1)
-// goto error;
-// if (aux)
-// err=i2c_transfer(adap, &msg_aux, 1);
-//error:
-//#if 1
-// chan->fe->ops.i2c_gate_ctrl(chan->fe, 0);
-//#else
-// drxd_config_i2c(chan->fe, 0);
-//#endif
-// if (chan->dev->card_info->i2c_access&1)
-// up(&chan->dev->pll_mutex);
-// return err;
-//}
-//
-//static int ngene_pll_set_th_dtt7520x(void *priv, void *priv_params,
-// u8 plladr, u8 dadr, s32 *off)
-//{
-// struct dvb_frontend_parameters *params=priv_params;
-// struct ngene_channel *chan=priv;
-//
-// u32 freq=params->frequency;
-// u8 pll[4], aux[2];
-// u8 c1, c2;
-// u32 div;
-//
-// if (freq<185000000 || freq>900000000)
-// return -EINVAL;
-//
-// if (freq<465000000)
-// c2=0x12;
-// else
-// c2=0x18;
-//
-// if (freq<305000000) c1=0xb4;
-// else if (freq<405000000) c1=0xbc;
-// else if (freq<445000000) c1=0xf4;
-// else if (freq<465000000) c1=0xfc;
-// else if (freq<735000000) c1=0xbc;
-// else if (freq<835000000) c1=0xf4;
-// else c1=0xfc;
-//
-// if (params->u.ofdm.bandwidth==BANDWIDTH_8_MHZ)
-// c2^=0x10;
-//
-// div=(freq+36000000+166667/2)/166667;
-// *off=((s32) div)*166667-(s32)freq-36000000;
-//
-// pll[0]=(div>>8)&0x7f;
-// pll[1]=div&0xff;
-// pll[2]=c1;
-// pll[3]=c2;
-//
-// aux[0]=(c1&0xc7)|0x98;
-// aux[1]=0x30;
-//
-// return ngene_drxd_pll_set(chan, pll, aux, plladr);
-//}
-//
-//static int ngene_pll_set_mt_3x0823(void *priv,
-// void *priv_params,
-// u8 plladr, u8 dadr, s32 *off)
-//{
-// struct dvb_frontend_parameters *params=priv_params;
-// struct ngene_channel *chan=priv;
-// struct i2c_adapter *adap=&chan->i2c_adapter;
-// u32 freq=params->frequency;
-// u8 pll[4];
-// u8 aux[2];
-// u8 c1, c2;
-// u32 div;
-//
-// if (freq<47125000 || freq>855250000)
-// return -EINVAL;
-// else if (freq<120000000) { c1=0xcc; c2=0x01; }
-// else if (freq<155500000) { c1=0xfc; c2=0x01; }
-// else if (freq<300000000) { c1=0xbc; c2=0x02; }
-// else if (freq<467000000) { c1=0xcc; c2=0x02; }
-// else { c1=0xcc; c2=0x04; }
-//
-// if (params->u.ofdm.bandwidth==BANDWIDTH_8_MHZ)
-// c2|=0x08;
-//
-//#define INTERFREQ (36000000)
-//
-// div=(freq+INTERFREQ+166667/2)/166667;
-//
-// *off=((s32) div)*166667-(s32)freq-INTERFREQ;
-//
-// pll[0]=(div>>8)&0x7f;
-// pll[1]=div&0xff;
-// pll[2]=c1;
-// pll[3]=c2;
-//
-// aux[0]=(c1&0xc7)|0x98;
-// aux[1]=0x20;
-//
-//#if 0
-// write_demod(adap, dadr, 0x1007, 0x000);
-// write_demod(adap, dadr, 0x1094, 0x500); /*280-7ff*/
-//#else
-// write_demod(adap, dadr, 0x1007, 0xc27);
-//
-// switch (params->u.ofdm.bandwidth) {
-// case BANDWIDTH_7_MHZ:
-// write_demod(adap, dadr, 0x0020, 0x103);
-// break;
-// case BANDWIDTH_AUTO:
-// case BANDWIDTH_8_MHZ:
-// write_demod(adap, dadr, 0x0020, 0x003);
-// break;
-// case BANDWIDTH_6_MHZ:
-// write_demod(adap, dadr, 0x0020, 0x002);
-// /*write_demod(adap, dadr, 0x1022, 397);*/
-// break;
-// }
-//#endif
-//
-// return ngene_drxd_pll_set(chan, pll, aux, plladr);
-//
-//}
-//
-//static s16 osc_deviation(void *priv, s16 deviation, int flag)
-//{
-// struct ngene_channel *chan=priv;
-// struct i2c_adapter *adap=&chan->i2c_adapter;
-// u16 data=0;
-//
-// if (flag) {
-// data=(u16) deviation;
-// printk("write deviation %d\n", deviation);
-// eeprom_write_ushort(adap, 0x1000+chan->number, data);
-// } else {
-// if (eeprom_read_ushort(adap, 0x1000+chan->number, &data))
-// data=0;
-// printk("read deviation %d\n", (s16)data);
-// }
-//
-// return (s16) data;
-//}
+#if 0
+static int write_demod(struct i2c_adapter *adapter,
+ u8 adr, u16 reg, u16 data)
+{
+ u8 mm[5]={0x10, (reg>>8)&0xff, reg&0xff,
+ (data>>8)&0xff, data&0xff};
+ struct i2c_msg msg={.addr=adr, .flags=0, .buf=mm, .len=5};
+
+ if (i2c_transfer(adapter, &msg, 1)!=1) {
+ printk("error in write_demod\n");
+ return -1;
+ }
+ return 0;
+}
+
+#if 0
+static int read_demod(struct i2c_adapter *adapter,
+ u8 adr, u16 reg, u16 *data)
+{
+ u8 msg[3] = {0x11, (reg>>8)&0xff, reg&0xff};
+ u8 val[2];
+ struct i2c_msg msgs[2]={{.addr=adr, .flags=0,
+ .buf=msg, .len=3 },
+ {.addr=adr, .flags=I2C_M_RD,
+ .buf=val, .len=2 }};
+
+ if (i2c_transfer(adapter, msgs, 2)!=2) {
+ printk("error in read_demod\n");
+ return -1;
+ }
+ *data=(val[0]<<8)|val[1];
+ return 0;
+}
+#endif
+
+static int ngene_drxd_pll_set(struct ngene_channel *chan,
+ u8 *pll, u8 *aux, u8 plladr)
+{
+ struct i2c_adapter *adap=&chan->i2c_adapter;
+ struct i2c_msg msg_pll={.addr=plladr, .flags=0, .buf=pll, .len=4};
+ struct i2c_msg msg_aux={.addr=plladr, .flags=0, .buf=aux, .len=2};
+ int err=0;
+
+ if (chan->dev->card_info->i2c_access&1)
+ down(&chan->dev->pll_mutex);
+
+#if 1
+ chan->fe->ops.i2c_gate_ctrl(chan->fe, 1);
+#else
+ drxd_config_i2c(chan->fe, 1);
+#endif
+ if ((err=i2c_transfer(adap, &msg_pll, 1))!=1)
+ goto error;
+ if (aux)
+ err=i2c_transfer(adap, &msg_aux, 1);
+error:
+#if 1
+ chan->fe->ops.i2c_gate_ctrl(chan->fe, 0);
+#else
+ drxd_config_i2c(chan->fe, 0);
+#endif
+ if (chan->dev->card_info->i2c_access&1)
+ up(&chan->dev->pll_mutex);
+ return err;
+}
+
+static int ngene_pll_set_th_dtt7520x(void *priv, void *priv_params,
+ u8 plladr, u8 dadr, s32 *off)
+{
+ struct dvb_frontend_parameters *params=priv_params;
+ struct ngene_channel *chan=priv;
+
+ u32 freq=params->frequency;
+ u8 pll[4], aux[2];
+ u8 c1, c2;
+ u32 div;
+
+ if (freq<185000000 || freq>900000000)
+ return -EINVAL;
+
+ if (freq<465000000)
+ c2=0x12;
+ else
+ c2=0x18;
+
+ if (freq<305000000) c1=0xb4;
+ else if (freq<405000000) c1=0xbc;
+ else if (freq<445000000) c1=0xf4;
+ else if (freq<465000000) c1=0xfc;
+ else if (freq<735000000) c1=0xbc;
+ else if (freq<835000000) c1=0xf4;
+ else c1=0xfc;
+
+ if (params->u.ofdm.bandwidth==BANDWIDTH_8_MHZ)
+ c2^=0x10;
+
+ div=(freq+36000000+166667/2)/166667;
+ *off=((s32) div)*166667-(s32)freq-36000000;
+
+ pll[0]=(div>>8)&0x7f;
+ pll[1]=div&0xff;
+ pll[2]=c1;
+ pll[3]=c2;
+
+ aux[0]=(c1&0xc7)|0x98;
+ aux[1]=0x30;
+
+ return ngene_drxd_pll_set(chan, pll, aux, plladr);
+}
+
+static int ngene_pll_set_mt_3x0823(void *priv,
+ void *priv_params,
+ u8 plladr, u8 dadr, s32 *off)
+{
+ struct dvb_frontend_parameters *params=priv_params;
+ struct ngene_channel *chan=priv;
+ struct i2c_adapter *adap=&chan->i2c_adapter;
+ u32 freq=params->frequency;
+ u8 pll[4];
+ u8 aux[2];
+ u8 c1, c2;
+ u32 div;
+
+ if (freq<47125000 || freq>855250000)
+ return -EINVAL;
+ else if (freq<120000000) { c1=0xcc; c2=0x01; }
+ else if (freq<155500000) { c1=0xfc; c2=0x01; }
+ else if (freq<300000000) { c1=0xbc; c2=0x02; }
+ else if (freq<467000000) { c1=0xcc; c2=0x02; }
+ else { c1=0xcc; c2=0x04; }
+
+ if (params->u.ofdm.bandwidth==BANDWIDTH_8_MHZ)
+ c2|=0x08;
+
+#define INTERFREQ (36000000)
+
+ div=(freq+INTERFREQ+166667/2)/166667;
+
+ *off=((s32) div)*166667-(s32)freq-INTERFREQ;
+
+ pll[0]=(div>>8)&0x7f;
+ pll[1]=div&0xff;
+ pll[2]=c1;
+ pll[3]=c2;
+
+ aux[0]=(c1&0xc7)|0x98;
+ aux[1]=0x20;
+
+#if 0
+ write_demod(adap, dadr, 0x1007, 0x000);
+ write_demod(adap, dadr, 0x1094, 0x500); /*280-7ff*/
+#else
+ write_demod(adap, dadr, 0x1007, 0xc27);
+
+ switch (params->u.ofdm.bandwidth) {
+ case BANDWIDTH_7_MHZ:
+ write_demod(adap, dadr, 0x0020, 0x103);
+ break;
+ case BANDWIDTH_AUTO:
+ case BANDWIDTH_8_MHZ:
+ write_demod(adap, dadr, 0x0020, 0x003);
+ break;
+ case BANDWIDTH_6_MHZ:
+ write_demod(adap, dadr, 0x0020, 0x002);
+ /*write_demod(adap, dadr, 0x1022, 397);*/
+ break;
+ }
+#endif
+
+ return ngene_drxd_pll_set(chan, pll, aux, plladr);
+
+}
+
+static s16 osc_deviation(void *priv, s16 deviation, int flag)
+{
+ struct ngene_channel *chan=priv;
+ struct i2c_adapter *adap=&chan->i2c_adapter;
+ u16 data=0;
+
+ if (flag) {
+ data=(u16) deviation;
+ printk("write deviation %d\n", deviation);
+ eeprom_write_ushort(adap, 0x1000+chan->number, data);
+ } else {
+ if (eeprom_read_ushort(adap, 0x1000+chan->number, &data))
+ data=0;
+ printk("read deviation %d\n", (s16)data);
+ }
+
+ return (s16) data;
+}
+#endif
static int write_to_decoder(struct dvb_demux_feed *feed,
const u8 *buf, size_t len)
@@ -2648,88 +2664,90 @@ static u32 Buffer2Sizes[MAX_STREAM] =
0
};
-//static int allocate_buffer(struct pci_dev *pci_dev,
-// dma_addr_t of,
-// struct SRingBufferDescriptor *rbuf,
-// u32 entries,
-// u32 size1, u32 size2)
-//{
-// if (create_ring_buffer(pci_dev, rbuf, entries)<0)
-// return -ENOMEM;
-//
-// if (AllocateRingBuffers(pci_dev, of,
-// rbuf, size1, size2)<0)
-// return -ENOMEM;
-//
-// return 0;
-//}
-//
-//static int channel_allocate_buffers(struct ngene_channel *chan)
-//{
-// struct ngene *dev=chan->dev;
-// int type=dev->card_info->io_type[chan->number];
-// int status;
-//
-// chan->State = KSSTATE_STOP;
-//
-// if (type&(NGENE_IO_TV|NGENE_IO_HDTV|NGENE_IO_AIN)) {
-// status=create_ring_buffer(dev->pci_dev,
-// &chan->RingBuffer,
-// RingBufferSizes[chan->number]);
-// if (status<0)
-// return -ENOMEM;
-//
-// if (type&(NGENE_IO_TV|NGENE_IO_AIN)) {
-// status=AllocateRingBuffers(dev->pci_dev,
-// dev->PAOverflowBuffer,
-// &chan->RingBuffer,
-// Buffer1Sizes[chan->number],
-// Buffer2Sizes[chan->number]);
-// if (status<0)
-// return -ENOMEM;
-// } else if (type&NGENE_IO_HDTV) {
-// status=AllocateRingBuffers(dev->pci_dev,
-// dev->PAOverflowBuffer,
-// &chan->RingBuffer,
-// MAX_HDTV_BUFFER_SIZE, 0);
-// if (status<0)
-// return -ENOMEM;
-// }
-// }
-//
-// if (type&(NGENE_IO_TSIN|NGENE_IO_TSOUT)) {
-//
-// status=create_ring_buffer(dev->pci_dev,
-// &chan->TSRingBuffer,
-// RING_SIZE_TS);
-// if (status<0)
-// return -ENOMEM;
-//
-// status=AllocateRingBuffers(dev->pci_dev,
-// dev->PAOverflowBuffer,
-// &chan->TSRingBuffer,
-// MAX_TS_BUFFER_SIZE,0);
-// if (status)
-// return -ENOMEM;
-// }
-//
-// if (type&NGENE_IO_TSOUT) {
-// status=create_ring_buffer(dev->pci_dev,
-// &chan->TSIdleBuffer,
-// 1);
-// if (status<0)
-// return -ENOMEM;
-// status=AllocateRingBuffers(dev->pci_dev,
-// dev->PAOverflowBuffer,
-// &chan->TSIdleBuffer,
-// MAX_TS_BUFFER_SIZE,0);
-// if (status)
-// return -ENOMEM;
-// FillTSIdleBuffer(&chan->TSIdleBuffer,
-// &chan->TSRingBuffer);
-// }
-// return 0;
-//}
+#if 0
+static int allocate_buffer(struct pci_dev *pci_dev,
+ dma_addr_t of,
+ struct SRingBufferDescriptor *rbuf,
+ u32 entries,
+ u32 size1, u32 size2)
+{
+ if (create_ring_buffer(pci_dev, rbuf, entries)<0)
+ return -ENOMEM;
+
+ if (AllocateRingBuffers(pci_dev, of,
+ rbuf, size1, size2)<0)
+ return -ENOMEM;
+
+ return 0;
+}
+
+static int channel_allocate_buffers(struct ngene_channel *chan)
+{
+ struct ngene *dev=chan->dev;
+ int type=dev->card_info->io_type[chan->number];
+ int status;
+
+ chan->State = KSSTATE_STOP;
+
+ if (type&(NGENE_IO_TV|NGENE_IO_HDTV|NGENE_IO_AIN)) {
+ status=create_ring_buffer(dev->pci_dev,
+ &chan->RingBuffer,
+ RingBufferSizes[chan->number]);
+ if (status<0)
+ return -ENOMEM;
+
+ if (type&(NGENE_IO_TV|NGENE_IO_AIN)) {
+ status=AllocateRingBuffers(dev->pci_dev,
+ dev->PAOverflowBuffer,
+ &chan->RingBuffer,
+ Buffer1Sizes[chan->number],
+ Buffer2Sizes[chan->number]);
+ if (status<0)
+ return -ENOMEM;
+ } else if (type&NGENE_IO_HDTV) {
+ status=AllocateRingBuffers(dev->pci_dev,
+ dev->PAOverflowBuffer,
+ &chan->RingBuffer,
+ MAX_HDTV_BUFFER_SIZE, 0);
+ if (status<0)
+ return -ENOMEM;
+ }
+ }
+
+ if (type&(NGENE_IO_TSIN|NGENE_IO_TSOUT)) {
+
+ status=create_ring_buffer(dev->pci_dev,
+ &chan->TSRingBuffer,
+ RING_SIZE_TS);
+ if (status<0)
+ return -ENOMEM;
+
+ status=AllocateRingBuffers(dev->pci_dev,
+ dev->PAOverflowBuffer,
+ &chan->TSRingBuffer,
+ MAX_TS_BUFFER_SIZE,0);
+ if (status)
+ return -ENOMEM;
+ }
+
+ if (type&NGENE_IO_TSOUT) {
+ status=create_ring_buffer(dev->pci_dev,
+ &chan->TSIdleBuffer,
+ 1);
+ if (status<0)
+ return -ENOMEM;
+ status=AllocateRingBuffers(dev->pci_dev,
+ dev->PAOverflowBuffer,
+ &chan->TSIdleBuffer,
+ MAX_TS_BUFFER_SIZE,0);
+ if (status)
+ return -ENOMEM;
+ FillTSIdleBuffer(&chan->TSIdleBuffer,
+ &chan->TSRingBuffer);
+ }
+ return 0;
+}
+#endif
static int AllocCommonBuffers(struct ngene *dev)
{
@@ -3000,7 +3018,7 @@ static int ngene_start(struct ngene *dev)
if (dev->card_info->fw_version==17) {
u8 hdtv_config[6]={6144/64,0,0,2048/64,2048/64,2048/64};
u8 tsin4_config[6]={3072/64,3072/64,0,3072/64,3072/64,0};
-// u8 ts5_config[6]={2048/64,2048/64,0,2048/64,2048/64,2048/64};
+ //u8 ts5_config[6]={2048/64,2048/64,0,2048/64,2048/64,2048/64};
u8 default_config[6]={4096/64,4096/64,0,2048/64,2048/64,0};
u8 *bconf=default_config;
@@ -3363,19 +3381,22 @@ static int lnbh21_set_tone(struct dvb_frontend *fe,
}
#endif
+
/****************************************************************************/
/* Switch control (I2C gates, etc.) *****************************************/
/****************************************************************************/
-//static int avf_output(struct ngene_channel *chan, int state)
-//{
-// if (chan->dev->card_info->avf[chan->number])
-// i2c_write_register(&chan->i2c_adapter,
-// chan->dev->
-// card_info->avf[chan->number],
-// 0xf2, state ? 0x89 : 0x80);
-// return 0;
-//}
+#if 0
+static int avf_output(struct ngene_channel *chan, int state)
+{
+ if (chan->dev->card_info->avf[chan->number])
+ i2c_write_register(&chan->i2c_adapter,
+ chan->dev->
+ card_info->avf[chan->number],
+ 0xf2, state ? 0x89 : 0x80);
+ return 0;
+}
+#endif
/* Viper expander: sw11,sw12,sw21,sw22,i2csw1,i2csw2,tsen1,tsen2 */
@@ -3395,162 +3416,167 @@ static int exp_init(struct ngene *dev)
return exp_set(dev);
}
-//static int exp_set_bit(struct ngene *dev, int bit, int val)
-//{
-// if (val)
-// set_bit(bit, &dev->exp_val);
-// else
-// clear_bit(bit, &dev->exp_val);
-// return exp_set(dev);
-//}
-//
-//static int viper_switch_ctrl(struct ngene_channel *chan, int type, int val)
-//{
-// switch (type) {
-// case 0: /* I2C tuner gate on/off */
-// return exp_set_bit(chan->dev, 4+chan->number, val);
-// case 1: /* Stream: 0=TS 1=ITU */
-// avf_output(chan, val);
-// return exp_set_bit(chan->dev, 6+chan->number, val);
-// case 2: /* Input: 0=digital 1=analog antenna input */
-// exp_set_bit(chan->dev, 0+chan->number*2, val ? 0 : 1);
-// exp_set_bit(chan->dev, 1+chan->number*2, val ? 1 : 0);
-// break;
-// }
-// return 0;
-//}
-//
-//static int viper_switch_ctrl2(struct ngene_channel *chan, int type, int val)
-//{
-// switch (type) {
-// case 0: /* I2C tuner gate on/off */
-// return exp_set_bit(chan->dev, 4+chan->number, val);
-// case 1: /* Stream: 0=TS 1=ITU */
-// avf_output(chan, val);
-// return exp_set_bit(chan->dev, 6+chan->number, val);
-// case 2: /* Input: 0=digital 1=analog antenna input */
-// exp_set_bit(chan->dev, 0+chan->number*2, val ? 0 : 1);
-// exp_set_bit(chan->dev, 1+chan->number*2, 0);
-// break;
-// }
-// return 0;
-//}
-//
-//static int viper_gate_ctrl(struct dvb_frontend *fe, int enable)
-//{
-//#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
-// struct ngene_channel *chan=fe->misc_priv;
-//#else /* Why is there no misc_priv available anymore !?!?! */
-// /* Well, just abuse sec :-) */
-// struct ngene_channel *chan=fe->sec_priv;
-//#endif
-// struct ngene *dev=chan->dev;
-//
-// return dev->card_info->switch_ctrl(chan, 0, enable);
-//}
-//
-//static int python_switch_ctrl(struct ngene_channel *chan, int type, int val)
-//{
-// switch (type) {
-// case 0: /* I2C tuner gate on/off */
-// if (chan->number>1)
-// return -EINVAL;
-// return ngene_command_gpio_set(chan->dev, 3+chan->number, val);
-// case 1: /* Stream: 0=TS 1=ITU */
-// avf_output(chan, val);
-// return 0;
-// }
-// return 0;
-//}
-//
-//static int viper_reset_xc(struct dvb_frontend *fe)
-//{
-//#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
-// struct ngene_channel *chan=fe->misc_priv;
-//#else
-// struct ngene_channel *chan=fe->sec_priv;
-//#endif
-// struct ngene *dev=chan->dev;
-//
-// printk("Reset XC3028\n");
-//
-// if (chan->number>1)
-// return -EINVAL;
-//
-// ngene_command_gpio_set(dev, 3+chan->number, 0);
-// msleep(150);
-// ngene_command_gpio_set(dev, 3+chan->number, 1);
-// return 0;
-//}
-//
-//static int python_gate_ctrl(struct dvb_frontend *fe, int enable)
-//{
-//#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
-// struct ngene_channel *chan=fe->misc_priv;
-//#else /* Why is there no misc_priv available anymore !?!?! */
-// struct ngene_channel *chan=fe->sec_priv;
-//#endif
-// struct ngene *dev=chan->dev;
-//
-// if (chan->number==0)
-// return ngene_command_gpio_set(dev, 3, enable);
-// if (chan->number==1)
-// return ngene_command_gpio_set(dev, 4, enable);
-// return -EINVAL;
-//}
+#if 0
+static int exp_set_bit(struct ngene *dev, int bit, int val)
+{
+ if (val)
+ set_bit(bit, &dev->exp_val);
+ else
+ clear_bit(bit, &dev->exp_val);
+ return exp_set(dev);
+}
+
+static int viper_switch_ctrl(struct ngene_channel *chan, int type, int val)
+{
+ switch (type) {
+ case 0: /* I2C tuner gate on/off */
+ return exp_set_bit(chan->dev, 4+chan->number, val);
+ case 1: /* Stream: 0=TS 1=ITU */
+ avf_output(chan, val);
+ return exp_set_bit(chan->dev, 6+chan->number, val);
+ case 2: /* Input: 0=digital 1=analog antenna input */
+ exp_set_bit(chan->dev, 0+chan->number*2, val ? 0 : 1);
+ exp_set_bit(chan->dev, 1+chan->number*2, val ? 1 : 0);
+ break;
+ }
+ return 0;
+}
+
+static int viper_switch_ctrl2(struct ngene_channel *chan, int type, int val)
+{
+ switch (type) {
+ case 0: /* I2C tuner gate on/off */
+ return exp_set_bit(chan->dev, 4+chan->number, val);
+ case 1: /* Stream: 0=TS 1=ITU */
+ avf_output(chan, val);
+ return exp_set_bit(chan->dev, 6+chan->number, val);
+ case 2: /* Input: 0=digital 1=analog antenna input */
+ exp_set_bit(chan->dev, 0+chan->number*2, val ? 0 : 1);
+ exp_set_bit(chan->dev, 1+chan->number*2, 0);
+ break;
+ }
+ return 0;
+}
+
+static int viper_gate_ctrl(struct dvb_frontend *fe, int enable)
+{
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ struct ngene_channel *chan=fe->misc_priv;
+#else /* Why is there no misc_priv available anymore !?!?! */
+ /* Well, just abuse sec :-) */
+ struct ngene_channel *chan=fe->sec_priv;
+#endif
+ struct ngene *dev=chan->dev;
+
+ return dev->card_info->switch_ctrl(chan, 0, enable);
+}
+
+static int python_switch_ctrl(struct ngene_channel *chan, int type, int val)
+{
+ switch (type) {
+ case 0: /* I2C tuner gate on/off */
+ if (chan->number>1)
+ return -EINVAL;
+ return ngene_command_gpio_set(chan->dev, 3+chan->number, val);
+ case 1: /* Stream: 0=TS 1=ITU */
+ avf_output(chan, val);
+ return 0;
+ }
+ return 0;
+}
+
+static int viper_reset_xc(struct dvb_frontend *fe)
+{
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ struct ngene_channel *chan=fe->misc_priv;
+#else
+ struct ngene_channel *chan=fe->sec_priv;
+#endif
+ struct ngene *dev=chan->dev;
+
+ printk("Reset XC3028\n");
+
+ if (chan->number>1)
+ return -EINVAL;
+
+ ngene_command_gpio_set(dev, 3+chan->number, 0);
+ msleep(150);
+ ngene_command_gpio_set(dev, 3+chan->number, 1);
+ return 0;
+}
+
+static int python_gate_ctrl(struct dvb_frontend *fe, int enable)
+{
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ struct ngene_channel *chan=fe->misc_priv;
+#else /* Why is there no misc_priv available anymore !?!?! */
+ struct ngene_channel *chan=fe->sec_priv;
+#endif
+ struct ngene *dev=chan->dev;
+
+ if (chan->number==0)
+ return ngene_command_gpio_set(dev, 3, enable);
+ if (chan->number==1)
+ return ngene_command_gpio_set(dev, 4, enable);
+ return -EINVAL;
+}
+#endif
/****************************************************************************/
/* Demod/tuner attachment ***************************************************/
/****************************************************************************/
-//static int tuner_attach_mt2060(struct ngene_channel *chan)
-//{
-// struct ngene *dev=chan->dev;
-// void *tconf=dev->card_info->tuner_config[chan->number];
-// u8 drxa=dev->card_info->demoda[chan->number];
-// struct dvb_frontend *fe=chan->fe, *fe2;
-//
-//#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
-// fe->misc_priv=chan;
-//#else
-// fe->sec_priv=chan;
-//#endif
-// fe->ops.i2c_gate_ctrl=dev->card_info->gate_ctrl;
-//
-// dev->card_info->gate_ctrl(fe, 1);
-// fe2=mt2060_attach(fe, &chan->i2c_adapter, tconf, 1220);
-// dev->card_info->gate_ctrl(fe, 0);
-//
-// i2c_write_register(&chan->i2c_adapter, drxa, 3, 4);
-// write_demod(&chan->i2c_adapter, drxa, 0x1012, 15);
-// write_demod(&chan->i2c_adapter, drxa, 0x1007, 0xc27);
-// write_demod(&chan->i2c_adapter, drxa, 0x0020, 0x003);
-//
-// return fe2 ? 0 : -ENODEV;
-//}
-//
-//static int tuner_attach_xc3028(struct ngene_channel *chan)
-//{
-// struct ngene *dev=chan->dev;
-// void *tconf=dev->card_info->tuner_config[chan->number];
-// struct dvb_frontend *fe=chan->fe, *fe2;
-//
-//#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
-// fe->misc_priv=chan;
-//#else
-// fe->sec_priv=chan;
-//#endif
-// fe->ops.i2c_gate_ctrl=dev->card_info->gate_ctrl;
-//
-// dev->card_info->gate_ctrl(fe, 1);
-// fe2=xc3028_attach(fe, &chan->i2c_adapter, tconf);
-// dev->card_info->gate_ctrl(fe, 0);
-//
-// /*chan->fe->ops.tuner_ops.set_frequency(chan->fe,231250000);*/
-//
-// return fe2 ? 0 : -ENODEV;
-//}
+#if 0
+static int tuner_attach_mt2060(struct ngene_channel *chan)
+{
+ struct ngene *dev=chan->dev;
+ void *tconf=dev->card_info->tuner_config[chan->number];
+ u8 drxa=dev->card_info->demoda[chan->number];
+ struct dvb_frontend *fe=chan->fe, *fe2;
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ fe->misc_priv=chan;
+#else
+ fe->sec_priv=chan;
+#endif
+ fe->ops.i2c_gate_ctrl=dev->card_info->gate_ctrl;
+
+ dev->card_info->gate_ctrl(fe, 1);
+ fe2=mt2060_attach(fe, &chan->i2c_adapter, tconf, 1220);
+ dev->card_info->gate_ctrl(fe, 0);
+
+ i2c_write_register(&chan->i2c_adapter, drxa, 3, 4);
+ write_demod(&chan->i2c_adapter, drxa, 0x1012, 15);
+ write_demod(&chan->i2c_adapter, drxa, 0x1007, 0xc27);
+ write_demod(&chan->i2c_adapter, drxa, 0x0020, 0x003);
+
+ return fe2 ? 0 : -ENODEV;
+}
+
+static int tuner_attach_xc3028(struct ngene_channel *chan)
+{
+ struct ngene *dev=chan->dev;
+ void *tconf=dev->card_info->tuner_config[chan->number];
+ struct dvb_frontend *fe=chan->fe, *fe2;
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ fe->misc_priv=chan;
+#else
+ fe->sec_priv=chan;
+#endif
+ fe->ops.i2c_gate_ctrl=dev->card_info->gate_ctrl;
+
+ dev->card_info->gate_ctrl(fe, 1);
+ fe2=xc3028_attach(fe, &chan->i2c_adapter, tconf);
+ dev->card_info->gate_ctrl(fe, 0);
+
+ /*chan->fe->ops.tuner_ops.set_frequency(chan->fe,231250000);*/
+
+ return fe2 ? 0 : -ENODEV;
+}
+
+#endif
static int tuner_attach_stv6110(struct ngene_channel *chan)
{
@@ -3581,6 +3607,7 @@ static int tuner_attach_stv6110(struct ngene_channel *chan)
feconf->tuner_get_bbgain = ctl->tuner_get_bbgain;
feconf->tuner_set_refclk = ctl->tuner_set_refclk;
feconf->tuner_get_status = ctl->tuner_get_status;
+
#else
struct stv6110_config *tunerconf =
(struct stv6110_config*)chan->dev->card_info->tuner_config[chan->number];
@@ -3603,9 +3630,7 @@ static int tuner_attach_stv6110(struct ngene_channel *chan)
chan->fe->ops.set_voltage=lnbh21_set_voltage;
#else
printk(DEVICE_NAME ": lnbh24_attach: nr = %d, lnb = %x\n", chan->number, chan->dev->card_info->lnb[chan->number]);
- if (!dvb_attach(lnbh24_attach, chan->fe, &chan->i2c_adapter,
- 0, /* LNBH24_PCL */
- 0, /* LNBH24_TTX */
+ if (!dvb_attach(lnbh24_attach, chan->fe, &chan->i2c_adapter, 0, 0,
chan->dev->card_info->lnb[chan->number])) {
printk(KERN_ERR "No LNBH24 found!\n");
return -ENODEV;
@@ -3615,47 +3640,49 @@ static int tuner_attach_stv6110(struct ngene_channel *chan)
return 0;
}
-//static int demod_attach_drxd(struct ngene_channel *chan)
-//{
-// void *feconf=chan->dev->card_info->fe_config[chan->number];
-//
-// chan->fe=drxd_attach(feconf,
-// chan, &chan->i2c_adapter,
-// &chan->dev->pci_dev->dev);
-// return (chan->fe) ? 0 : -ENODEV;
-//}
-//
-//static int demod_attach_drxh(struct ngene_channel *chan)
-//{
-// void *feconf=chan->dev->card_info->fe_config[chan->number];
-//
-// chan->fe=drxh_attach(feconf, chan,
-// &chan->i2c_adapter,
-// &chan->dev->pci_dev->dev);
-// return (chan->fe) ? 0 : -ENODEV;
-//}
-//
-//static int demod_attach_stb0899(struct ngene_channel *chan)
-//{
-// void *feconf=chan->dev->card_info->fe_config[chan->number];
-//
-// chan->fe=stb0899_attach(feconf,
-// chan, &chan->i2c_adapter,
-// &chan->dev->pci_dev->dev);
-// if (chan->fe) {
-//#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
-// chan->set_tone=chan->fe->ops->set_tone;
-// chan->fe->ops->set_tone=lnbh21_set_tone;
-// chan->fe->ops->set_voltage=lnbh21_set_voltage;
-//#else
-// chan->set_tone=chan->fe->ops.set_tone;
-// chan->fe->ops.set_tone=lnbh21_set_tone;
-// chan->fe->ops.set_voltage=lnbh21_set_voltage;
-//#endif
-// }
-//
-// return (chan->fe) ? 0 : -ENODEV;
-//}
+#if 0
+static int demod_attach_drxd(struct ngene_channel *chan)
+{
+ void *feconf=chan->dev->card_info->fe_config[chan->number];
+
+ chan->fe=drxd_attach(feconf,
+ chan, &chan->i2c_adapter,
+ &chan->dev->pci_dev->dev);
+ return (chan->fe) ? 0 : -ENODEV;
+}
+
+static int demod_attach_drxh(struct ngene_channel *chan)
+{
+ void *feconf=chan->dev->card_info->fe_config[chan->number];
+
+ chan->fe=drxh_attach(feconf, chan,
+ &chan->i2c_adapter,
+ &chan->dev->pci_dev->dev);
+ return (chan->fe) ? 0 : -ENODEV;
+}
+
+static int demod_attach_stb0899(struct ngene_channel *chan)
+{
+ void *feconf=chan->dev->card_info->fe_config[chan->number];
+
+ chan->fe=stb0899_attach(feconf,
+ chan, &chan->i2c_adapter,
+ &chan->dev->pci_dev->dev);
+ if (chan->fe) {
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
+ chan->set_tone=chan->fe->ops->set_tone;
+ chan->fe->ops->set_tone=lnbh21_set_tone;
+ chan->fe->ops->set_voltage=lnbh21_set_voltage;
+#else
+ chan->set_tone=chan->fe->ops.set_tone;
+ chan->fe->ops.set_tone=lnbh21_set_tone;
+ chan->fe->ops.set_voltage=lnbh21_set_voltage;
+#endif
+ }
+
+ return (chan->fe) ? 0 : -ENODEV;
+}
+#endif
static int demod_attach_stv0900(struct ngene_channel *chan)
{
@@ -3985,141 +4012,143 @@ fail1:
/* Card configs *************************************************************/
/****************************************************************************/
-//static struct drxd_config fe_terratec_dvbt_0 = {
-// .index=0, .demod_address=0x70, .demod_revision=0xa2,
-// .demoda_address=0x00, .pll_address=0x60,
-// .pll_type=DRXD_PLL_DTT7520X, .clock=20000,
-// .pll_set=ngene_pll_set_th_dtt7520x,
-// .osc_deviation=osc_deviation,
-//};
-//
-//static struct drxd_config fe_terratec_dvbt_1 = {
-// .index=1, .demod_address=0x71, .demod_revision=0xa2,
-// .demoda_address=0x00, .pll_address=0x60,
-// .pll_type=DRXD_PLL_DTT7520X, .clock=20000,
-// .pll_set=ngene_pll_set_th_dtt7520x,
-// .osc_deviation=osc_deviation,
-//};
-//
-//static struct ngene_info ngene_info_terratec = {
-// .type=NGENE_TERRATEC,
-// .name="Terratec Integra/Cinergy2400i Dual DVB-T",
-// .io_type={NGENE_IO_TSIN, NGENE_IO_TSIN},
-// .demod_attach={demod_attach_drxd, demod_attach_drxd},
-// .fe_config={&fe_terratec_dvbt_0, &fe_terratec_dvbt_1 },
-// .i2c_access=1,
-//};
+#if 0
+static struct drxd_config fe_terratec_dvbt_0 = {
+ .index=0, .demod_address=0x70, .demod_revision=0xa2,
+ .demoda_address=0x00, .pll_address=0x60,
+ .pll_type=DRXD_PLL_DTT7520X, .clock=20000,
+ .pll_set=ngene_pll_set_th_dtt7520x,
+ .osc_deviation=osc_deviation,
+};
+
+static struct drxd_config fe_terratec_dvbt_1 = {
+ .index=1, .demod_address=0x71, .demod_revision=0xa2,
+ .demoda_address=0x00, .pll_address=0x60,
+ .pll_type=DRXD_PLL_DTT7520X, .clock=20000,
+ .pll_set=ngene_pll_set_th_dtt7520x,
+ .osc_deviation=osc_deviation,
+};
+
+static struct ngene_info ngene_info_terratec = {
+ .type=NGENE_TERRATEC,
+ .name="Terratec Integra/Cinergy2400i Dual DVB-T",
+ .io_type={NGENE_IO_TSIN, NGENE_IO_TSIN},
+ .demod_attach={demod_attach_drxd, demod_attach_drxd},
+ .fe_config={&fe_terratec_dvbt_0, &fe_terratec_dvbt_1 },
+ .i2c_access=1,
+};
/****************************************************************************/
-//static struct mt2060_config tuner_python_0 = {
-// .i2c_address = 0x60,
-// .clock_out = 3,
-// .input = 0
-//};
-//
-//static struct mt2060_config tuner_python_1 = {
-// .i2c_address = 0x61,
-// .clock_out = 3,
-// .input = 1
-//};
-//
-//static struct drxd_config fe_python_0 = {
-// .index = 0,
-// .demod_address = 0x71,
-// .demod_revision = 0xb1,
-// .demoda_address = 0x41,
-// .clock = 16000,
-// .osc_deviation = osc_deviation,
-//};
-//
-//static struct drxd_config fe_python_1 = {
-// .index = 1,
-// .demod_address = 0x70,
-// .demod_revision = 0xb1,
-// .demoda_address = 0x45,
-// .clock = 16000,
-// .osc_deviation = osc_deviation,
-//};
-//
-//static struct ngene_info ngene_info_python = {
-// .type = NGENE_PYTHON,
-// .name = "Micronas MicPython/Hedgehog Dual DVB-T",
-// .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_AIN, NGENE_IO_AIN },
-// .demod_attach = { demod_attach_drxd, demod_attach_drxd },
-// .tuner_attach = { tuner_attach_mt2060, tuner_attach_mt2060 },
-// .fe_config = { &fe_python_0, &fe_python_1 },
-// .tuner_config = { &tuner_python_0, &tuner_python_1 },
-// .avf = { 0x43, 0x47 },
-// .msp = { 0x40, 0x42 },
-// .demoda = { 0x41, 0x45 },
-// .gate_ctrl = python_gate_ctrl,
-// .switch_ctrl = python_switch_ctrl,
-//};
+static struct mt2060_config tuner_python_0 = {
+ .i2c_address = 0x60,
+ .clock_out = 3,
+ .input = 0
+};
+
+static struct mt2060_config tuner_python_1 = {
+ .i2c_address = 0x61,
+ .clock_out = 3,
+ .input = 1
+};
+
+static struct drxd_config fe_python_0 = {
+ .index = 0,
+ .demod_address = 0x71,
+ .demod_revision = 0xb1,
+ .demoda_address = 0x41,
+ .clock = 16000,
+ .osc_deviation = osc_deviation,
+};
+
+static struct drxd_config fe_python_1 = {
+ .index = 1,
+ .demod_address = 0x70,
+ .demod_revision = 0xb1,
+ .demoda_address = 0x45,
+ .clock = 16000,
+ .osc_deviation = osc_deviation,
+};
+
+static struct ngene_info ngene_info_python = {
+ .type = NGENE_PYTHON,
+ .name = "Micronas MicPython/Hedgehog Dual DVB-T",
+ .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_AIN, NGENE_IO_AIN },
+ .demod_attach = { demod_attach_drxd, demod_attach_drxd },
+ .tuner_attach = { tuner_attach_mt2060, tuner_attach_mt2060 },
+ .fe_config = { &fe_python_0, &fe_python_1 },
+ .tuner_config = { &tuner_python_0, &tuner_python_1 },
+ .avf = { 0x43, 0x47 },
+ .msp = { 0x40, 0x42 },
+ .demoda = { 0x41, 0x45 },
+ .gate_ctrl = python_gate_ctrl,
+ .switch_ctrl = python_switch_ctrl,
+};
/****************************************************************************/
-//static struct drxd_config fe_appb_dvbt_0 = {
-// .index = 0,
-// .demod_address = 0x71,
-// .demod_revision = 0xa2,
-// .demoda_address = 0x41,
-// .pll_address = 0x63,
-// .pll_type = DRXD_PLL_MT3X0823, .clock=20000,
-// .pll_set = ngene_pll_set_mt_3x0823,
-// .osc_deviation = osc_deviation,
-//};
-//
-//static struct drxd_config fe_appb_dvbt_1 = {
-// .index = 1,
-// .demod_address = 0x70,
-// .demod_revision = 0xa2,
-// .demoda_address = 0x45,
-// .pll_address = 0x60,
-// .pll_type = DRXD_PLL_MT3X0823, .clock=20000,
-// .pll_set = ngene_pll_set_mt_3x0823,
-// .osc_deviation = osc_deviation,
-//};
-//
-//static struct ngene_info ngene_info_appboard = {
-// .type = NGENE_APP,
-// .name = "Micronas Application Board Dual DVB-T",
-// .io_type = {NGENE_IO_TSIN, NGENE_IO_TSIN},
-// .demod_attach = {demod_attach_drxd, demod_attach_drxd},
-// .fe_config = {&fe_appb_dvbt_0, &fe_appb_dvbt_1 },
-// .avf = {0x43, 0x47},
-//};
-//
-//static struct ngene_info ngene_info_appboard_ntsc = {
-// .type = NGENE_APP,
-// .name = "Micronas Application Board Dual DVB-T",
-// .io_type = {NGENE_IO_TSIN, NGENE_IO_TSIN},
-// .demod_attach = {demod_attach_drxd, demod_attach_drxd},
-// .fe_config = {&fe_appb_dvbt_0, &fe_appb_dvbt_1 },
-// .avf = {0x43, 0x47},
-// .ntsc=1,
-//};
+static struct drxd_config fe_appb_dvbt_0 = {
+ .index = 0,
+ .demod_address = 0x71,
+ .demod_revision = 0xa2,
+ .demoda_address = 0x41,
+ .pll_address = 0x63,
+ .pll_type = DRXD_PLL_MT3X0823, .clock=20000,
+ .pll_set = ngene_pll_set_mt_3x0823,
+ .osc_deviation = osc_deviation,
+};
+
+static struct drxd_config fe_appb_dvbt_1 = {
+ .index = 1,
+ .demod_address = 0x70,
+ .demod_revision = 0xa2,
+ .demoda_address = 0x45,
+ .pll_address = 0x60,
+ .pll_type = DRXD_PLL_MT3X0823, .clock=20000,
+ .pll_set = ngene_pll_set_mt_3x0823,
+ .osc_deviation = osc_deviation,
+};
+
+static struct ngene_info ngene_info_appboard = {
+ .type = NGENE_APP,
+ .name = "Micronas Application Board Dual DVB-T",
+ .io_type = {NGENE_IO_TSIN, NGENE_IO_TSIN},
+ .demod_attach = {demod_attach_drxd, demod_attach_drxd},
+ .fe_config = {&fe_appb_dvbt_0, &fe_appb_dvbt_1 },
+ .avf = {0x43, 0x47},
+};
+
+static struct ngene_info ngene_info_appboard_ntsc = {
+ .type = NGENE_APP,
+ .name = "Micronas Application Board Dual DVB-T",
+ .io_type = {NGENE_IO_TSIN, NGENE_IO_TSIN},
+ .demod_attach = {demod_attach_drxd, demod_attach_drxd},
+ .fe_config = {&fe_appb_dvbt_0, &fe_appb_dvbt_1 },
+ .avf = {0x43, 0x47},
+ .ntsc=1,
+};
/****************************************************************************/
-//static struct stb0899_config fe_sidewinder_0 = {
-// .demod_address=0x68, .pll_address=0x63,
-//};
-//
-//static struct stb0899_config fe_sidewinder_1 = {
-// .demod_address=0x6b, .pll_address=0x60,
-//};
-//
-//static struct ngene_info ngene_info_sidewinder = {
-// .type = NGENE_SIDEWINDER,
-// .name = "Micronas MicSquirrel/Sidewinder Dual DVB-S2",
-// .io_type = { NGENE_IO_TSIN, NGENE_IO_TSIN },
-// .demod_attach = { demod_attach_stb0899, demod_attach_stb0899 },
-// .fe_config = { &fe_sidewinder_0, &fe_sidewinder_1 },
-// .lnb = { 0x0b, 0x08 },
-//};
+static struct stb0899_config fe_sidewinder_0 = {
+ .demod_address=0x68, .pll_address=0x63,
+};
+
+static struct stb0899_config fe_sidewinder_1 = {
+ .demod_address=0x6b, .pll_address=0x60,
+};
+
+static struct ngene_info ngene_info_sidewinder = {
+ .type = NGENE_SIDEWINDER,
+ .name = "Micronas MicSquirrel/Sidewinder Dual DVB-S2",
+ .io_type = { NGENE_IO_TSIN, NGENE_IO_TSIN },
+ .demod_attach = { demod_attach_stb0899, demod_attach_stb0899 },
+ .fe_config = { &fe_sidewinder_0, &fe_sidewinder_1 },
+ .lnb = { 0x0b, 0x08 },
+};
+#endif
/****************************************************************************/
@@ -4133,10 +4162,10 @@ static struct stv090x_config fe_mps2 = {
.address = 0x68,
.ref_clk = 27000000,
- .ts1_mode = STV090x_TSMODE_SERIAL_PUNCTURED,
- .ts2_mode = STV090x_TSMODE_SERIAL_PUNCTURED,
+ .ts1_mode = STV090x_TSMODE_SERIAL_PUNCTURED, /* => TSCFGH.SERIAL & TSCFGH.TSFIFO_DVBCI */
+ .ts2_mode = STV090x_TSMODE_SERIAL_PUNCTURED, /* => TSCFGH.SERIAL & TSCFGH.TSFIFO_DVBCI */
- .repeater_level = STV090x_RPTLEVEL_64, /* STV090x_RPTLEVEL_16 */
+ .repeater_level = STV090x_RPTLEVEL_16, /* => I2CRPT.ENARPT_LEVEL */
.tuner_init = NULL,
.tuner_set_mode = NULL,
@@ -4186,12 +4215,12 @@ static struct stv0900_reg stv0900_regs[] = {
// { R0900_P1_TNRCFG2, 0x80 }, /* v4l: 0x82 */
// { R0900_P2_TNRCFG2, 0x80 }, /* v4l: 0x02 */
//TSCFG
-// { R0900_P1_TSCFGH, 0x60 }, /* v4l: 0xe0 */
-// { R0900_P2_TSCFGH, 0x60 }, /* v4l: 0xe0 */
+ { R0900_P1_TSCFGH, 0x60 }, /* v4l: 0xe0 */
+ { R0900_P2_TSCFGH, 0x60 }, /* v4l: 0xe0 */
{ R0900_P1_TSCFGM, 0x00 }, /* v4l: 0xc0 */
{ R0900_P2_TSCFGM, 0x00 }, /* v4l: 0xc0 */
-// { R0900_P1_TSCFGL, 0x20 }, /* v4l: 0x20 */
-// { R0900_P2_TSCFGL, 0x20 }, /* v4l: 0x20 */
+ { R0900_P1_TSCFGL, 0x20 }, /* v4l: 0x20 */
+ { R0900_P2_TSCFGL, 0x20 }, /* v4l: 0x20 */
// { R0900_P1_BCLC2S2Q, 0x86 }, /* v4l: 0x86 */
// { R0900_P2_BCLC2S2Q, 0xa5 }, /* v4l: 0x86 */
@@ -4203,36 +4232,35 @@ static struct stv0900_reg stv0900_regs[] = {
{ 0xffff, 0xff }, /* terminate */
};
-//TODO F0900_INV_CLKADCI1 = 1
static struct stv0900_config fe_mps2 = {
.demod_address = 0x68,
.xtal = 27000000,
- .clkmode = 2,/* 0-CLKI, 2-XTALI, else AUTO */
- .diseqc_mode = 2,/* 2/3 PWM */
+ .clkmode = 2, /* 0-CLKI, 2-XTALI, else AUTO => SYNTCTRL.SELOSCI */
+ .diseqc_mode = 2, /* ??? => DISTXCTL.DISTX_MODE */
/* STV0900_USE_REGISTERS_DEFAULT = 0,
* STV0900_SERIAL_PUNCT_CLOCK = 1,
* STV0900_SERIAL_CONT_CLOCK = 2,
* STV0900_PARALLEL_PUNCT_CLOCK = 3,
* STV0900_DVBCI_CLOCK = 4 */
-// .path1_mode = 1,
-// .path2_mode = 1,
+// .path1_mode = 1, /* => TSCFGH.TSFIFO_SERIAL & TSCFGH.TSFIFO_DVBCI */
+// .path2_mode = 1, /* => TSCFGH.TSFIFO_SERIAL & TSCFGH.TSFIFO_DVBCI */
.ts_config_regs = stv0900_regs,
- .tun1_maddress = 0,/* 0x60 */
- .tun2_maddress = 3,/* 0x63 */
- .tun1_adc = 0,
- .tun2_adc = 0,
+ .tun1_maddress = 0, /* 0x60 */
+ .tun2_maddress = 3, /* 0x63 */
+ .tun1_adc = 1, /* => if 1 TSTTNR1=0x26 */
+ .tun2_adc = 1, /* => if 1 TSTTNR3=0x26 */
};
static struct stv6110_config tuner_mps2_0 = {
.i2c_address = 0x60,
- .mclk = 27000000,
- .clk_div = 1,
+ .mclk = 27000000, /* => CTRL1.K */
+ .clk_div = 1, /* => CTRL2.CO_DIV */
};
static struct stv6110_config tuner_mps2_1 = {
.i2c_address = 0x63,
- .mclk = 27000000,
- .clk_div = 1,
+ .mclk = 27000000, /* => CTRL1.K */
+ .clk_div = 1, /* => CTRL2.CO_DIV */
};
#endif /* NGENE_STV090X */
@@ -4254,153 +4282,155 @@ static struct ngene_info ngene_info_mps2 = {
/* Yet unnamed S2 card with dual DVB-S2 demod */
/****************************************************************************/
-//static struct stv0900_config fe_s2_0 = {
-// .addr=0x68, .pll=0x63, .pll_type=0, .nr=0,
-//};
-//
-//static struct stv0900_config fe_s2_1 = {
-// .addr=0x68, .pll=0x60, .pll_type=0, .nr=1,
-//};
-//
-//static struct ngene_info ngene_info_s2 = {
-// .type = NGENE_SIDEWINDER,
-// .name = "S2",
-// .io_type = { NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN },
-// .demod_attach = { demod_attach_stv0900, demod_attach_stv0900 },
-// .fe_config = { &fe_s2_0, &fe_s2_1 },
-// .lnb = { 0x0b, 0x08 },
-// .tsf = { 3, 3 },
-// .fw_version = 15,
-//};
-
-//static struct stv0900_config fe_s2b_0 = {
-// .addr=0x68, .pll=0x60, .pll_type=0x10, .nr=0,
-//};
-//
-//static struct stv0900_config fe_s2b_1 = {
-// .addr=0x68, .pll=0x63, .pll_type=0x10, .nr=1,
-//};
-//
-//static struct ngene_info ngene_info_s2_b = {
-// .type = NGENE_SIDEWINDER,
-// .name = "S2 V2",
-// .io_type = { NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN },
-// .demod_attach = { demod_attach_stv0900, demod_attach_stv0900 },
-// .fe_config = { &fe_s2b_0, &fe_s2b_1 },
-// .lnb = { 0x0b, 0x08 },
-// .tsf = { 3, 3 },
-// .fw_version = 17,
-//};
-//
-///****************************************************************************/
-//
-//static struct xc3028_config tuner_viper_0 = {
-// .adr = 0x61, .reset=viper_reset_xc
-//};
-//
-//static struct xc3028_config tuner_viper_1 = {
-// .adr = 0x64, .reset=viper_reset_xc
-//};
-//
-//static struct drxh_config fe_viper_h_0 = { .adr=0x2b };
-//
-//static struct drxh_config fe_viper_h_1 = { .adr=0x29 };
-//
-//static struct drxh_config fe_viper_l_0 = { .adr=0x2b, .type=3931 };
-//
-//static struct drxh_config fe_viper_l_1 = { .adr=0x29, .type=3931 };
-//
-//static struct ngene_info ngene_info_viper_v1 = {
-// .type = NGENE_VIPER,
-// .name = "Micronas MicViper Dual ATSC DRXH",
-// .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_AIN, NGENE_IO_AIN },
-// .demod_attach = { demod_attach_drxh, demod_attach_drxh },
-// .fe_config = { &fe_viper_h_0, &fe_viper_h_1 },
-// .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
-// .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
-// .avf = { 0x43, 0x47 },
-// .msp = { 0x40, 0x42 },
-// .exp = 0x20,
-// .exp_init = 0xf5,
-// .gate_ctrl = viper_gate_ctrl,
-// .switch_ctrl = viper_switch_ctrl,
-// .tsf = { 2, 2 },
-//};
-//
-//static struct ngene_info ngene_info_viper_v2 = {
-// .type = NGENE_VIPER,
-// .name = "Micronas MicViper Dual ATSC DRXL",
-// .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_AIN, NGENE_IO_AIN },
-// .demod_attach = { demod_attach_drxh, demod_attach_drxh },
-// .fe_config = { &fe_viper_l_0, &fe_viper_l_1 },
-// .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
-// .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
-// .avf = { 0x43, 0x47 },
-// .msp = { 0x40, 0x42 },
-// .exp = 0x38,
-// .exp_init = 0xf5,
-// .gate_ctrl = viper_gate_ctrl,
-// .switch_ctrl = viper_switch_ctrl,
-// .tsf = { 2, 2 },
-//};
+#if 0
+static struct stv0900_config fe_s2_0 = {
+ .addr=0x68, .pll=0x63, .pll_type=0, .nr=0,
+};
+
+static struct stv0900_config fe_s2_1 = {
+ .addr=0x68, .pll=0x60, .pll_type=0, .nr=1,
+};
+
+static struct ngene_info ngene_info_s2 = {
+ .type = NGENE_SIDEWINDER,
+ .name = "S2",
+ .io_type = { NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN },
+ .demod_attach = { demod_attach_stv0900, demod_attach_stv0900 },
+ .fe_config = { &fe_s2_0, &fe_s2_1 },
+ .lnb = { 0x0b, 0x08 },
+ .tsf = { 3, 3 },
+ .fw_version = 15,
+};
+
+static struct stv0900_config fe_s2b_0 = {
+ .addr=0x68, .pll=0x60, .pll_type=0x10, .nr=0,
+};
+
+static struct stv0900_config fe_s2b_1 = {
+ .addr=0x68, .pll=0x63, .pll_type=0x10, .nr=1,
+};
+
+static struct ngene_info ngene_info_s2_b = {
+ .type = NGENE_SIDEWINDER,
+ .name = "S2 V2",
+ .io_type = { NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN, NGENE_IO_TSIN },
+ .demod_attach = { demod_attach_stv0900, demod_attach_stv0900 },
+ .fe_config = { &fe_s2b_0, &fe_s2b_1 },
+ .lnb = { 0x0b, 0x08 },
+ .tsf = { 3, 3 },
+ .fw_version = 17,
+};
+
+/****************************************************************************/
+
+static struct xc3028_config tuner_viper_0 = {
+ .adr = 0x61, .reset=viper_reset_xc
+};
+
+static struct xc3028_config tuner_viper_1 = {
+ .adr = 0x64, .reset=viper_reset_xc
+};
+
+static struct drxh_config fe_viper_h_0 = { .adr=0x2b };
+
+static struct drxh_config fe_viper_h_1 = { .adr=0x29 };
+
+static struct drxh_config fe_viper_l_0 = { .adr=0x2b, .type=3931 };
+
+static struct drxh_config fe_viper_l_1 = { .adr=0x29, .type=3931 };
+
+static struct ngene_info ngene_info_viper_v1 = {
+ .type = NGENE_VIPER,
+ .name = "Micronas MicViper Dual ATSC DRXH",
+ .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_AIN, NGENE_IO_AIN },
+ .demod_attach = { demod_attach_drxh, demod_attach_drxh },
+ .fe_config = { &fe_viper_h_0, &fe_viper_h_1 },
+ .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
+ .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
+ .avf = { 0x43, 0x47 },
+ .msp = { 0x40, 0x42 },
+ .exp = 0x20,
+ .exp_init = 0xf5,
+ .gate_ctrl = viper_gate_ctrl,
+ .switch_ctrl = viper_switch_ctrl,
+ .tsf = { 2, 2 },
+};
+
+static struct ngene_info ngene_info_viper_v2 = {
+ .type = NGENE_VIPER,
+ .name = "Micronas MicViper Dual ATSC DRXL",
+ .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_AIN, NGENE_IO_AIN },
+ .demod_attach = { demod_attach_drxh, demod_attach_drxh },
+ .fe_config = { &fe_viper_l_0, &fe_viper_l_1 },
+ .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
+ .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
+ .avf = { 0x43, 0x47 },
+ .msp = { 0x40, 0x42 },
+ .exp = 0x38,
+ .exp_init = 0xf5,
+ .gate_ctrl = viper_gate_ctrl,
+ .switch_ctrl = viper_switch_ctrl,
+ .tsf = { 2, 2 },
+};
/****************************************************************************/
-//static struct ngene_info ngene_info_vbox_v1 = {
-// .type = NGENE_VBOX_V1,
-// .name = "VBox Cat's Eye 164E",
-// .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_AIN, NGENE_IO_AIN },
-// .demod_attach = { demod_attach_drxh, demod_attach_drxh },
-// .fe_config = { &fe_viper_h_0, &fe_viper_h_1 },
-// .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
-// .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
-// .avf = { 0x43, 0x47 },
-// .msp = { 0x40, 0x42 },
-// .exp = 0x20,
-// .exp_init = 0xf5,
-// .gate_ctrl = viper_gate_ctrl,
-// .switch_ctrl = viper_switch_ctrl,
-// .tsf = { 2, 2 },
-//};
+static struct ngene_info ngene_info_vbox_v1 = {
+ .type = NGENE_VBOX_V1,
+ .name = "VBox Cat's Eye 164E",
+ .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_AIN, NGENE_IO_AIN },
+ .demod_attach = { demod_attach_drxh, demod_attach_drxh },
+ .fe_config = { &fe_viper_h_0, &fe_viper_h_1 },
+ .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
+ .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
+ .avf = { 0x43, 0x47 },
+ .msp = { 0x40, 0x42 },
+ .exp = 0x20,
+ .exp_init = 0xf5,
+ .gate_ctrl = viper_gate_ctrl,
+ .switch_ctrl = viper_switch_ctrl,
+ .tsf = { 2, 2 },
+};
/****************************************************************************/
-//static struct ngene_info ngene_info_vbox_v2 = {
-// .type = NGENE_VBOX_V2,
-// .name = "VBox Cat's Eye 164E",
-// .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_TSIN | NGENE_IO_TV,
-// NGENE_IO_AIN, NGENE_IO_AIN },
-// .demod_attach = { demod_attach_drxh, demod_attach_drxh },
-// .fe_config = { &fe_viper_h_0, &fe_viper_h_1 },
-// .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
-// .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
-// .avf = { 0x43, 0x47 },
-// .msp = { 0x40, 0x42 },
-// .exp = 0x20,
-// .exp_init = 0xf5,
-// .gate_ctrl = viper_gate_ctrl,
-// .switch_ctrl = viper_switch_ctrl2,
-// .tsf = { 2, 2 },
-//};
+static struct ngene_info ngene_info_vbox_v2 = {
+ .type = NGENE_VBOX_V2,
+ .name = "VBox Cat's Eye 164E",
+ .io_type = { NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_TSIN | NGENE_IO_TV,
+ NGENE_IO_AIN, NGENE_IO_AIN },
+ .demod_attach = { demod_attach_drxh, demod_attach_drxh },
+ .fe_config = { &fe_viper_h_0, &fe_viper_h_1 },
+ .tuner_config = { &tuner_viper_0, &tuner_viper_1 },
+ .tuner_attach = { tuner_attach_xc3028, tuner_attach_xc3028 },
+ .avf = { 0x43, 0x47 },
+ .msp = { 0x40, 0x42 },
+ .exp = 0x20,
+ .exp_init = 0xf5,
+ .gate_ctrl = viper_gate_ctrl,
+ .switch_ctrl = viper_switch_ctrl2,
+ .tsf = { 2, 2 },
+};
/****************************************************************************/
-//static struct ngene_info ngene_info_racer = {
-// .type = NGENE_RACER,
-// .name = "Micronas MicRacer HDTV Decoder Card",
-// .io_type = { NGENE_IO_HDTV, NGENE_IO_NONE,
-// NGENE_IO_AIN, NGENE_IO_NONE,
-// NGENE_IO_TSOUT },
-// .i2s = { 0, 0, 1, 0 },
-// .fw_version = 17,
-//};
+static struct ngene_info ngene_info_racer = {
+ .type = NGENE_RACER,
+ .name = "Micronas MicRacer HDTV Decoder Card",
+ .io_type = { NGENE_IO_HDTV, NGENE_IO_NONE,
+ NGENE_IO_AIN, NGENE_IO_NONE,
+ NGENE_IO_TSOUT },
+ .i2s = { 0, 0, 1, 0 },
+ .fw_version = 17,
+};
+#endif
/****************************************************************************/
@@ -4415,13 +4445,13 @@ static struct ngene_info ngene_info_mps2 = {
/****************************************************************************/
static const struct pci_device_id ngene_id_tbl[] __devinitdata = {
-//TODO NGENE_ID( 0x153b, 0x1167, ngene_info_terratec ),
NGENE_ID( 0x18c3, 0xabc3, ngene_info_mps2 ),
#if 0 /* not (yet?) supported */
NGENE_ID( 0x18c3, 0x0000, ngene_info_appboard ),
NGENE_ID( 0x18c3, 0x0004, ngene_info_appboard ),
NGENE_ID( 0x18c3, 0x8011, ngene_info_appboard ),
NGENE_ID( 0x18c3, 0x8015, ngene_info_appboard_ntsc ),
+ NGENE_ID( 0x153b, 0x1167, ngene_info_terratec ),
NGENE_ID( 0x18c3, 0x0030, ngene_info_python ),
NGENE_ID( 0x18c3, 0x0052, ngene_info_sidewinder ),
NGENE_ID( 0x18c3, 0x8f00, ngene_info_racer ),