Date: 10 Jun 2003 10:51:10 -0500 From: Craig Boston <craig@xfoil.gank.org> To: current@freebsd.org Subject: CardBus USB 2.0 Controller (NEC uPD) Message-ID: <1055260269.91337.127.camel@owen1492.uf.corelab.com>
next in thread | raw e-mail | index | archive | help
I recently purchased a generic CompUSA branded CardBus USB 2.0 controller for a challenge to try to get it to work under FreeBSD ;) It appears to use an NEC chip -- one that I've seen reports of the PCI version working -- so at least some of the support for it is already there. I'm willing to take a stab at it and would be grateful if someone can point me in the general direction of where to start. Here's the dmesg output when it's attached. cardbus1: Resource not specified in CIS: id=10, size=1000 found-> vendor=0x1033, dev=0x0035, revid=0x41 bus=3, slot=0, func=0 class=0c-03-10, hdrtype=0x00, mfdev=1 cmdreg=0x0000, statreg=0x0210, cachelnsz=8 (dwords) lattimer=0xa8 (5040 ns), mingnt=0x01 (250 ns), maxlat=0x2a (10500 ns) intpin=a, irq=11 powerspec 2 supports D0 D1 D2 D3 current D0 ohci0: <NEC uPD 9210 USB controller> mem 0x88000000-0x88000fff irq 11 at device 0.0 on cardbus1 usb1: OHCI version 1.0 usb1: <NEC uPD 9210 USB controller> on ohci0 usb1: USB revision 1.0 uhub1: NEC OHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub1: 3 ports with 3 removable, self powered cardbus1: Resource not specified in CIS: id=10, size=1000 found-> vendor=0x1033, dev=0x0035, revid=0x41 bus=3, slot=0, func=1 class=0c-03-10, hdrtype=0x00, mfdev=0 cmdreg=0x0000, statreg=0x0210, cachelnsz=8 (dwords) lattimer=0xa8 (5040 ns), mingnt=0x01 (250 ns), maxlat=0x2a (10500 ns) intpin=b, irq=11 powerspec 2 supports D0 D1 D2 D3 current D0 ohci1: <NEC uPD 9210 USB controller> mem 0x88001000-0x88001fff irq 11 at device 0.1 on cardbus1 usb2: OHCI version 1.0 usb2: <NEC uPD 9210 USB controller> on ohci1 usb2: USB revision 1.0 uhub2: NEC OHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub2: 2 ports with 2 removable, self powered cardbus1: Resource not specified in CIS: id=10, size=100 found-> vendor=0x1033, dev=0x00e0, revid=0x02 bus=3, slot=0, func=2 class=0c-03-20, hdrtype=0x00, mfdev=0 cmdreg=0x0000, statreg=0x0210, cachelnsz=8 (dwords) lattimer=0xa8 (5040 ns), mingnt=0x10 (4000 ns), maxlat=0x22 (8500 ns) intpin=c, irq=11 powerspec 2 supports D0 D1 D2 D3 current D0 cardbus1: <serial bus, USB> at device 0.2 (no driver attached) That output seems a little funny, between the "Resource not specified in CIS" and claiming there is no driver attached right after it attaches ohci... I tried to use pccardc dumpcis, but that appears to not work with newcard. Is there an easy way to get equivalent information? Anyway, at least attaching ohci and the uhubs seems to be off to a good start. When I plug in my USB keyboard (or any other device), it doesn't attach and usbdevs -v shows this: Controller /dev/usb0: addr 1: full speed, self powered, config 1, UHCI root hub(0x0000), Intel(0x0000), rev 1.00 port 1 powered port 2 powered Controller /dev/usb1: addr 1: full speed, self powered, config 1, OHCI root hub(0x0000), NEC(0x0000), rev 1.00 port 1 powered port 2 powered port 3 powered Controller /dev/usb2: addr 1: full speed, self powered, config 1, OHCI root hub(0x0000), NEC(0x0000), rev 1.00 port 1 addr 0 should never happen! port 2 powered If I plug something in to the other port the "addr 0 should never happen!" shows up on port 1 of usb1. After about 20 seconds or so I get the message "uhub1: device problem, disabling port 1". If I pop out the card I get: cardbus1: release_all_resource: Resource still owned by child, oops. (type=1, rid=0, addr=b) cardbus1: release_all_resource: Resource still owned by child, oops. (type=3, rid=16, addr=88001000) cardbus1: release_all_resource: Resource still owned by child, oops. (type=1, rid=0, addr=b) cardbus1: release_all_resource: Resource still owned by child, oops. (type=3, rid=16, addr=88002000) If I then re-insert the card, BOOM! panic. That exact location of the panic seems to vary but it's usually somewhere in the bowels of the USB code. If anyone is really that interested, contact me off-list and I can provide traces for some of them. So, I'm not sure if I should start hacking in the Cardbus or the USB code first. My guess is that I should resolve the cardbus CIS issues first and go from there. Any hints are welcome :) Thanks, Craig
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1055260269.91337.127.camel>