diff options
author | Michael Hunold <devnull@localhost> | 2003-04-24 12:57:17 +0000 |
---|---|---|
committer | Michael Hunold <devnull@localhost> | 2003-04-24 12:57:17 +0000 |
commit | 3e004ed242b3bb9cd7d41031c089c851021c7680 (patch) | |
tree | 66e5e643631d858b52ec1f2d2e6d7e25a1b4ab74 /linux/drivers/media | |
parent | d768b768fbe2bc59f1f3335081fbe907dda9e036 (diff) | |
download | mediapointer-dvb-s2-3e004ed242b3bb9cd7d41031c089c851021c7680.tar.gz mediapointer-dvb-s2-3e004ed242b3bb9cd7d41031c089c851021c7680.tar.bz2 |
Some fixes to get the "analog" i2c drivers to work for both 2.4 and
2.5. Add the DVB_DEVFS_ONLY switch back again.
Diffstat (limited to 'linux/drivers/media')
-rw-r--r-- | linux/drivers/media/dvb/dvb-core/Kconfig | 10 | ||||
-rw-r--r-- | linux/drivers/media/video/saa7111.c | 29 | ||||
-rw-r--r-- | linux/drivers/media/video/tda9840.c | 17 | ||||
-rw-r--r-- | linux/drivers/media/video/tea6415c.c | 13 | ||||
-rw-r--r-- | linux/drivers/media/video/tea6420.c | 13 |
5 files changed, 69 insertions, 13 deletions
diff --git a/linux/drivers/media/dvb/dvb-core/Kconfig b/linux/drivers/media/dvb/dvb-core/Kconfig index 99e2d6b9d..ea925e5c0 100644 --- a/linux/drivers/media/dvb/dvb-core/Kconfig +++ b/linux/drivers/media/dvb/dvb-core/Kconfig @@ -5,3 +5,13 @@ config DVB_CORE DVB core utility functions for device handling, software fallbacks etc. Say Y when you have a DVB card and want to use it. If unsure say N. + +config DVB_DEVFS_ONLY + bool "devfs only" + depends on DVB_CORE=y && DEVFS_FS + help + If you rely completly on devfs, you can drop support for the old + major/minor device scheme. This omits some really awkward lines of + code and saves some space in your kernel image. + + But as always: If unsure say N. diff --git a/linux/drivers/media/video/saa7111.c b/linux/drivers/media/video/saa7111.c index 456e2fdf1..cac5ddd99 100644 --- a/linux/drivers/media/video/saa7111.c +++ b/linux/drivers/media/video/saa7111.c @@ -60,12 +60,10 @@ struct saa7111 { static unsigned short normal_i2c[] = { 0x24, 0x25, I2C_CLIENT_END }; static unsigned short normal_i2c_range[] = { I2C_CLIENT_END }; -/* magic definition of all other variables and things */ I2C_CLIENT_INSMOD; static struct i2c_client client_template; /* ----------------------------------------------------------------------- */ - static int saa7111_attach(struct i2c_adapter *adap, int addr, unsigned short flags, int kind) { int i; @@ -122,7 +120,6 @@ static int saa7111_attach(struct i2c_adapter *adap, int addr, unsigned short fla } memset(decoder, 0, sizeof(*decoder)); - strcpy(client->name, "saa7111"); decoder->client = client; client->data = decoder; decoder->addr = addr; @@ -137,10 +134,18 @@ static int saa7111_attach(struct i2c_adapter *adap, int addr, unsigned short fla i = i2c_master_send(client, init, sizeof(init)); if (i < 0) { printk(KERN_ERR "%s_attach: init status %d\n", +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) client->name, i); +#else + client->dev.name, i); +#endif } else { printk(KERN_INFO "%s_attach: chip version %x @ 0x%08x\n", +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) client->name, i2c_smbus_read_byte_data(client, 0x00) >> 4,addr); +#else + client->dev.name, i2c_smbus_read_byte_data(client, 0x00) >> 4,addr); +#endif } init_MUTEX(&decoder->lock); @@ -165,7 +170,11 @@ static int saa7111_probe(struct i2c_adapter *adap) static int saa7111_detach(struct i2c_client *client) { +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) struct saa7111 *decoder = client->data; +#else + struct saa7111 *decoder = i2c_get_clientdata(client); +#endif i2c_detach_client(client); kfree(decoder); kfree(client); @@ -176,7 +185,11 @@ static int saa7111_detach(struct i2c_client *client) static int saa7111_command(struct i2c_client *client, unsigned int cmd, void *arg) { +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) struct saa7111 *decoder = client->data; +#else + struct saa7111 *decoder = i2c_get_clientdata(client); +#endif switch (cmd) { #if defined(DECODER_DUMP) @@ -187,7 +200,11 @@ static int saa7111_command(struct i2c_client *client, unsigned int cmd, for (i = 0; i < 32; i += 16) { int j; +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) printk("KERN_DEBUG %s: %03x", client->name, +#else + printk("KERN_DEBUG %s: %03x", client->dev.name, +#endif i); for (j = 0; j < 16; ++j) { printk(" %02x", @@ -408,7 +425,13 @@ static struct i2c_driver i2c_driver_saa7111 = { }; static struct i2c_client client_template = { +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) .name = "saa7111_client", +#else + .dev = { + .name = "saa7111_client", + }, +#endif .id = -1, .driver = &i2c_driver_saa7111 }; diff --git a/linux/drivers/media/video/tda9840.c b/linux/drivers/media/video/tda9840.c index 85295ac2d..b5030135a 100644 --- a/linux/drivers/media/video/tda9840.c +++ b/linux/drivers/media/video/tda9840.c @@ -4,7 +4,7 @@ Copyright (C) 1998-2003 Michael Hunold <michael@mihu.de> The tda9840 is a stereo/dual sound processor with digital - identification. It can be found at address 0x84 on the i2c-bus. + identification. It can be found at address 0x42 on the i2c-bus. For detailed informations download the specifications directly from SGS Thomson at http://www.st.com @@ -196,15 +196,19 @@ static int tda9840_detect(struct i2c_adapter *adapter, int address, unsigned sho printk("tda9840.o: not enough kernel memory.\n"); return -ENOMEM; } - + memset(client, 0, sizeof(struct i2c_client)); + /* fill client structure */ +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) sprintf(client->name,"tda9840 (0x%02x)", address); +#else + sprintf(client->dev.name,"tda9840 (0x%02x)", address); +#endif client->id = tda9840_id++; client->flags = 0; client->addr = address; client->adapter = adapter; client->driver = &driver; - client->data = NULL; /* tell the i2c layer a new client has arrived */ if (0 != (result = i2c_attach_client(client))) { @@ -227,8 +231,11 @@ static int tda9840_detect(struct i2c_adapter *adapter, int address, unsigned sho printk("tda9840.o: could not initialize ic #3. continuing anyway. (result:%d)\n",result); } - printk("tda9840.o: detected @ 0x%02x on adapter %s\n",2*address,&client->adapter->name[0]); - +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) + printk("tda9840.o: detected @ 0x%02x on adapter %s\n",address,&client->adapter->name[0]); +#else + printk("tda9840.o: detected @ 0x%02x on adapter %s\n",address,&client->adapter->dev.name[0]); +#endif return 0; } diff --git a/linux/drivers/media/video/tea6415c.c b/linux/drivers/media/video/tea6415c.c index 7215c58f8..fe91e32cb 100644 --- a/linux/drivers/media/video/tea6415c.c +++ b/linux/drivers/media/video/tea6415c.c @@ -6,7 +6,7 @@ The tea6415c is a bus controlled video-matrix-switch with 8 inputs and 6 outputs. It is cascadable, i.e. it can be found at the addresses - 0x86 and 0x06 on the i2c-bus. + 0x43 and 0x03 on the i2c-bus. For detailed informations download the specifications directly from SGS Thomson at http://www.st.com @@ -70,9 +70,14 @@ static int tea6415c_detect(struct i2c_adapter *adapter, int address, unsigned sh if (0 == client) { return -ENOMEM; } + memset(client, 0, sizeof(struct i2c_client)); /* fill client structure */ +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) sprintf(client->name,"tea6415c (0x%02x)", address); +#else + sprintf(client->dev.name,"tea6415c (0x%02x)", address); +#endif client->id = tea6415c_id++; client->flags = 0; client->addr = address; @@ -85,7 +90,11 @@ static int tea6415c_detect(struct i2c_adapter *adapter, int address, unsigned sh return err; } - printk("tea6415c.o: detected @ 0x%02x on adapter %s\n",2*address,&client->adapter->name[0]); +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) + printk("tea6415c.o: detected @ 0x%02x on adapter %s\n",address,&client->adapter->name[0]); +#else + printk("tea6415c.o: detected @ 0x%02x on adapter %s\n",address,&client->adapter->dev.name[0]); +#endif return 0; } diff --git a/linux/drivers/media/video/tea6420.c b/linux/drivers/media/video/tea6420.c index 63aa2caa9..aa0ef021e 100644 --- a/linux/drivers/media/video/tea6420.c +++ b/linux/drivers/media/video/tea6420.c @@ -110,15 +110,19 @@ static int tea6420_detect(struct i2c_adapter *adapter, int address, unsigned sho if (0 == client) { return -ENOMEM; } + memset(client, 0, sizeof(struct i2c_client)); /* fill client structure */ +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) sprintf(client->name,"tea6420 (0x%02x)", address); +#else + sprintf(client->dev.name,"tea6420 (0x%02x)", address); +#endif client->id = tea6420_id++; client->flags = 0; client->addr = address; client->adapter = adapter; client->driver = &driver; - client->data = NULL; /* tell the i2c layer a new client has arrived */ if (0 != (err = i2c_attach_client(client))) { @@ -135,8 +139,11 @@ static int tea6420_detect(struct i2c_adapter *adapter, int address, unsigned sho printk("tea6420.o: could not initialize chipset. continuing anyway.\n"); } - printk("tea6420.o: detected @ 0x%02x on adapter %s\n",2*address,&client->adapter->name[0]); - +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) + printk("tea6420.o: detected @ 0x%02x on adapter %s\n",address,&client->adapter->name[0]); +#else + printk("tea6420.o: detected @ 0x%02x on adapter %s\n",address,&client->adapter->dev.name[0]); +#endif return 0; } |