]> Pileus Git - ~andy/linux/commitdiff
i2c: piix4: Add support for secondary SMBus on AMD SB800 and AMD FCH chipsets
authorRudolf Marek <r.marek@assembler.cz>
Sun, 14 Jul 2013 21:17:26 +0000 (23:17 +0200)
committerWolfram Sang <wsa@the-dreams.de>
Thu, 15 Aug 2013 13:17:31 +0000 (15:17 +0200)
Add support for the secondary SMBus controller on the AMD SB800 and AMD FCH
chipsets.

Signed-off-by: Rudolf Marek <r.marek@assembler.cz>
Tested-by: Paul Menzel <paulepanter@users.sourceforge.net>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
Documentation/i2c/busses/i2c-piix4
drivers/i2c/busses/i2c-piix4.c

index a370b2047cf3025b5a0c318af15c670a76bc41e3..c097e0f020fe1d786bed67fd3ed9e06fd99f7b63 100644 (file)
@@ -73,9 +73,10 @@ this driver on those mainboards.
 The ServerWorks Southbridges, the Intel 440MX, and the Victory66 are
 identical to the PIIX4 in I2C/SMBus support.
 
-The AMD SB700 and SP5100 chipsets implement two PIIX4-compatible SMBus
-controllers. If your BIOS initializes the secondary controller, it will
-be detected by this driver as an "Auxiliary SMBus Host Controller".
+The AMD SB700, SB800, SP5100 and Hudson-2 chipsets implement two
+PIIX4-compatible SMBus controllers. If your BIOS initializes the
+secondary controller, it will be detected by this driver as
+an "Auxiliary SMBus Host Controller".
 
 If you own Force CPCI735 motherboard or other OSB4 based systems you may need
 to change the SMBus Interrupt Select register so the SMBus controller uses
index d05ad590af29b5163e0920a8d7868a31d8ec0529..a028617b8f13c37a4a8371264a149ba7f6d44540 100644 (file)
@@ -231,11 +231,11 @@ static int piix4_setup(struct pci_dev *PIIX4_dev,
 }
 
 static int piix4_setup_sb800(struct pci_dev *PIIX4_dev,
-                            const struct pci_device_id *id)
+                            const struct pci_device_id *id, u8 aux)
 {
        unsigned short piix4_smba;
        unsigned short smba_idx = 0xcd6;
-       u8 smba_en_lo, smba_en_hi, i2ccfg, i2ccfg_offset = 0x10, smb_en = 0x2c;
+       u8 smba_en_lo, smba_en_hi, i2ccfg, i2ccfg_offset = 0x10, smb_en;
 
        /* SB800 and later SMBus does not support forcing address */
        if (force || force_addr) {
@@ -245,6 +245,8 @@ static int piix4_setup_sb800(struct pci_dev *PIIX4_dev,
        }
 
        /* Determine the address of the SMBus areas */
+       smb_en = (aux) ? 0x28 : 0x2c;
+
        if (!request_region(smba_idx, 2, "smba_idx")) {
                dev_err(&PIIX4_dev->dev, "SMBus base address index region "
                        "0x%x already in use!\n", smba_idx);
@@ -272,6 +274,13 @@ static int piix4_setup_sb800(struct pci_dev *PIIX4_dev,
                return -EBUSY;
        }
 
+       /* Aux SMBus does not support IRQ information */
+       if (aux) {
+               dev_info(&PIIX4_dev->dev,
+                        "SMBus Host Controller at 0x%x\n", piix4_smba);
+               return piix4_smba;
+       }
+
        /* Request the SMBus I2C bus config region */
        if (!request_region(piix4_smba + i2ccfg_offset, 1, "i2ccfg")) {
                dev_err(&PIIX4_dev->dev, "SMBus I2C bus config region "
@@ -597,7 +606,7 @@ static int piix4_probe(struct pci_dev *dev, const struct pci_device_id *id)
             dev->revision >= 0x40) ||
            dev->vendor == PCI_VENDOR_ID_AMD)
                /* base address location etc changed in SB800 */
-               retval = piix4_setup_sb800(dev, id);
+               retval = piix4_setup_sb800(dev, id, 0);
        else
                retval = piix4_setup(dev, id);
 
@@ -611,17 +620,29 @@ static int piix4_probe(struct pci_dev *dev, const struct pci_device_id *id)
                return retval;
 
        /* Check for auxiliary SMBus on some AMD chipsets */
+       retval = -ENODEV;
+
        if (dev->vendor == PCI_VENDOR_ID_ATI &&
-           dev->device == PCI_DEVICE_ID_ATI_SBX00_SMBUS &&
-           dev->revision < 0x40) {
-               retval = piix4_setup_aux(dev, id, 0x58);
-               if (retval > 0) {
-                       /* Try to add the aux adapter if it exists,
-                        * piix4_add_adapter will clean up if this fails */
-                       piix4_add_adapter(dev, retval, &piix4_aux_adapter);
+           dev->device == PCI_DEVICE_ID_ATI_SBX00_SMBUS) {
+               if (dev->revision < 0x40) {
+                       retval = piix4_setup_aux(dev, id, 0x58);
+               } else {
+                       /* SB800 added aux bus too */
+                       retval = piix4_setup_sb800(dev, id, 1);
                }
        }
 
+       if (dev->vendor == PCI_VENDOR_ID_AMD &&
+           dev->device == PCI_DEVICE_ID_AMD_HUDSON2_SMBUS) {
+               retval = piix4_setup_sb800(dev, id, 1);
+       }
+
+       if (retval > 0) {
+               /* Try to add the aux adapter if it exists,
+                * piix4_add_adapter will clean up if this fails */
+               piix4_add_adapter(dev, retval, &piix4_aux_adapter);
+       }
+
        return 0;
 }