Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 10 Dec 2008 16:45:50 -0800
From:      Sam Leffler <sam@freebsd.org>
To:        Jille Timmermans <jille@quis.cx>
Cc:        FreeBSD Current <current@freebsd.org>
Subject:   Re: Panic when loading if_ath
Message-ID:  <494062BE.5050202@freebsd.org>
In-Reply-To: <49405EC7.8080906@quis.cx>
References:  <49403F27.3020605@quis.cx> <4940440E.9050805@freebsd.org> <49405EC7.8080906@quis.cx>

next in thread | previous in thread | raw e-mail | index | archive | help
Jille Timmermans wrote:
> Sam Leffler schreef:
>   
>> Jille Timmermans wrote:
>>     
>>> Hello list,
>>>
>>> A panic with if_ath (Atheros 2413)
>>>
>>> root /sys/modules/ath_rate_amrr# make
>>> root /sys/modules/ath_rate_amrr# make install
>>> root ~# kldload if_ath
>>> warning: KLD '/boot/kernel/if_ath.ko' is newer than the linker.hints file
>>> ath0: <Atheros 2413> mem 0xc9000000-0xc900ffff irq 18 at device 1.0 on
>>> pci5
>>> ath0: [ITHREAD]
>>>
>>> Fatal trap 12: page fault while in kernel mode
>>> cpuid = 0; apic id = 00
>>> fault virtual address = 0x0
>>> fault code = supervisor read, page not present
>>> instruction pointer = 0x20:0x0
>>> stack pointer = 0x28:0xc43cc748
>>> frame pointer = 0x28:0xc43cc75c
>>> code segment = base 0x0, limit 0xfffff, type 0x1b
>>>              = DPL 0, pres 1, def32 1, gran 1
>>> processor eflags = interrupt enabled, resume, IOPL = 0
>>> current_process = 993 (kldload)
>>> trap number = 12
>>> panic: page fault
>>> cpuid = 0
>>>
>>> [dump]
>>> [reboot]
>>> WARNING: /tmp was not properly dismounted
>>> WARNING: /usr was not properly dismounted
>>> WARNING: /var was not properly dismounted
>>>
>>> Fatal trap 12: page fault while in kernel mode
>>> cpuid = 0; apic id = 00
>>> fault virtual address = 0x5bbfe499
>>> fault code = supervisor read, page not present
>>> instruction pointer  = 0x20:0xc0684c37
>>> stack pointer = 0x28:0xc4364a5c
>>> frame pointer = 0x28:0xc4364c28
>>> code segment = base 0x0, limit 0xfffff, type 0x1b
>>>              = DPL 0, pres 1, def32 1, gran 1
>>> processor eflags = interrupt enabled, resume, IOPL = 0
>>> current process = 136 (ifconfig)
>>> trap number = 12
>>> panic: page fault
>>> cpuid = 0
>>>
>>> [a few crashes later, when it comes to mind to get a backtrace]
>>> root ~# kldload ath_rate
>>> root ~# kldload if_ath
>>> ath0: <Atheros 2413> mem 0xc9000000-0xc900ffff irq 18 at device 1.0 on
>>> pci5
>>> ath0: [ITHREAD]
>>> [panic]
>>> uart_z8530_class(c4ac5000, 0, 1, 1, c4390000, ...) at 0
>>> ar5212Attach(1a, c48b0000, 1, c4389000, c437c8ec, ...) at
>>> ar5212Attach+0x211
>>> ath_hal_attach(1a, c48b0000, 1, c4389000, c437c8ec, ...) at
>>> ath_hal_attach+0x56
>>> ath_attach(1a, c48b0000, 3, c437c940, ffffffff, ...) at ath_attach+0x9e
>>> ath_pci_attach(c46bb200, c4823854, c09fcf80, c099dc60, 80000000, ...) at
>>> ath_pci_attach+0x332
>>> device_attach([snip]) at device_attach+0x36f
>>> device_probe_and_attach([snip) at ...+0x43
>>> pci_driver_added([snip]) at +0x104
>>> devclass_add_driver([snip]) at +0xe8
>>> driver_module_handler([snip]) at +0x79
>>> module_register_init()
>>> linker_load_module()
>>> kern_kldload()
>>>
>>> (Please don't tell me you want any of that snips.)
>>>
>>> Any extra information I can provide to you ?
>>> I am willing to help debugging / crashing.
>>>
>>>   
>>>       
>> Try building the driver into the kernel.  Also use sample and not amrr.
>>     
> root ~# cd /sys/modules/ath_rate_sample
> root /sys/modules/ath_rate_sample# make
> root /sys/modules/ath_rate_sample# make install
> root /sys/modules/ath_rate_sample# kldload if_ath
> link_elf: symbol ath_hal_computetxtime undefined
> KLD if_ath.ko: depends on ath_rate - not available
> kldload: can't load if_ath: No such file or directory
> root /sys/modules/ath_rate_sample# kldload ath_rate
> link_elf: symbol ath_hal_computetxtime undefined
> kldload: can't load ath_rate: No such file or directory
>
> I'll try compiling it in.
>
>   
I know module building is broken; I posted recently to just build things 
into the kernel.  I've got a possible solution in p4 in the sam_vap 
branch if you want to try it.  I removed the ath_rate_* modules and just 
smooshed the code into the ath module so we go from 
(ath+ath_hal+ath_rate) to just (ath).

Right now I want to see if your problem is in the module mess, 
ath_rate_amrr, or something else.  I tested 2413 w/ the driver built 
into the kernel so I'm guessing it's amrr which I may just nuke entirely 
(along with onoe).

    Sam




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