Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 04 Nov 1999 12:52:47 -0700
From:      Warner Losh <imp@village.org>
To:        Will Andrews <andrews@technologist.com>
Cc:        mobile@FreeBSD.ORG, current@FreeBSD.ORG
Subject:   Re: laptop problems 
Message-ID:  <199911041952.MAA09155@harmony.village.org>
In-Reply-To: Your message of "Wed, 03 Nov 1999 23:12:37 EST." <3.0.6.32.19991103231237.008b0d40@mail.psn.net> 
References:  <3.0.6.32.19991103231237.008b0d40@mail.psn.net>  <Your message of "Mon, 01 Nov 1999 18:15:13 EST."<3.0.6.32.19991101181513.0081bb40@mail.psn.net> <3.0.6.32.19991101181513.0081bb40@mail.psn.net> 

next in thread | previous in thread | raw e-mail | index | archive | help
In message <3.0.6.32.19991103231237.008b0d40@mail.psn.net> Will Andrews writes:
: My card IS getting recognized, and seems to be on the appropriate port,
: BUT, I think memory pointers are getting mixed up, because it's
: returning the _WRONG_ MAC address.

That's usually an indication that something is wrong.

: Plus, 'pccard0' is being used even
: though it's not in the kernel currently loaded.

It must be, or it won't work at all.

: Here's the kernel output (that I found erroneous):
: pcic: polling, can't alloc 0
: pcic: polling, can't alloc 0

Hardwire your pcic's irq to one that works.

: Here's the pccardd output:
: 
: ep0: <3Com 3C574B, Megahertz 3CCFE574BT or Fast Etherlink 3C574-TX> at
: port 0x240-0x25f irq 10 slot 0 on pccard0
: ep0: Ethernet address 4b:57:4b:57:4b:57
: ep0: strange connector type in EEPROM, assuming AUI
: 
: Yes, I have a 3Com 3CCFE574BT that has worked with -CURRENT before.
: And yes, the kernel sources (at least relevant to pccard) is up to
: date, including your EEPROM an pcic_p.c (or whatever) fixes. The
: devclass_alloc_unit() problem was fixed by the pcic_p.c fix, but
: EEPROM problems lurk. :\

Hmmm.  Looks like I'll need access to the hardware to fix it then.  Or
Matt Dodd will.

: It's been a few days since I wrote this reply. I've been hacking
: /sys/dev/ep/if_ep.c, trying to figure out what's wrong. I
: originally thought the ep_get_macaddr() function's for() loop
: was erroneous in that it uses an integer `i' in the for loop
: instead of a u_int_16. That theory didn't go (still got the
: wrong MAC addresses.. something's not right.), however, I did
: find out that the polling thing was caused by pcic's IRQ not
: being assigned properly. I hardwared the pcic_irq = 11; in my
: /sys/pccard/pcic.c, and that removed the error. So, somebody
: borked pcic.c in this respect somewhere (haven't looked
: further yet), although this hardwire didn't fix the MAC
: address problem.

I woundn't expect it to.

: Then I had a look at the odd EEPROM problem, which seems to have
: been caused by erroneous values in IFM_ETHER_10T, etc. I put in
: a debugging device_printf(), and found my ifm.ifmedia (whatever's
: in the switch() with a default: that outputs the error message
: above (it's in /sys/dev/ep/if_ep.c)) to equal 0. What the hell's
: wrong with this thing? IFM_ETHER_10T should be 0, judging by
: the array definition given. Perhaps you meant to use an enum?
: Anyway, I plugged in a case 0: to see if that fixed the problem,
: and it did. So, something's borked with that too.
: 
: /me will check CVS logs tomorrow to see if in one place or
: another ep_get_macaddr(), etc. got borked somehow.

Patches?

Warner


To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199911041952.MAA09155>