pciehp - Problems with ExpressCard hotplug

From: Mike DeKoker
Date: Wed Nov 03 2010 - 22:13:18 EST


Hello everyone, I hope this is the correct forum.

I'm having a problem with hotplug working for a PCIe-based ExpressCard
device that I'm developing a driver module for. If not hot-plugged,
everything works great. Further, running the exact same laptop/device
hardware but different OS (XP or Win7-64) hot-plugging works okay so I don't
think this is a simple hardware/BIOS error.

I've tried several stock kernel versions from 2.6.18 (the version my
customer intends to use) up to 2.6.34.7 (version for all verbiage below) and
have had fairly consistent behavior.

The driver module (sig_ec14) is using the pci_register_driver interface and
in the subsequent probe callback function (after a hot-plug) an error occurs
when calling pci_enable_device. Here's the relevant dmesg data:

Insert device:
pciehp 0000:00:1c.5:pcie04: Card present on Slot(5)
pci 0000:07:00.0: supports D1
pci 0000:07:00.0: PME# supported from D0 D1 D3hot
pci 0000:07:00.0: PME# disabled
pci 0000:07:00.0: disabling ASPM on pre-1.1 PCIe device. You can enable it
with 'pcie_aspm=force'
pci 0000:08:00.0: reg 10: [mem 0x00000000-0x0000001f]
pci 0000:08:00.0: reg 14: [mem 0x00000000-0x0000007f]
pci 0000:08:00.0: reg 18: [mem 0x00000000-0x0000003f]
pci 0000:07:00.0: PCI bridge to [bus 08-ff]
pci 0000:07:00.0: bridge window [io 0x0000-0x0000] (disabled)
pci 0000:07:00.0: bridge window [mem 0x00000000-0x000fffff] (disabled)
pci 0000:07:00.0: bridge window [mem 0x00000000-0x000fffff pref]
(disabled)
pci 0000:07:00.0: BAR 14: assigned [mem 0xd9000000-0xd90fffff]
pci 0000:07:00.0: PCI bridge to [bus 08-08]
pci 0000:07:00.0: bridge window [io disabled]
pci 0000:07:00.0: bridge window [mem 0xd9000000-0xd90fffff]
pci 0000:07:00.0: bridge window [mem pref disabled]
pcieport 0000:00:1c.5: PCI bridge to [bus 07-09]
pcieport 0000:00:1c.5: bridge window [io 0x1000-0x1fff]
pcieport 0000:00:1c.5: bridge window [mem 0xd9000000-0xd9ffffff]
pcieport 0000:00:1c.5: bridge window [mem 0xd8000000-0xd8ffffff 64bit
pref]
pcieport 0000:00:1c.5: setting latency timer to 64
pci 0000:07:00.0: enabling device (0000 -> 0002)
pci 0000:07:00.0: PCI INT A -> GSI 17 (level, low) -> IRQ 17
pci 0000:07:00.0: setting latency timer to 64
pci 0000:07:00.0: no hotplug settings from platform
pci 0000:08:00.0: no hotplug settings from platform
pci 0000:08:00.0: using default PCI settings
sig_ec14 : Driver module loading
sig_ec14 : Verbose module output enabled (development build)
sig_ec14 : Dynamic major number: 248
sig_ec14 : PCI probe: New EC14 device
sig_ec14 0000:08:00.0: device not available (can't reserve [mem
0x00000000-0x0000001f])
sig_ec14 : Failed to enable PCI device: -22
sig_ec14: probe of 0000:08:00.0 failed with error -22
.

It looks like the requested memory spaces are not allocated properly. I'm a
little uncertain about the entity that's actually responsible for allocating
the resources. Is this a failure of the BIOS or does system software play a
role in PNP resource allocation for hot-plug? I'm a little out of my element
here.

I've also run with pciehp_debug=1 in the event that the extra info makes
sense to someone:

Insert device:
pciehp 0000:00:1c.5:pcie04: pcie_isr: intr_loc 8
pciehp 0000:00:1c.5:pcie04: Presence/Notify input change
pciehp 0000:00:1c.5:pcie04: Card present on Slot(5)
pciehp 0000:00:1c.5:pcie04: Surprise Removal
pciehp 0000:00:1c.5:pcie04: pciehp_check_link_status: lnk_status = 3011
pci 0000:07:00.0: supports D1
pci 0000:07:00.0: PME# supported from D0 D1 D3hot
pci 0000:07:00.0: PME# disabled
pci 0000:07:00.0: disabling ASPM on pre-1.1 PCIe device. You can enable it
with 'pcie_aspm=force'
.

That 'Surprise Removal' immediately following the 'Card present on Slot(5)'
message looks like a potential culprit.

When the device is connected cold and the system is powered up I have no
problems:
sig_ec14 : Driver module loading
sig_ec14 : Verbose module output enabled (development build)
sig_ec14 : Dynamic major number: 248
sig_ec14 : PCI probe: New EC14 device
sig_ec14 0000:0a:00.0: PCI INT A -> GSI 17 (level, low) -> IRQ 17
sig_ec14 : Memory IO region 0 -> Start: 0xD90000C0, Len: 0x0020
sig_ec14 : Memory IO region 1 -> Start: 0xD9000000, Len: 0x0080
sig_ec14 : Memory IO region 2 -> Start: 0xD9000080, Len: 0x0040
.

Any advice would be greatly appreciated; I'd like to be able to test the
module's handling of surprise removal, etc.

I am off-list, please CC me at: mdekoker at the domain of signatec dot com.

Thank you all for your time and the great work you do.

Regards,
Mike DeKoker



--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/