Author: hselasky
Date: Fri Nov  4 09:19:18 2011
New Revision: 227075
URL: http://svn.freebsd.org/changeset/base/227075

Log:
  Fix for panic at USB controller attach failure during cold boot.
  
  Reported by:  Jan Henrik Sylvester, Xin LI and more.
  MFC after:    3 days

Modified:
  head/sys/dev/usb/usb_process.c

Modified: head/sys/dev/usb/usb_process.c
==============================================================================
--- head/sys/dev/usb/usb_process.c      Fri Nov  4 06:56:59 2011        
(r227074)
+++ head/sys/dev/usb/usb_process.c      Fri Nov  4 09:19:18 2011        
(r227075)
@@ -67,11 +67,13 @@ static int usb_pcount;
 #define        USB_THREAD_CREATE(f, s, p, ...) \
                kproc_kthread_add((f), (s), &usbproc, (p), RFHIGHPID, \
                    0, "usb", __VA_ARGS__)
+#define        USB_THREAD_SUSPEND_CHECK() kthread_suspend_check()
 #define        USB_THREAD_SUSPEND(p)   kthread_suspend(p,0)
 #define        USB_THREAD_EXIT(err)    kthread_exit()
 #else
 #define        USB_THREAD_CREATE(f, s, p, ...) \
                kthread_create((f), (s), (p), RFHIGHPID, 0, __VA_ARGS__)
+#define        USB_THREAD_SUSPEND_CHECK() kthread_suspend_check()
 #define        USB_THREAD_SUSPEND(p)   kthread_suspend(p,0)
 #define        USB_THREAD_EXIT(err)    kthread_exit(err)
 #endif
@@ -98,6 +100,9 @@ usb_process(void *arg)
        struct usb_proc_msg *pm;
        struct thread *td;
 
+       /* in case of attach error, check for suspended */
+       USB_THREAD_SUSPEND_CHECK();
+
        /* adjust priority */
        td = curthread;
        thread_lock(td);
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to