diff options
author | Peter Hurley <peter@hurleysoftware.com> | 2011-08-05 10:51:26 -0400 |
---|---|---|
committer | Jaikumar Ganesh <jaikumar@google.com> | 2011-08-11 18:23:59 -0700 |
commit | 3f8c499e5d6963525407553c11a241b00809f428 (patch) | |
tree | c3ff0fd232aefa9eaa4f56cd0c278f6952cd5ccd /net | |
parent | 8624f2bb85de9ec7051b341d956ac1669eaebad1 (diff) | |
download | kernel_samsung_espresso10-3f8c499e5d6963525407553c11a241b00809f428.zip kernel_samsung_espresso10-3f8c499e5d6963525407553c11a241b00809f428.tar.gz kernel_samsung_espresso10-3f8c499e5d6963525407553c11a241b00809f428.tar.bz2 |
Bluetooth: hidp: Fix session cleanup on failed conn add
Once the session thread is running, cleanup must be
handled by the session thread only.
Signed-off-by: Peter Hurley <peter@hurleysoftware.com>
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
Diffstat (limited to 'net')
-rw-r--r-- | net/bluetooth/hidp/core.c | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/net/bluetooth/hidp/core.c b/net/bluetooth/hidp/core.c index 43b4c2d..7e19a01 100644 --- a/net/bluetooth/hidp/core.c +++ b/net/bluetooth/hidp/core.c @@ -1044,8 +1044,12 @@ int hidp_add_connection(struct hidp_connadd_req *req, struct socket *ctrl_sock, } err = hid_add_device(session->hid); - if (err < 0) - goto err_add_device; + if (err < 0) { + atomic_inc(&session->terminate); + wake_up_process(session->task); + up_write(&hidp_session_sem); + return err; + } if (session->input) { hidp_send_ctrl_message(session, @@ -1059,12 +1063,6 @@ int hidp_add_connection(struct hidp_connadd_req *req, struct socket *ctrl_sock, up_write(&hidp_session_sem); return 0; -err_add_device: - hid_destroy_device(session->hid); - session->hid = NULL; - atomic_inc(&session->terminate); - wake_up_process(session->task); - unlink: hidp_del_timer(session); |