Commit 02a11d70 authored by Jeff Garzik's avatar Jeff Garzik

Merge pobox.com:/spare/repo/linux-2.6

into pobox.com:/spare/repo/netdev-2.6/janitor
parents 8b5915b0 6e72934d
...@@ -262,14 +262,13 @@ static int __devinit sis630e_get_mac_addr(struct pci_dev * pci_dev, struct net_d ...@@ -262,14 +262,13 @@ static int __devinit sis630e_get_mac_addr(struct pci_dev * pci_dev, struct net_d
u8 reg; u8 reg;
int i; int i;
isa_bridge = pci_find_device(PCI_VENDOR_ID_SI, 0x0008, isa_bridge); isa_bridge = pci_get_device(PCI_VENDOR_ID_SI, 0x0008, isa_bridge);
if (!isa_bridge) { if (!isa_bridge)
isa_bridge = pci_find_device(PCI_VENDOR_ID_SI, 0x0018, isa_bridge); isa_bridge = pci_get_device(PCI_VENDOR_ID_SI, 0x0018, isa_bridge);
if (!isa_bridge) { if (!isa_bridge) {
printk("%s: Can not find ISA bridge\n", net_dev->name); printk("%s: Can not find ISA bridge\n", net_dev->name);
return 0; return 0;
} }
}
pci_read_config_byte(isa_bridge, 0x48, &reg); pci_read_config_byte(isa_bridge, 0x48, &reg);
pci_write_config_byte(isa_bridge, 0x48, reg | 0x40); pci_write_config_byte(isa_bridge, 0x48, reg | 0x40);
...@@ -278,6 +277,7 @@ static int __devinit sis630e_get_mac_addr(struct pci_dev * pci_dev, struct net_d ...@@ -278,6 +277,7 @@ static int __devinit sis630e_get_mac_addr(struct pci_dev * pci_dev, struct net_d
((u8 *)(net_dev->dev_addr))[i] = inb(0x71); ((u8 *)(net_dev->dev_addr))[i] = inb(0x71);
} }
pci_write_config_byte(isa_bridge, 0x48, reg & ~0x40); pci_write_config_byte(isa_bridge, 0x48, reg & ~0x40);
pci_dev_put(isa_bridge);
return 1; return 1;
} }
...@@ -485,9 +485,11 @@ static int __devinit sis900_probe (struct pci_dev *pci_dev, const struct pci_dev ...@@ -485,9 +485,11 @@ static int __devinit sis900_probe (struct pci_dev *pci_dev, const struct pci_dev
} }
/* save our host bridge revision */ /* save our host bridge revision */
dev = pci_find_device(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_630, NULL); dev = pci_get_device(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_630, NULL);
if (dev) if (dev) {
pci_read_config_byte(dev, PCI_CLASS_REVISION, &sis_priv->host_bridge_rev); pci_read_config_byte(dev, PCI_CLASS_REVISION, &sis_priv->host_bridge_rev);
pci_dev_put(dev);
}
/* print some information about our NIC */ /* print some information about our NIC */
printk(KERN_INFO "%s: %s at %#lx, IRQ %d, ", net_dev->name, printk(KERN_INFO "%s: %s at %#lx, IRQ %d, ", net_dev->name,
......
...@@ -1236,6 +1236,11 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, ...@@ -1236,6 +1236,11 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
struct tulip_private *tp; struct tulip_private *tp;
/* See note below on the multiport cards. */ /* See note below on the multiport cards. */
static unsigned char last_phys_addr[6] = {0x00, 'L', 'i', 'n', 'u', 'x'}; static unsigned char last_phys_addr[6] = {0x00, 'L', 'i', 'n', 'u', 'x'};
static struct pci_device_id early_486_chipsets[] = {
{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82424) },
{ PCI_DEVICE(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_496) },
{ },
};
static int last_irq; static int last_irq;
static int multiport_cnt; /* For four-port boards w/one EEPROM */ static int multiport_cnt; /* For four-port boards w/one EEPROM */
u8 chip_rev; u8 chip_rev;
...@@ -1289,17 +1294,15 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, ...@@ -1289,17 +1294,15 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
* without the workarounds being on. * without the workarounds being on.
*/ */
/* Intel Saturn. Switch to 8 long words burst, 8 long word cache aligned /* 1. Intel Saturn. Switch to 8 long words burst, 8 long word cache
Aries might need this too. The Saturn errata are not pretty reading but aligned. Aries might need this too. The Saturn errata are not
thankfully it's an old 486 chipset. pretty reading but thankfully it's an old 486 chipset.
2. The dreaded SiS496 486 chipset. Same workaround as Intel
Saturn.
*/ */
if (pci_find_device(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82424, NULL)) { if (pci_dev_present(early_486_chipsets)) {
csr0 = MRL | MRM | (8 << BurstLenShift) | (1 << CALShift);
force_csr0 = 1;
}
/* The dreaded SiS496 486 chipset. Same workaround as above. */
if (pci_find_device(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_496, NULL)) {
csr0 = MRL | MRM | (8 << BurstLenShift) | (1 << CALShift); csr0 = MRL | MRM | (8 << BurstLenShift) | (1 << CALShift);
force_csr0 = 1; force_csr0 = 1;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment