summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGerd Knorr <devnull@localhost>2005-02-09 19:27:21 +0000
committerGerd Knorr <devnull@localhost>2005-02-09 19:27:21 +0000
commita57f1dd6d13a9b061984fe1621703da7ae99090d (patch)
tree2599ac5eb9411b6573213c22407fcf583ac4f769
parentd88c7c9e5a9181439bd0facde6802a881acd5442 (diff)
downloadmediapointer-dvb-s2-a57f1dd6d13a9b061984fe1621703da7ae99090d.tar.gz
mediapointer-dvb-s2-a57f1dd6d13a9b061984fe1621703da7ae99090d.tar.bz2
- make the new splitted tuner module build.
-rw-r--r--linux/drivers/media/video/cx88/cx88-input.c4
-rw-r--r--linux/drivers/media/video/mt20xx.c29
-rw-r--r--linux/drivers/media/video/tda8290.c164
-rw-r--r--linux/drivers/media/video/tuner-core.c30
-rw-r--r--linux/drivers/media/video/tuner-simple.c7
-rw-r--r--linux/include/media/tuner.h9
6 files changed, 107 insertions, 136 deletions
diff --git a/linux/drivers/media/video/cx88/cx88-input.c b/linux/drivers/media/video/cx88/cx88-input.c
index 0570cebe8..d6266e51a 100644
--- a/linux/drivers/media/video/cx88/cx88-input.c
+++ b/linux/drivers/media/video/cx88/cx88-input.c
@@ -1,5 +1,5 @@
/*
- * $Id: cx88-input.c,v 1.5 2005/01/31 11:35:05 kraxel Exp $
+ * $Id: cx88-input.c,v 1.6 2005/02/09 19:27:21 kraxel Exp $
*
* Device driver for GPIO attached remote control interfaces
* on Conexant 2388x based TV/DVB cards.
@@ -95,8 +95,10 @@ static IR_KEYTAB_TYPE ir_codes_hauppauge_new[IR_KEYTAB_SIZE] = {
[ 0x1f ] = KEY_EXIT, // back/exit
[ 0x20 ] = KEY_CHANNELUP, // channel / program +
[ 0x21 ] = KEY_CHANNELDOWN, // channel / program -
+ [ 0x22 ] = KEY_CHANNEL, // source (old black remote)
[ 0x24 ] = KEY_PREVIOUS, // replay |<
[ 0x25 ] = KEY_ENTER, // OK
+ [ 0x26 ] = KEY_SLEEP, // minimize (old black remote)
[ 0x29 ] = KEY_BLUE, // blue key
[ 0x2e ] = KEY_GREEN, // green button
[ 0x30 ] = KEY_PAUSE, // pause
diff --git a/linux/drivers/media/video/mt20xx.c b/linux/drivers/media/video/mt20xx.c
index c505b33af..4e66135d1 100644
--- a/linux/drivers/media/video/mt20xx.c
+++ b/linux/drivers/media/video/mt20xx.c
@@ -1,5 +1,8 @@
/*
- * $Id: mt20xx.c,v 1.1 2005/02/09 15:42:46 kraxel Exp $
+ * $Id: mt20xx.c,v 1.2 2005/02/09 19:27:21 kraxel Exp $
+ *
+ * i2c tv tuner chip device driver
+ * controls microtune tuners, mt2032 + mt2050 at the moment.
*/
#include <linux/delay.h>
#include <linux/i2c.h>
@@ -149,13 +152,13 @@ static int mt2032_check_lo_lock(struct i2c_client *c)
buf[0]=0x0e;
i2c_master_send(c,buf,1);
i2c_master_recv(c,buf,1);
- dprintk("mt2032 Reg.E=0x%02x\n",buf[0]);
+ printk("mt2032 Reg.E=0x%02x\n",buf[0]);
lock=buf[0] &0x06;
if (lock==6)
break;
- dprintk("mt2032: pll wait 1ms for lock (0x%2x)\n",buf[0]);
+ printk("mt2032: pll wait 1ms for lock (0x%2x)\n",buf[0]);
udelay(1000);
}
return lock;
@@ -169,7 +172,7 @@ static int mt2032_optimize_vco(struct i2c_client *c,int sel,int lock)
buf[0]=0x0f;
i2c_master_send(c,buf,1);
i2c_master_recv(c,buf,1);
- dprintk("mt2032 Reg.F=0x%02x\n",buf[0]);
+ printk("mt2032 Reg.F=0x%02x\n",buf[0]);
tad1=buf[0]&0x07;
if(tad1 ==0) return lock;
@@ -187,7 +190,7 @@ static int mt2032_optimize_vco(struct i2c_client *c,int sel,int lock)
return lock;
}
- dprintk("mt2032 optimize_vco: sel=%d\n",sel);
+ printk("mt2032 optimize_vco: sel=%d\n",sel);
buf[0]=0x0f;
buf[1]=sel;
@@ -205,7 +208,7 @@ static void mt2032_set_if_freq(struct i2c_client *c, unsigned int rfin,
int lint_try,ret,sel,lock=0;
struct tuner *t = i2c_get_clientdata(c);
- dprintk("mt2032_set_if_freq rfin=%d if1=%d if2=%d from=%d to=%d\n",rfin,if1,if2,from,to);
+ printk("mt2032_set_if_freq rfin=%d if1=%d if2=%d from=%d to=%d\n",rfin,if1,if2,from,to);
buf[0]=0;
ret=i2c_master_send(c,buf,1);
@@ -315,17 +318,17 @@ static int mt2032_init(struct i2c_client *c)
// Adjust XOGC (register 7), wait for XOK
xogc=7;
do {
- dprintk("mt2032: xogc = 0x%02x\n",xogc&0x07);
+ printk("mt2032: xogc = 0x%02x\n",xogc&0x07);
mdelay(10);
buf[0]=0x0e;
i2c_master_send(c,buf,1);
i2c_master_recv(c,buf,1);
xok=buf[0]&0x01;
- dprintk("mt2032: xok = 0x%02x\n",xok);
+ printk("mt2032: xok = 0x%02x\n",xok);
if (xok == 1) break;
xogc--;
- dprintk("mt2032: xogc = 0x%02x\n",xogc&0x07);
+ printk("mt2032: xogc = 0x%02x\n",xogc&0x07);
if (xogc == 3) {
xogc=4; // min. 4 per spec
break;
@@ -351,7 +354,7 @@ static void mt2050_set_antenna(struct i2c_client *c, unsigned char antenna)
buf[0] = 6;
buf[1] = antenna ? 0x11 : 0x10;
ret=i2c_master_send(c,buf,2);
- dprintk("mt2050: enabled antenna connector %d\n", antenna);
+ printk("mt2050: enabled antenna connector %d\n", antenna);
}
static void mt2050_set_if_freq(struct i2c_client *c,unsigned int freq, unsigned int if2)
@@ -361,8 +364,8 @@ static void mt2050_set_if_freq(struct i2c_client *c,unsigned int freq, unsigned
int ret;
unsigned char buf[6];
- dprintk("mt2050_set_if_freq freq=%d if1=%d if2=%d\n",
- freq,if1,if2);
+ printk("mt2050_set_if_freq freq=%d if1=%d if2=%d\n",
+ freq,if1,if2);
f_lo1=freq+if1;
f_lo1=(f_lo1/1000000)*1000000;
@@ -462,7 +465,7 @@ static int mt2050_init(struct i2c_client *c)
ret=i2c_master_send(c,buf,1);
i2c_master_recv(c,buf,1);
- dprintk("mt2050: sro is %x\n",buf[0]);
+ printk("mt2050: sro is %x\n",buf[0]);
t->tv_freq = mt2050_set_tv_freq;
t->radio_freq = mt2050_set_radio_freq;
return 0;
diff --git a/linux/drivers/media/video/tda8290.c b/linux/drivers/media/video/tda8290.c
index 898ac62e5..6c54d9e82 100644
--- a/linux/drivers/media/video/tda8290.c
+++ b/linux/drivers/media/video/tda8290.c
@@ -1,5 +1,8 @@
/*
- * $Id: tda8290.c,v 1.1 2005/02/09 15:42:46 kraxel Exp $
+ * $Id: tda8290.c,v 1.2 2005/02/09 19:27:21 kraxel Exp $
+ *
+ * i2c tv tuner chip device driver
+ * controls the philips tda8290+75 tuner chip combo.
*/
#include <linux/i2c.h>
#include <linux/videodev.h>
@@ -8,9 +11,12 @@
/* ---------------------------------------------------------------------- */
+#define I2C_ADDR_TDA8290 0x4b
+#define I2C_ADDR_TDA8275 0x61
+
struct freq_entry {
- __u16 freq;
- __u8 value;
+ u16 freq;
+ u8 value;
};
static struct freq_entry band_table[] = {
@@ -71,12 +77,9 @@ static unsigned char i2c_init_tda8275[14] = { 0x00, 0x00, 0x00, 0x00,
0x00, 0x40 };
static unsigned char i2c_set_VS[2] = { 0x30, 0x6F };
static unsigned char i2c_set_GP01_CF[2] = { 0x20, 0x0B };
-static unsigned char i2c_easy_mode[2] = { 0x01, 0x02 };
static unsigned char i2c_tda8290_reset[2] = { 0x00, 0x00 };
static unsigned char i2c_gainset_off[2] = { 0x28, 0x14 };
static unsigned char i2c_gainset_on[2] = { 0x28, 0x54 };
-static unsigned char i2c_set_freq[8] = { 0x00, 0x00, 0x00, 0x40,
- 0x52, 0x00, 0x00, 0x8F };
static unsigned char i2c_agc3_00[2] = { 0x80, 0x00 };
static unsigned char i2c_agc2_BF[2] = { 0x60, 0xBF };
static unsigned char i2c_cb1_D2[2] = { 0x30, 0xD2 };
@@ -94,14 +97,14 @@ static struct i2c_msg i2c_msg_init[] = {
};
static struct i2c_msg i2c_msg_prolog[] = {
- { I2C_ADDR_TDA8290, 0, ARRAY_SIZE(i2c_easy_mode), i2c_easy_mode },
+// { I2C_ADDR_TDA8290, 0, ARRAY_SIZE(i2c_easy_mode), i2c_easy_mode },
{ I2C_ADDR_TDA8290, 0, ARRAY_SIZE(i2c_gainset_off), i2c_gainset_off },
{ I2C_ADDR_TDA8290, 0, ARRAY_SIZE(i2c_tda8290_reset), i2c_tda8290_reset },
{ I2C_ADDR_TDA8290, 0, ARRAY_SIZE(i2c_enable_bridge), i2c_enable_bridge },
};
static struct i2c_msg i2c_msg_config[] = {
- { I2C_ADDR_TDA8275, 0, ARRAY_SIZE(i2c_set_freq), i2c_set_freq },
+// { I2C_ADDR_TDA8275, 0, ARRAY_SIZE(i2c_set_freq), i2c_set_freq },
{ I2C_ADDR_TDA8275, 0, ARRAY_SIZE(i2c_agc3_00), i2c_agc3_00 },
{ I2C_ADDR_TDA8275, 0, ARRAY_SIZE(i2c_agc2_BF), i2c_agc2_BF },
{ I2C_ADDR_TDA8275, 0, ARRAY_SIZE(i2c_cb1_D2), i2c_cb1_D2 },
@@ -117,26 +120,38 @@ static struct i2c_msg i2c_msg_epilog[] = {
{ I2C_ADDR_TDA8290, 0, ARRAY_SIZE(i2c_gainset_on), i2c_gainset_on },
};
-static int tda8290_tune(void)
+static int tda8290_tune(struct i2c_client *c)
{
- i2c_transfer(tda8290_client_template.adapter, i2c_msg_prolog, ARRAY_SIZE(i2c_msg_prolog));
- i2c_transfer(tda8290_client_template.adapter, i2c_msg_config, ARRAY_SIZE(i2c_msg_config));
- msleep(550);
- i2c_transfer(tda8290_client_template.adapter, i2c_msg_epilog, ARRAY_SIZE(i2c_msg_epilog));
+ struct tuner *t = i2c_get_clientdata(c);
+ struct i2c_msg easy_mode =
+ { I2C_ADDR_TDA8290, 0, 2, t->i2c_easy_mode };
+ struct i2c_msg set_freq =
+ { I2C_ADDR_TDA8290, 0, 8, t->i2c_set_freq };
+
+ i2c_transfer(c->adapter, &easy_mode, 1);
+ i2c_transfer(c->adapter, i2c_msg_prolog, ARRAY_SIZE(i2c_msg_prolog));
+
+ i2c_transfer(c->adapter, &set_freq, 1);
+ i2c_transfer(c->adapter, i2c_msg_config, ARRAY_SIZE(i2c_msg_config));
+ msleep(550);
+ i2c_transfer(c->adapter, i2c_msg_epilog, ARRAY_SIZE(i2c_msg_epilog));
return 0;
}
-static void set_frequency(struct tuner *t, u32 frequency, u16 ifc)
+static void set_frequency(struct tuner *t, u16 ifc)
{
- u32 N = (((frequency<<3)+ifc)&0x3fffc);
-
- N = N >> get_freq_entry(div_table, frequency);
-
- i2c_set_freq[1] = (unsigned char)(N>>8);
- i2c_set_freq[2] = (unsigned char) N;
- i2c_set_freq[5] = get_freq_entry(band_table, frequency);
- i2c_set_freq[6] = get_freq_entry(agc_table, frequency);
+ u32 N = (((t->freq<<3)+ifc)&0x3fffc);
+
+ N = N >> get_freq_entry(div_table, t->freq);
+ t->i2c_set_freq[0] = 0;
+ t->i2c_set_freq[1] = (unsigned char)(N>>8);
+ t->i2c_set_freq[2] = (unsigned char) N;
+ t->i2c_set_freq[0] = 0x40;
+ t->i2c_set_freq[0] = 0x52;
+ t->i2c_set_freq[5] = get_freq_entry(band_table, t->freq);
+ t->i2c_set_freq[6] = get_freq_entry(agc_table, t->freq);
+ t->i2c_set_freq[0] = 0x8f;
}
#define V4L2_STD_MN (V4L2_STD_PAL_M|V4L2_STD_PAL_N|V4L2_STD_PAL_Nc|V4L2_STD_NTSC)
@@ -146,18 +161,20 @@ static void set_frequency(struct tuner *t, u32 frequency, u16 ifc)
static void set_audio(struct tuner *t)
{
+ t->i2c_easy_mode[0] = 0x01;
+
if (t->std & V4L2_STD_MN)
- i2c_easy_mode[1] = 0x01;
+ t->i2c_easy_mode[1] = 0x01;
else if (t->std & V4L2_STD_B)
- i2c_easy_mode[1] = 0x02;
+ t->i2c_easy_mode[1] = 0x02;
else if (t->std & V4L2_STD_GH)
- i2c_easy_mode[1] = 0x04;
+ t->i2c_easy_mode[1] = 0x04;
else if (t->std & V4L2_STD_PAL_I)
- i2c_easy_mode[1] = 0x08;
+ t->i2c_easy_mode[1] = 0x08;
else if (t->std & V4L2_STD_DK)
- i2c_easy_mode[1] = 0x10;
+ t->i2c_easy_mode[1] = 0x10;
else if (t->std & V4L2_STD_SECAM_L)
- i2c_easy_mode[1] = 0x20;
+ t->i2c_easy_mode[1] = 0x20;
}
static void set_tv_freq(struct i2c_client *c, unsigned int freq)
@@ -165,18 +182,28 @@ static void set_tv_freq(struct i2c_client *c, unsigned int freq)
struct tuner *t = i2c_get_clientdata(c);
set_audio(t);
- set_frequency(t, f->frequency, 864);
- tda8290_tune();
+ set_frequency(t, 864);
+ tda8290_tune(c);
}
static void set_radio_freq(struct i2c_client *c, unsigned int freq)
{
struct tuner *t = i2c_get_clientdata(c);
- set_frequency(t, f->frequency, 704);
- tda8290_tune();
+ set_frequency(t, 704);
+ tda8290_tune(c);
}
-int default_tuner_init(struct i2c_client *c)
+static int has_signal(struct i2c_client *c)
+{
+ unsigned char i2c_get_afc[1] = { 0x1B };
+ unsigned char afc = 0;
+
+ i2c_master_send(c, i2c_get_afc, ARRAY_SIZE(i2c_get_afc));
+ i2c_master_recv(c, &afc, 1);
+ return (afc & 0x80)? 65535:0;
+}
+
+int tda8290_init(struct i2c_client *c)
{
struct tuner *t = i2c_get_clientdata(c);
@@ -184,77 +211,13 @@ int default_tuner_init(struct i2c_client *c)
printk("tuner: type set to %s\n", c->name);
t->tv_freq = set_tv_freq;
t->radio_freq = set_radio_freq;
- return 0;
-}
-
-/* ----------------------------------------------------------------------- */
-
-#if 0
-
-static int tda8290_command(struct i2c_client *client, unsigned int cmd, void *arg)
-{
- if( client->addr == I2C_ADDR_TDA8275)
- return 0;
-
- switch (cmd) {
- /* --- v4l ioctls --- */
- case VIDIOC_G_TUNER:
- {
- struct v4l2_tuner* t = arg;
-
- if (t->type == V4L2_TUNER_ANALOG_TV)
- {
- unsigned char afc = 0;
- unsigned char i2c_get_afc[1] = { 0x1B };
-
- i2c_master_send(&tda8290_client_template, i2c_get_afc, ARRAY_SIZE(i2c_get_afc));
- i2c_master_recv(&tda8290_client_template, &afc, 1);
-
- t->signal = (afc & 0x80)? 65535:0;
- t->afc = -((((char)(afc<<1))*3375)>>9);
- }
- return 0;
- }
- }
-
- return -EINVAL;
-}
-
-static int tda8290_attach(struct i2c_adapter *adap, int addr, int kind)
-{
- printk("%s: chip found @ 0x%x\n", __FUNCTION__, addr);
-
- switch(addr)
- {
- case I2C_ADDR_TDA8290:
- {
- tda8290_client_template.adapter = adap;
- tda8290_client_template.addr = addr;
-
- i2c_attach_client(&tda8290_client_template);
-
- i2c_master_send(&tda8290_client_template, i2c_enable_bridge, ARRAY_SIZE(i2c_enable_bridge));
- } break;
-
- case I2C_ADDR_TDA8275:
- {
- tda8275_client_template.adapter = adap;
- tda8275_client_template.addr = addr;
-
- i2c_attach_client(&tda8275_client_template);
-
- i2c_transfer(tda8290_client_template.adapter, i2c_msg_init, ARRAY_SIZE(i2c_msg_init));
- } break;
-
- default:
- return -EINVAL;
- }
+ t->has_signal = has_signal;
+ i2c_master_send(c, i2c_enable_bridge, ARRAY_SIZE(i2c_enable_bridge));
+ i2c_transfer(c->adapter, i2c_msg_init, ARRAY_SIZE(i2c_msg_init));
return 0;
}
-#endif
-
/*
* Overrides for Emacs so that we follow Linus's tabbing style.
* ---------------------------------------------------------------------------
@@ -262,4 +225,3 @@ static int tda8290_attach(struct i2c_adapter *adap, int addr, int kind)
* c-basic-offset: 8
* End:
*/
-
diff --git a/linux/drivers/media/video/tuner-core.c b/linux/drivers/media/video/tuner-core.c
index f20e7b912..0fdc2fcf6 100644
--- a/linux/drivers/media/video/tuner-core.c
+++ b/linux/drivers/media/video/tuner-core.c
@@ -1,5 +1,8 @@
/*
- * $Id: tuner-core.c,v 1.1 2005/02/09 15:42:46 kraxel Exp $
+ * $Id: tuner-core.c,v 1.2 2005/02/09 19:27:21 kraxel Exp $
+ *
+ * i2c tv tuner chip device driver
+ * core core, i.e. kernel interfaces, registering and so on
*/
#include <linux/module.h>
@@ -242,9 +245,6 @@ static int tuner_detach(struct i2c_client *client)
i2c_detach_client(client);
kfree(t);
kfree(client);
-#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)
- MOD_DEC_USE_COUNT;
-#endif
return 0;
}
@@ -323,10 +323,8 @@ tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
struct video_tuner *vt = arg;
CHECK_V4L2;
-#if 0
- if (V4L2_TUNER_RADIO == t->mode)
- vt->signal = tuner_signal(client);
-#endif
+ if (V4L2_TUNER_RADIO == t->mode && t->has_signal)
+ vt->signal = t->has_signal(client);
return 0;
}
case VIDIOCGAUDIO:
@@ -334,10 +332,10 @@ tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
struct video_audio *va = arg;
CHECK_V4L2;
-#if 0
- if (V4L2_TUNER_RADIO == t->mode)
- va->mode = (tuner_stereo(client) ? VIDEO_SOUND_STEREO : VIDEO_SOUND_MONO);
-#endif
+ if (V4L2_TUNER_RADIO == t->mode && t->is_stereo)
+ va->mode = t->is_stereo(client)
+ ? VIDEO_SOUND_STEREO
+ : VIDEO_SOUND_MONO;
return 0;
}
@@ -371,10 +369,8 @@ tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
struct v4l2_tuner *tuner = arg;
SWITCH_V4L2;
-#if 0
- if (V4L2_TUNER_RADIO == t->mode)
- tuner->signal = tuner_signal(client);
-#endif
+ if (V4L2_TUNER_RADIO == t->mode && t->has_signal)
+ tuner->signal = t->has_signal(client);
break;
}
default:
@@ -406,9 +402,7 @@ static int tuner_resume(struct device * dev, u32 level)
/* ----------------------------------------------------------------------- */
static struct i2c_driver driver = {
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,54)
.owner = THIS_MODULE,
-#endif
.name = "i2c TV tuner driver",
.id = I2C_DRIVERID_TUNER,
.flags = I2C_DF_NOTIFY,
diff --git a/linux/drivers/media/video/tuner-simple.c b/linux/drivers/media/video/tuner-simple.c
index afa89e8d1..231f709d7 100644
--- a/linux/drivers/media/video/tuner-simple.c
+++ b/linux/drivers/media/video/tuner-simple.c
@@ -1,5 +1,8 @@
/*
- * $Id: tuner-simple.c,v 1.1 2005/02/09 15:42:46 kraxel Exp $
+ * $Id: tuner-simple.c,v 1.2 2005/02/09 19:27:21 kraxel Exp $
+ *
+ * i2c tv tuner chip device driver
+ * controls all those simple 4-control-bytes style tuners.
*/
#include <linux/delay.h>
#include <linux/i2c.h>
@@ -455,6 +458,8 @@ int default_tuner_init(struct i2c_client *c)
t->tv_freq = default_set_tv_freq;
t->radio_freq = default_set_radio_freq;
+ t->has_signal = tuner_signal;
+ t->is_stereo = tuner_stereo;
return 0;
}
diff --git a/linux/include/media/tuner.h b/linux/include/media/tuner.h
index f98895daf..369c70904 100644
--- a/linux/include/media/tuner.h
+++ b/linux/include/media/tuner.h
@@ -149,10 +149,15 @@ struct tuner {
unsigned int xogc;
unsigned int radio_if2;
+ /* used by tda8290 */
+ unsigned char i2c_easy_mode[2];
+ unsigned char i2c_set_freq[8];
+
+ /* function ptrs */
void (*tv_freq)(struct i2c_client *c, unsigned int freq);
void (*radio_freq)(struct i2c_client *c, unsigned int freq);
- void (*has_signal)(struct i2c_client *c);
- void (*is_stereo)(struct i2c_client *c);
+ int (*has_signal)(struct i2c_client *c);
+ int (*is_stereo)(struct i2c_client *c);
};
extern unsigned int tuner_debug;