2004-08-24 18:20:46 +02:00
|
|
|
#include <console/console.h>
|
|
|
|
#include <device/device.h>
|
|
|
|
#include <device/pci.h>
|
|
|
|
#include <device/pci_ids.h>
|
|
|
|
#include "i82801dbm.h"
|
|
|
|
|
|
|
|
void i82801dbm_enable(device_t dev)
|
|
|
|
{
|
2005-09-21 15:49:44 +02:00
|
|
|
unsigned int index = 0;
|
|
|
|
uint8_t bHasDisableBit = 0;
|
|
|
|
uint16_t cur_disable_mask, new_disable_mask;
|
|
|
|
|
|
|
|
// all 82801dbm devices are in bus 0
|
|
|
|
unsigned int devfn = PCI_DEVFN(0x1f, 0); // lpc
|
|
|
|
device_t lpc_dev = dev_find_slot(0, devfn); // 0
|
|
|
|
if (!lpc_dev)
|
2004-08-24 18:20:46 +02:00
|
|
|
return;
|
2005-09-21 15:49:44 +02:00
|
|
|
|
|
|
|
// Calculate disable bit position for specified device:function
|
|
|
|
// NOTE: For ICH-4, only the following devices can be disabled:
|
|
|
|
// D31: F0, F1, F3, F5, F6,
|
|
|
|
// D29: F0, F1, F2, F7
|
|
|
|
|
2009-02-28 21:10:20 +01:00
|
|
|
if (PCI_SLOT(dev->path.pci.devfn) == 31) {
|
|
|
|
index = PCI_FUNC(dev->path.pci.devfn);
|
2005-09-21 15:49:44 +02:00
|
|
|
|
|
|
|
switch (index) {
|
|
|
|
case 0:
|
|
|
|
case 1:
|
|
|
|
case 3:
|
|
|
|
case 5:
|
|
|
|
case 6:
|
|
|
|
bHasDisableBit = 1;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
};
|
|
|
|
|
|
|
|
if (index == 0)
|
|
|
|
index = 14; // D31:F0 bit is an exception
|
|
|
|
|
2009-02-28 21:10:20 +01:00
|
|
|
} else if (PCI_SLOT(dev->path.pci.devfn) == 29) {
|
|
|
|
index = 8 + PCI_FUNC(dev->path.pci.devfn);
|
2005-09-21 15:49:44 +02:00
|
|
|
|
2009-02-28 21:10:20 +01:00
|
|
|
if ((PCI_FUNC(dev->path.pci.devfn) < 3) || (PCI_FUNC(dev->path.pci.devfn) == 7))
|
2005-09-21 15:49:44 +02:00
|
|
|
bHasDisableBit = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bHasDisableBit) {
|
|
|
|
cur_disable_mask = pci_read_config16(lpc_dev, FUNC_DIS);
|
|
|
|
new_disable_mask = cur_disable_mask & ~(1<<index); // enable it
|
|
|
|
if (!dev->enabled) {
|
|
|
|
new_disable_mask |= (1<<index); // disable it
|
|
|
|
}
|
|
|
|
if (new_disable_mask != cur_disable_mask) {
|
|
|
|
pci_write_config16(lpc_dev, FUNC_DIS, new_disable_mask);
|
2004-08-24 18:20:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-12-14 15:54:00 +01:00
|
|
|
struct chip_operations southbridge_intel_i82801dbm_ops = {
|
2006-11-05 19:50:49 +01:00
|
|
|
CHIP_NAME("Intel 82801DBM Southbridge")
|
2004-08-24 18:20:46 +02:00
|
|
|
.enable_dev = i82801dbm_enable,
|
|
|
|
};
|