Commit e1869588 authored by Marcel Holtmann's avatar Marcel Holtmann

[Bluetooth] Use wait_event_timeout()

Use wait_event_timeout() instead of custom wait queue code. The
current code uses TASK_INTERRUPTIBLE but only cares about timing
out and the wait queue event taking place (does not actively do
anything in response to signals), so wait_event_timeout() should
be enough.
Signed-off-by: default avatarNishanth Aravamudan <nacc@us.ibm.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 0ee0d77d
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
#include <linux/ioctl.h> #include <linux/ioctl.h>
#include <linux/file.h> #include <linux/file.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/wait.h>
#include <net/sock.h> #include <net/sock.h>
#include <linux/input.h> #include <linux/input.h>
...@@ -459,7 +460,6 @@ static int hidp_session(void *arg) ...@@ -459,7 +460,6 @@ static int hidp_session(void *arg)
struct sk_buff *skb; struct sk_buff *skb;
int vendor = 0x0000, product = 0x0000; int vendor = 0x0000, product = 0x0000;
wait_queue_t ctrl_wait, intr_wait; wait_queue_t ctrl_wait, intr_wait;
unsigned long timeo = HZ;
BT_DBG("session %p", session); BT_DBG("session %p", session);
...@@ -504,28 +504,12 @@ static int hidp_session(void *arg) ...@@ -504,28 +504,12 @@ static int hidp_session(void *arg)
hidp_del_timer(session); hidp_del_timer(session);
if (intr_sk->sk_state != BT_CONNECTED) { if (intr_sk->sk_state != BT_CONNECTED)
init_waitqueue_entry(&ctrl_wait, current); wait_event_timeout(*(ctrl_sk->sk_sleep), (ctrl_sk->sk_state == BT_CLOSED), HZ);
add_wait_queue(ctrl_sk->sk_sleep, &ctrl_wait);
while (timeo && ctrl_sk->sk_state != BT_CLOSED) {
set_current_state(TASK_INTERRUPTIBLE);
timeo = schedule_timeout(timeo);
}
set_current_state(TASK_RUNNING);
remove_wait_queue(ctrl_sk->sk_sleep, &ctrl_wait);
timeo = HZ;
}
fput(session->ctrl_sock->file); fput(session->ctrl_sock->file);
init_waitqueue_entry(&intr_wait, current); wait_event_timeout(*(intr_sk->sk_sleep), (intr_sk->sk_state == BT_CLOSED), HZ);
add_wait_queue(intr_sk->sk_sleep, &intr_wait);
while (timeo && intr_sk->sk_state != BT_CLOSED) {
set_current_state(TASK_INTERRUPTIBLE);
timeo = schedule_timeout(timeo);
}
set_current_state(TASK_RUNNING);
remove_wait_queue(intr_sk->sk_sleep, &intr_wait);
fput(session->intr_sock->file); fput(session->intr_sock->file);
......
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