svn commit: r188763 - head/sys/dev/ata
    Alexander Motin 
    mav at FreeBSD.org
       
    Wed Feb 18 13:12:49 PST 2009
    
    
  
Author: mav
Date: Wed Feb 18 21:12:48 2009
New Revision: 188763
URL: http://svn.freebsd.org/changeset/base/188763
Log:
  Make ch->dma.free() called symmetrically to ch->dma.alloc().
Modified:
  head/sys/dev/ata/ata-all.c
  head/sys/dev/ata/ata-pci.c
Modified: head/sys/dev/ata/ata-all.c
==============================================================================
--- head/sys/dev/ata/ata-all.c	Wed Feb 18 20:42:42 2009	(r188762)
+++ head/sys/dev/ata/ata-all.c	Wed Feb 18 21:12:48 2009	(r188763)
@@ -186,6 +186,11 @@ ata_detach(device_t dev)
     bus_teardown_intr(dev, ch->r_irq, ch->ih);
     bus_release_resource(dev, SYS_RES_IRQ, ATA_IRQ_RID, ch->r_irq);
     ch->r_irq = NULL;
+
+    /* free DMA resources if DMA HW present*/
+    if (ch->dma.free)
+	ch->dma.free(dev);
+
     mtx_destroy(&ch->state_mtx);
     mtx_destroy(&ch->queue_mtx);
     return 0;
Modified: head/sys/dev/ata/ata-pci.c
==============================================================================
--- head/sys/dev/ata/ata-pci.c	Wed Feb 18 20:42:42 2009	(r188762)
+++ head/sys/dev/ata/ata-pci.c	Wed Feb 18 21:12:48 2009	(r188763)
@@ -544,14 +544,11 @@ ata_pcichannel_attach(device_t dev)
 static int
 ata_pcichannel_detach(device_t dev)
 {
-    struct ata_channel *ch = device_get_softc(dev);
     int error;
 
     if ((error = ata_detach(dev)))
 	return error;
 
-    ch->dma.free(dev);
-
     /* XXX SOS free resources for io and ctlio ?? */
 
     return 0;
    
    
More information about the svn-src-all
mailing list