Date: Fri, 13 Oct 2006 05:04:54 +0800 From: "Jia-Shiun Li" <jiashiun@gmail.com> To: freebsd-current@freebsd.org Subject: using dev nameunit prior to probe & attach in pcib_alloc_resource() Message-ID: <1d6d20bc0610121404r600bfee6n9633d621b6dc2e87@mail.gmail.com>
next in thread | raw e-mail | index | archive | help
This is a cosmetic bug (probably). I noticed that pcib prints some null pointer string in verbose dmesg like the following example. The pcib driver prints "(null) requested memory...". It turns out that pcib_alloc_resource() intended to use dev->nameunit to show device name. But the function is called for the first time during pci bus device enumeration. By the time the driver probing function is not called yet, and hence no valid nameunit. I suppose this code fragment in pcib_alloc_resource(): if (bootverbose) device_printf(dev,"%s requested memory range " "0x%lx-0x%lx: good\n", device_get_nameunit(child), start, end); should be changed to use something else, for example pci device(slot) and function numbers, to identify the newly enumerated and yet probed pci devices. Any comment? The verbose dmesg example: pcib3: <ACPI PCI-PCI bridge> at device 30.0 on pci0 pcib3: secondary bus 1 pcib3: subordinate bus 1 pcib3: I/O decode 0xc000-0xcfff pcib3: memory decode 0xdec00000-0xdeefffff pcib3: prefetched decode 0xdf000000-0xdfffffff pcib3: Subtractively decoded bridge. pci1: <ACPI PCI bus> on pcib3 pci1: physical bus=1 found-> vendor=0x1039, dev=0x6326, revid=0x0b bus=1, slot=9, func=0 class=03-00-00, hdrtype=0x00, mfdev=0 cmdreg=0x0007, statreg=0x0230, cachelnsz=0 (dwords) lattimer=0x40 (1920 ns), mingnt=0x02 (500 ns), maxlat=0x00 (0 ns) powerspec 1 supports D0 D2 D3 current D0 map[10]: type 3, range 32, base df000000, size 23, enabled pcib3: (null) requested memory range 0xdf000000-0xdf7fffff: good map[14]: type 1, range 32, base decf0000, size 16, enabled pcib3: (null) requested memory range 0xdecf0000-0xdecfffff: good map[18]: type 4, range 32, base 0000c400, size 7, enabled pcib3: (null) requested I/O range 0xc400-0xc47f: in range found-> vendor=0x8086, dev=0x1229, revid=0x02 bus=1, slot=10, func=0 class=02-00-00, hdrtype=0x00, mfdev=0 cmdreg=0x0007, statreg=0x0280, cachelnsz=0 (dwords) lattimer=0x40 (1920 ns), mingnt=0x08 (2000 ns), maxlat=0x38 (14000 ns) intpin=a, irq=5 map[10]: type 3, range 32, base dffff000, size 12, enabled pcib3: (null) requested memory range 0xdffff000-0xdfffffff: good map[14]: type 4, range 32, base 0000c800, size 5, enabled pcib3: (null) requested I/O range 0xc800-0xc81f: in range map[18]: type 1, range 32, base dee00000, size 20, enabled pcib3: (null) requested memory range 0xdee00000-0xdeefffff: good pcib3: matched entry for 1.10.INTA pcib3: slot 10 INTA hardwired to IRQ 21 vgapci0: <VGA-compatible display> port 0xc400-0xc47f mem 0xdf000000-0xdf7fffff,0xdecf0000-0xdecfffff at device 9.0 o n pci1 fxp0: <Intel 82557 Pro/100 Ethernet> port 0xc800-0xc81f mem 0xdffff000-0xdfffffff,0xdee00000-0xdeefffff irq 21 at de vice 10.0 on pci1 fxp0: Reserved 0x1000 bytes for rid 0x10 type 3 at 0xdffff000 fxp0: using memory space register mapping fxp0: PCI IDs: 8086 1229 0000 0000 0002 fxp0: Dynamic Standby mode is disabled miibus0: <MII bus> on fxp0 amphy0: <Am79C873 10/100 media interface> on miibus0 amphy0: 10baseT, 10baseT-FDX, 100baseTX, 100baseTX-FDX, auto fxp0: bpf attached fxp0: Ethernet address: 00:c0:0c:70:10:05 ioapic0: routing intpin 21 (PCI IRQ 21) to vector 49 fxp0: [MPSAFE] Jia-Shiun.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1d6d20bc0610121404r600bfee6n9633d621b6dc2e87>