Branching CVS for 1.10 on wednesday

Matthew Dillon dillon at apollo.backplane.com
Tue Jul 17 15:54:13 PDT 2007


:okay, then this is specific to hda:
:
:http://leaf.dragonflybsd.org/mailarchive/commits/2007-06/msg00231.html
:
:in any case, this panics the box on driver unload.
:
:cheers
:  simon

    I think I recall saying that the design of the sound driver subsystem
    is a huge mess.

    This is the sound subsystem assuming that it a driver unload is
    serialized against the dispatch of a pending sound interrupt when it
    isn't because the interrupt may ALREADY be dispatched but stuck INSIDE
    the sound driver on a lock.  It doesn't matter what kind of lock it is.

    For that matter, any attempt to unload the driver while simultaniously
    doing some other sound operation would result in the same problem.

    If you want a hack to fix HDA then just add an unconditional tsleep
    for a few ticks in hdac_release_resources().  Try this patch.

    After the release we can come up with a more involved fix by
    forcing the interrupt teardown code to wait for any pending interrupts
    to clear before returning.

					-Matt
					Matthew Dillon 
					<dillon at backplane.com>

Index: pci/hda/hdac.c
===================================================================
RCS file: /cvs/src/sys/dev/sound/pci/hda/hdac.c,v
retrieving revision 1.7
diff -u -p -r1.7 hdac.c
--- pci/hda/hdac.c	26 Jun 2007 14:56:50 -0000	1.7
+++ pci/hda/hdac.c	17 Jul 2007 22:50:05 -0000
@@ -5649,6 +5649,10 @@ 	hdac_unlock(sc);
 
 	hdac_irq_free(sc);
 
+	/* give pending interrupts stuck on the lock a chance to clear */
+	/* bad hack */
+	tsleep(&sc->irq, 0, "hdaslp", hz / 10);
+
 	device_get_children(sc->dev, &devlist, &devcount);
 	for (i = 0; devlist != NULL && i < devcount; i++) {
 		devinfo = (struct hdac_devinfo *)device_get_ivars(devlist[i]);





More information about the Kernel mailing list