Commit a3064855 authored by Andy Walls's avatar Andy Walls Committed by Mauro Carvalho Chehab

[media] lirc_zilog: Convert the instance open count to an atomic_t

The open count is simply used for deciding if the Rx polling thread
needs to poll the IR chip for userspace.  Simplify the manipulation
of the open count by using an atomic_t and not requiring a lock
The polling thread errantly didn't try to take the lock anyway.
Signed-off-by: default avatarAndy Walls <awalls@md.metrocast.net>
Signed-off-by: default avatarJarod Wilson <jarod@redhat.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 5c07134f
...@@ -94,7 +94,7 @@ struct IR { ...@@ -94,7 +94,7 @@ struct IR {
struct lirc_driver l; struct lirc_driver l;
struct mutex ir_lock; struct mutex ir_lock;
int open; atomic_t open_count;
struct i2c_adapter *adapter; struct i2c_adapter *adapter;
struct IR_rx *rx; struct IR_rx *rx;
...@@ -279,7 +279,7 @@ static int lirc_thread(void *arg) ...@@ -279,7 +279,7 @@ static int lirc_thread(void *arg)
set_current_state(TASK_INTERRUPTIBLE); set_current_state(TASK_INTERRUPTIBLE);
/* if device not opened, we can sleep half a second */ /* if device not opened, we can sleep half a second */
if (!ir->open) { if (atomic_read(&ir->open_count) == 0) {
schedule_timeout(HZ/2); schedule_timeout(HZ/2);
continue; continue;
} }
...@@ -1094,10 +1094,7 @@ static int open(struct inode *node, struct file *filep) ...@@ -1094,10 +1094,7 @@ static int open(struct inode *node, struct file *filep)
if (ir == NULL) if (ir == NULL)
return -ENODEV; return -ENODEV;
/* increment in use count */ atomic_inc(&ir->open_count);
mutex_lock(&ir->ir_lock);
++ir->open;
mutex_unlock(&ir->ir_lock);
/* stash our IR struct */ /* stash our IR struct */
filep->private_data = ir; filep->private_data = ir;
...@@ -1115,10 +1112,7 @@ static int close(struct inode *node, struct file *filep) ...@@ -1115,10 +1112,7 @@ static int close(struct inode *node, struct file *filep)
return -ENODEV; return -ENODEV;
} }
/* decrement in use count */ atomic_dec(&ir->open_count);
mutex_lock(&ir->ir_lock);
--ir->open;
mutex_unlock(&ir->ir_lock);
return 0; return 0;
} }
...@@ -1294,6 +1288,7 @@ static int ir_probe(struct i2c_client *client, const struct i2c_device_id *id) ...@@ -1294,6 +1288,7 @@ static int ir_probe(struct i2c_client *client, const struct i2c_device_id *id)
ir->adapter = adap; ir->adapter = adap;
mutex_init(&ir->ir_lock); mutex_init(&ir->ir_lock);
atomic_set(&ir->open_count, 0);
/* set lirc_dev stuff */ /* set lirc_dev stuff */
memcpy(&ir->l, &lirc_template, sizeof(struct lirc_driver)); memcpy(&ir->l, &lirc_template, sizeof(struct lirc_driver));
......
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