Commit 8c21677a authored by Gerd Knorr's avatar Gerd Knorr Committed by Linus Torvalds

[PATCH] media/saa7110: remove sleep_on*() usage

Directly use wait-queues instead of the deprecated sleep_on_timeout().  Since
the sleep in this function is unconditional, wait_event_timeout() does not
appear to be appropriate.  Patch is compile-tested.
Signed-off-by: default avatarNishanth Aravamudan <nacc@us.ibm.com>
Signed-off-by: default avatarDomen Puncer <domen@coderock.org>
Signed-off-by: default avatarGerd Knorr <kraxel@bytesex.org>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 8ac64752
...@@ -30,6 +30,7 @@ ...@@ -30,6 +30,7 @@
#include <linux/types.h> #include <linux/types.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/wait.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
...@@ -205,13 +206,16 @@ static const unsigned char initseq[] = { ...@@ -205,13 +206,16 @@ static const unsigned char initseq[] = {
static int static int
determine_norm (struct i2c_client *client) determine_norm (struct i2c_client *client)
{ {
DEFINE_WAIT(wait);
struct saa7110 *decoder = i2c_get_clientdata(client); struct saa7110 *decoder = i2c_get_clientdata(client);
int status; int status;
/* mode changed, start automatic detection */ /* mode changed, start automatic detection */
saa7110_write_block(client, initseq, sizeof(initseq)); saa7110_write_block(client, initseq, sizeof(initseq));
saa7110_selmux(client, decoder->input); saa7110_selmux(client, decoder->input);
sleep_on_timeout(&decoder->wq, HZ / 4); prepare_to_wait(&decoder->wq, &wait, TASK_UNINTERRUPTIBLE);
schedule_timeout(HZ/4);
finish_wait(&decoder->wq, &wait);
status = saa7110_read(client); status = saa7110_read(client);
if (status & 0x40) { if (status & 0x40) {
dprintk(1, KERN_INFO "%s: status=0x%02x (no signal)\n", dprintk(1, KERN_INFO "%s: status=0x%02x (no signal)\n",
...@@ -250,7 +254,9 @@ determine_norm (struct i2c_client *client) ...@@ -250,7 +254,9 @@ determine_norm (struct i2c_client *client)
saa7110_write(client, 0x11, 0x59); saa7110_write(client, 0x11, 0x59);
//saa7110_write(client,0x2E,0x9A); //saa7110_write(client,0x2E,0x9A);
sleep_on_timeout(&decoder->wq, HZ / 4); prepare_to_wait(&decoder->wq, &wait, TASK_UNINTERRUPTIBLE);
schedule_timeout(HZ/4);
finish_wait(&decoder->wq, &wait);
status = saa7110_read(client); status = saa7110_read(client);
if ((status & 0x03) == 0x01) { if ((status & 0x03) == 0x01) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment