Author: marius
Date: Mon Dec 14 21:11:50 2009
New Revision: 200544
URL: http://svn.freebsd.org/changeset/base/200544

Log:
  Set ATA_CHECKS_CABLE when appropriate.
  
  Reviewed by:  mav
  MFC after:    1 week

Modified:
  head/sys/dev/ata/chipsets/ata-amd.c

Modified: head/sys/dev/ata/chipsets/ata-amd.c
==============================================================================
--- head/sys/dev/ata/chipsets/ata-amd.c Mon Dec 14 20:59:18 2009        
(r200543)
+++ head/sys/dev/ata/chipsets/ata-amd.c Mon Dec 14 21:11:50 2009        
(r200544)
@@ -52,6 +52,7 @@ __FBSDID("$FreeBSD$");
 #include <ata_if.h>
 
 /* local prototypes */
+static int ata_amd_ch_attach(device_t dev);
 static int ata_amd_chipinit(device_t dev);
 static int ata_amd_setmode(device_t dev, int target, int mode);
 
@@ -59,7 +60,6 @@ static int ata_amd_setmode(device_t dev,
 #define AMD_BUG                0x01
 #define AMD_CABLE      0x02
 
-
 /*
  * American Micro Devices (AMD) chipset support functions
  */
@@ -100,6 +100,7 @@ ata_amd_chipinit(device_t dev)
     else
        pci_write_config(dev, 0x41, pci_read_config(dev, 0x41, 1) | 0xf0, 1);
 
+    ctlr->ch_attach = ata_amd_ch_attach;
     ctlr->setmode = ata_amd_setmode;
     return 0;
 }
@@ -137,4 +138,19 @@ ata_amd_setmode(device_t dev, int target
        return (mode);
 }
 
+static int
+ata_amd_ch_attach(device_t dev)
+{
+       struct ata_pci_controller *ctlr;
+       struct ata_channel *ch;
+       int error;
+
+       ctlr = device_get_softc(device_get_parent(dev));
+       ch = device_get_softc(dev);
+       error = ata_pci_ch_attach(dev);
+       if (ctlr->chip->cfg1 & AMD_CABLE)
+               ch->flags |= ATA_CHECKS_CABLE;
+       return (error);
+}
+
 ATA_DECLARE_DRIVER(ata_amd);
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to