Commit d2531433 authored by Dely Sy's avatar Dely Sy Committed by Greg Kroah-Hartman

[PATCH] PCI Hotplug: Bug fixes for shpchp driver

Can you please apply the following patch that has bug fixes for shpchp
driver? One bug was writing 1's to RsvdZ in Slot Status register
causing hot-plugging of PCI-X cards not working in some slots.  The
other fix is for getting the correct bus number.
Signed-off-by: default avatarDely Sy <dely.l.sy@intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent dc1bd315
...@@ -1539,7 +1539,7 @@ int shpc_init(struct controller * ctrl, ...@@ -1539,7 +1539,7 @@ int shpc_init(struct controller * ctrl,
slot_reg = readl(php_ctlr->creg + SLOT1 + 4*hp_slot ); slot_reg = readl(php_ctlr->creg + SLOT1 + 4*hp_slot );
dbg("%s: Default Logical Slot Register %d value %x\n", __FUNCTION__, dbg("%s: Default Logical Slot Register %d value %x\n", __FUNCTION__,
hp_slot, slot_reg); hp_slot, slot_reg);
tempdword = 0xffffffff; tempdword = 0xffff3fff;
writel(tempdword, php_ctlr->creg + SLOT1 + (4*hp_slot)); writel(tempdword, php_ctlr->creg + SLOT1 + (4*hp_slot));
} }
...@@ -1592,7 +1592,7 @@ int shpc_init(struct controller * ctrl, ...@@ -1592,7 +1592,7 @@ int shpc_init(struct controller * ctrl,
slot_reg = readl(php_ctlr->creg + SLOT1 + 4*hp_slot ); slot_reg = readl(php_ctlr->creg + SLOT1 + 4*hp_slot );
dbg("%s: Default Logical Slot Register %d value %x\n", __FUNCTION__, dbg("%s: Default Logical Slot Register %d value %x\n", __FUNCTION__,
hp_slot, slot_reg); hp_slot, slot_reg);
tempdword = 0xe01fffff; tempdword = 0xe01f3fff;
writel(tempdword, php_ctlr->creg + SLOT1 + (4*hp_slot)); writel(tempdword, php_ctlr->creg + SLOT1 + (4*hp_slot));
} }
if (!shpchp_poll_mode) { if (!shpchp_poll_mode) {
......
...@@ -1396,17 +1396,19 @@ static int configure_existing_function( ...@@ -1396,17 +1396,19 @@ static int configure_existing_function(
static int bind_pci_resources_to_slots ( struct controller *ctrl) static int bind_pci_resources_to_slots ( struct controller *ctrl)
{ {
struct pci_func *func, new_func; struct pci_func *func, new_func;
int busn = ctrl->bus; int busn = ctrl->slot_bus;
int devn, funn; int devn, funn;
u32 vid; u32 vid;
for (devn = 0; devn < 32; devn++) { for (devn = 0; devn < 32; devn++) {
for (funn = 0; funn < 8; funn++) { for (funn = 0; funn < 8; funn++) {
/*
if (devn == ctrl->device && funn == ctrl->function) if (devn == ctrl->device && funn == ctrl->function)
continue; continue;
*/
/* find out if this entry is for an occupied slot */ /* find out if this entry is for an occupied slot */
vid = 0xFFFFFFFF; vid = 0xFFFFFFFF;
pci_bus_read_config_dword(ctrl->pci_bus, PCI_DEVFN(devn, funn), PCI_VENDOR_ID, &vid); pci_bus_read_config_dword(ctrl->pci_dev->subordinate, PCI_DEVFN(devn, funn), PCI_VENDOR_ID, &vid);
if (vid != 0xFFFFFFFF) { if (vid != 0xFFFFFFFF) {
func = shpchp_slot_find(busn, devn, funn); func = shpchp_slot_find(busn, devn, funn);
......
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