Commit 05d6d677 authored by Roel Kluin's avatar Roel Kluin Committed by Greg Kroah-Hartman

Staging: usbip: usbip_start_threads(): handle kernel_thread failure

kernel_thread may fail, notice this.
Signed-off-by: default avatarRoel Kluin <roel.kluin@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent e48d94da
...@@ -406,8 +406,20 @@ void usbip_start_threads(struct usbip_device *ud) ...@@ -406,8 +406,20 @@ void usbip_start_threads(struct usbip_device *ud)
/* /*
* threads are invoked per one device (per one connection). * threads are invoked per one device (per one connection).
*/ */
kernel_thread(usbip_thread, (void *)&ud->tcp_rx, 0); int retval;
kernel_thread(usbip_thread, (void *)&ud->tcp_tx, 0);
retval = kernel_thread(usbip_thread, (void *)&ud->tcp_rx, 0);
if (retval < 0) {
printk(KERN_ERR "Creating tcp_rx thread for ud %p failed.\n",
ud);
return;
}
retval = kernel_thread(usbip_thread, (void *)&ud->tcp_tx, 0);
if (retval < 0) {
printk(KERN_ERR "Creating tcp_tx thread for ud %p failed.\n",
ud);
return;
}
/* confirm threads are starting */ /* confirm threads are starting */
wait_for_completion(&ud->tcp_rx.thread_done); wait_for_completion(&ud->tcp_rx.thread_done);
......
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