summaryrefslogtreecommitdiff
path: root/linux/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'linux/drivers')
-rw-r--r--linux/drivers/media/video/bttv-i2c.c6
-rw-r--r--linux/drivers/media/video/cx88/cx88-cards.c4
-rw-r--r--linux/drivers/media/video/cx88/cx88-core.c6
-rw-r--r--linux/drivers/media/video/msp3400-driver.c18
-rw-r--r--linux/drivers/media/video/msp3400.c18
-rw-r--r--linux/drivers/media/video/saa7134/saa7134-tvaudio.c21
-rw-r--r--linux/drivers/media/video/tda9887.c9
7 files changed, 44 insertions, 38 deletions
diff --git a/linux/drivers/media/video/bttv-i2c.c b/linux/drivers/media/video/bttv-i2c.c
index 6d11393cd..131231718 100644
--- a/linux/drivers/media/video/bttv-i2c.c
+++ b/linux/drivers/media/video/bttv-i2c.c
@@ -1,5 +1,5 @@
/*
- $Id: bttv-i2c.c,v 1.7 2004/09/16 08:43:57 kraxel Exp $
+ $Id: bttv-i2c.c,v 1.8 2004/09/22 11:47:11 kraxel Exp $
bttv-i2c.c -- all the i2c code is here
@@ -141,10 +141,8 @@ bttv_i2c_wait_done(struct bttv *btv)
int rc = 0;
add_wait_queue(&btv->i2c_queue, &wait);
- set_current_state(TASK_INTERRUPTIBLE);
if (0 == btv->i2c_done)
- schedule_timeout(HZ/50+1);
- set_current_state(TASK_RUNNING);
+ msleep_interruptible(20);
remove_wait_queue(&btv->i2c_queue, &wait);
if (0 == btv->i2c_done)
diff --git a/linux/drivers/media/video/cx88/cx88-cards.c b/linux/drivers/media/video/cx88/cx88-cards.c
index a1f61eb8f..ac5c20451 100644
--- a/linux/drivers/media/video/cx88/cx88-cards.c
+++ b/linux/drivers/media/video/cx88/cx88-cards.c
@@ -1,5 +1,5 @@
/*
- * $Id: cx88-cards.c,v 1.39 2004/09/20 11:53:23 kraxel Exp $
+ * $Id: cx88-cards.c,v 1.40 2004/09/22 11:47:11 kraxel Exp $
*
* device driver for Conexant 2388x based TV cards
* card-specific stuff.
@@ -155,6 +155,7 @@ struct cx88_board cx88_boards[] = {
.input = {{
.type = CX88_VMUX_TELEVISION,
.vmux = 0,
+ .gpio1 = 0x3004,
},{
.type = CX88_VMUX_COMPOSITE2,
.vmux = 2,
@@ -220,6 +221,7 @@ struct cx88_board cx88_boards[] = {
.radio = {
.type = CX88_RADIO,
},
+ .blackbird = 1,
},
[CX88_BOARD_IODATA_GVVCP3PCI] = {
.name = "IODATA GV-VCP3/PCI",
diff --git a/linux/drivers/media/video/cx88/cx88-core.c b/linux/drivers/media/video/cx88/cx88-core.c
index 5edc9e9c2..d9458efdb 100644
--- a/linux/drivers/media/video/cx88/cx88-core.c
+++ b/linux/drivers/media/video/cx88/cx88-core.c
@@ -1,5 +1,5 @@
/*
- * $Id: cx88-core.c,v 1.10 2004/09/16 07:05:48 kraxel Exp $
+ * $Id: cx88-core.c,v 1.11 2004/09/22 11:47:11 kraxel Exp $
*
* device driver for Conexant 2388x based TV cards
* driver core
@@ -832,7 +832,7 @@ static int set_pll(struct cx88_core *core, int prescale, u32 ofreq)
dprintk(1,"set_pll: MO_PLL_REG 0x%08x [old=0x%08x,freq=%d]\n",
reg, cx_read(MO_PLL_REG), ofreq);
cx_write(MO_PLL_REG, reg);
- for (i = 0; i < 10; i++) {
+ for (i = 0; i < 100; i++) {
reg = cx_read(MO_DEVICE_STATUS);
if (reg & (1<<2)) {
dprintk(1,"pll locked [pre=%d,ofreq=%d]\n",
@@ -840,7 +840,7 @@ static int set_pll(struct cx88_core *core, int prescale, u32 ofreq)
return 0;
}
dprintk(1,"pll not locked yet, waiting ...\n");
- msleep(100);
+ msleep(10);
}
dprintk(1,"pll NOT locked [pre=%d,ofreq=%d]\n",prescale,ofreq);
return -1;
diff --git a/linux/drivers/media/video/msp3400-driver.c b/linux/drivers/media/video/msp3400-driver.c
index 44287f2bf..74e57e172 100644
--- a/linux/drivers/media/video/msp3400-driver.c
+++ b/linux/drivers/media/video/msp3400-driver.c
@@ -745,11 +745,11 @@ static int msp34xx_sleep(struct msp3400c *msp, int timeout)
add_wait_queue(&msp->wq, &wait);
if (!msp->rmmod) {
- set_current_state(TASK_INTERRUPTIBLE);
- if (timeout < 0)
+ if (timeout < 0) {
+ set_current_state(TASK_INTERRUPTIBLE);
schedule();
- else
- schedule_timeout(timeout);
+ } else
+ msleep_interruptible(timeout);
}
remove_wait_queue(&msp->wq, &wait);
return msp->rmmod || signal_pending(current);
@@ -818,7 +818,7 @@ static int msp3400c_thread(void *data)
}
/* some time for the tuner to sync */
- if (msp34xx_sleep(msp,HZ/5))
+ if (msp34xx_sleep(msp,200))
goto done;
restart:
@@ -851,7 +851,7 @@ static int msp3400c_thread(void *data)
for (this = 0; this < count; this++) {
msp3400c_setcarrier(client, cd[this].cdo,cd[this].cdo);
- if (msp34xx_sleep(msp,HZ/10))
+ if (msp34xx_sleep(msp,100))
goto done;
if (msp->restart)
msp->restart = 0;
@@ -886,7 +886,7 @@ static int msp3400c_thread(void *data)
for (this = 0; this < count; this++) {
msp3400c_setcarrier(client, cd[this].cdo,cd[this].cdo);
- if (msp34xx_sleep(msp,HZ/10))
+ if (msp34xx_sleep(msp,100))
goto done;
if (msp->restart)
goto restart;
@@ -1055,7 +1055,7 @@ static int msp3410d_thread(void *data)
}
/* some time for the tuner to sync */
- if (msp34xx_sleep(msp,HZ/5))
+ if (msp34xx_sleep(msp,200))
goto done;
restart:
@@ -1114,7 +1114,7 @@ static int msp3410d_thread(void *data)
} else {
/* triggered autodetect */
for (;;) {
- if (msp34xx_sleep(msp,HZ/10))
+ if (msp34xx_sleep(msp,100))
goto done;
if (msp->restart)
goto restart;
diff --git a/linux/drivers/media/video/msp3400.c b/linux/drivers/media/video/msp3400.c
index 44287f2bf..74e57e172 100644
--- a/linux/drivers/media/video/msp3400.c
+++ b/linux/drivers/media/video/msp3400.c
@@ -745,11 +745,11 @@ static int msp34xx_sleep(struct msp3400c *msp, int timeout)
add_wait_queue(&msp->wq, &wait);
if (!msp->rmmod) {
- set_current_state(TASK_INTERRUPTIBLE);
- if (timeout < 0)
+ if (timeout < 0) {
+ set_current_state(TASK_INTERRUPTIBLE);
schedule();
- else
- schedule_timeout(timeout);
+ } else
+ msleep_interruptible(timeout);
}
remove_wait_queue(&msp->wq, &wait);
return msp->rmmod || signal_pending(current);
@@ -818,7 +818,7 @@ static int msp3400c_thread(void *data)
}
/* some time for the tuner to sync */
- if (msp34xx_sleep(msp,HZ/5))
+ if (msp34xx_sleep(msp,200))
goto done;
restart:
@@ -851,7 +851,7 @@ static int msp3400c_thread(void *data)
for (this = 0; this < count; this++) {
msp3400c_setcarrier(client, cd[this].cdo,cd[this].cdo);
- if (msp34xx_sleep(msp,HZ/10))
+ if (msp34xx_sleep(msp,100))
goto done;
if (msp->restart)
msp->restart = 0;
@@ -886,7 +886,7 @@ static int msp3400c_thread(void *data)
for (this = 0; this < count; this++) {
msp3400c_setcarrier(client, cd[this].cdo,cd[this].cdo);
- if (msp34xx_sleep(msp,HZ/10))
+ if (msp34xx_sleep(msp,100))
goto done;
if (msp->restart)
goto restart;
@@ -1055,7 +1055,7 @@ static int msp3410d_thread(void *data)
}
/* some time for the tuner to sync */
- if (msp34xx_sleep(msp,HZ/5))
+ if (msp34xx_sleep(msp,200))
goto done;
restart:
@@ -1114,7 +1114,7 @@ static int msp3410d_thread(void *data)
} else {
/* triggered autodetect */
for (;;) {
- if (msp34xx_sleep(msp,HZ/10))
+ if (msp34xx_sleep(msp,100))
goto done;
if (msp->restart)
goto restart;
diff --git a/linux/drivers/media/video/saa7134/saa7134-tvaudio.c b/linux/drivers/media/video/saa7134/saa7134-tvaudio.c
index 786c17d71..2e8b3d0b0 100644
--- a/linux/drivers/media/video/saa7134/saa7134-tvaudio.c
+++ b/linux/drivers/media/video/saa7134/saa7134-tvaudio.c
@@ -1,5 +1,5 @@
/*
- * $Id: saa7134-tvaudio.c,v 1.12 2004/09/20 13:53:37 kraxel Exp $
+ * $Id: saa7134-tvaudio.c,v 1.13 2004/09/22 11:47:11 kraxel Exp $
*
* device driver for philips saa7134 based TV cards
* tv audio decoder (fm stereo, nicam, ...)
@@ -58,9 +58,10 @@ MODULE_PARM_DESC(audio_clock_tweak, "Audio clock tick fine tuning for cards with
#define print_regb(reg) printk("%s: reg 0x%03x [%-16s]: 0x%02x\n", \
dev->name,(SAA7134_##reg),(#reg),saa_readb((SAA7134_##reg)))
-#define SCAN_INITIAL_DELAY (HZ)
-#define SCAN_SAMPLE_DELAY (HZ/5)
-#define SCAN_SUBCARRIER_DELAY (HZ*2)
+/* msecs */
+#define SCAN_INITIAL_DELAY 1000
+#define SCAN_SAMPLE_DELAY 200
+#define SCAN_SUBCARRIER_DELAY 2000
/* ------------------------------------------------------------------ */
/* saa7134 code */
@@ -326,11 +327,11 @@ static int tvaudio_sleep(struct saa7134_dev *dev, int timeout)
add_wait_queue(&dev->thread.wq, &wait);
if (dev->thread.scan1 == dev->thread.scan2 && !dev->thread.shutdown) {
- set_current_state(TASK_INTERRUPTIBLE);
- if (timeout < 0)
+ if (timeout < 0) {
+ set_current_state(TASK_INTERRUPTIBLE);
schedule();
- else
- schedule_timeout(timeout);
+ } else
+ msleep_interruptible(timeout);
}
remove_wait_queue(&dev->thread.wq, &wait);
return dev->thread.scan1 != dev->thread.scan2;
@@ -612,7 +613,7 @@ static int tvaudio_thread(void *data)
lastmode = 42;
for (;;) {
- if (tvaudio_sleep(dev,5*HZ))
+ if (tvaudio_sleep(dev,5000))
goto restart;
if (dev->thread.shutdown || signal_pending(current))
break;
@@ -840,7 +841,7 @@ static int tvaudio_thread_ddep(void *data)
saa_dsp_writel(dev, 0x464 >> 2, 0x000000);
saa_dsp_writel(dev, 0x470 >> 2, 0x101010);
- if (tvaudio_sleep(dev,3*HZ))
+ if (tvaudio_sleep(dev,3000))
goto restart;
value = saa_readl(0x528 >> 2) & 0xffffff;
diff --git a/linux/drivers/media/video/tda9887.c b/linux/drivers/media/video/tda9887.c
index 9cf8a8b69..779a98a4a 100644
--- a/linux/drivers/media/video/tda9887.c
+++ b/linux/drivers/media/video/tda9887.c
@@ -6,6 +6,7 @@
#include <linux/init.h>
#include <linux/errno.h>
#include <linux/slab.h>
+#include <linux/delay.h>
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)
#include "audiochip.h"
@@ -541,6 +542,11 @@ static int tda9887_configure(struct tda9887 *t)
tda9887_set_config(t,buf);
tda9887_set_insmod(t,buf);
+ if (t->std & V4L2_STD_SECAM_L) {
+ /* secam fixup (FIXME: move this to tvnorms array?) */
+ buf[1] &= ~cOutputPort2Inactive;
+ }
+
dprintk(PREFIX "writing: b=0x%02x c=0x%02x e=0x%02x\n",
buf[1],buf[2],buf[3]);
if (debug > 1)
@@ -550,8 +556,7 @@ static int tda9887_configure(struct tda9887 *t)
printk(PREFIX "i2c i/o error: rc == %d (should be 4)\n",rc);
if (debug > 2) {
- set_current_state(TASK_INTERRUPTIBLE);
- schedule_timeout(HZ);
+ msleep(1000);
tda9887_status(t);
}
return 0;