cvs commit: src/sys/dev/acpica acpi_pci_link.c
John Baldwin
jhb at FreeBSD.org
Thu Dec 2 13:11:05 PST 2004
On Wednesday 01 December 2004 06:17 pm, Pawel Jakub Dawidek wrote:
> On Wed, Dec 01, 2004 at 09:05:02PM +0000, John Baldwin wrote:
> +> jhb 2004-12-01 21:05:02 UTC
> +>
> +> FreeBSD src repository
> +>
> +> Modified files:
> +> sys/dev/acpica acpi_pci_link.c
> +> Log:
> +> - Do a better job of handling any Dependent Functions (aka DPFs) that
> appear +> in the _PRS or _CRS of link devices. If faced with multiple
> DPFs in a +> _PRS, we just use the first one. We assume that if _CRS
> has DPF tags they +> only contain a single set since multiple DPFs
> wouldn't make any sense. In +> practice, the only DPFs I've seen so
> far for link devices are that the one +> IRQ resource is surrounded by
> a DPF tag pair for no apparent reason, and +> this should handle that
> case fine now.
> +> - Only allocate link structures for IRQ resources for link devices
> rather +> than allocating a link structure for every resource.
>
> On my box things looks much worse (not sure if this is related):
>
> Timecounter "i8254" frequency 1193182 Hz quality 0
> CPU: Intel(R) XEON(TM) CPU 1.80GHz (1799.75-MHz 686-class CPU)
> Origin = "GenuineIntel" Id = 0xf24 Stepping = 4
>
> Features=0x3febfbff<FPU,VME,DE,PSE,TSC,MSR,PAE,MCE,CX8,APIC,SEP,MTRR,PGE,MC
>A,CMOV,PAT,PSE36,CLFLUSH,DTS,ACPI,MMX,FXSR,SSE,SSE2,SS,HTT,TM>
> Hyperthreading: 2 logical CPUs
> real memory = 1073741824 (1024 MB)
> avail memory = 1046126592 (997 MB)
> ACPI APIC Table: <INTEL APIC >
> FreeBSD/SMP: Multiprocessor System Detected: 4 CPUs
> cpu0 (BSP): APIC ID: 0
> cpu1 (AP): APIC ID: 1
> cpu2 (AP): APIC ID: 6
> cpu3 (AP): APIC ID: 7
> kernel trap 12 with interrupts disabled
>
>
> Fatal trap 12: page fault while in kernel mode
> cpuid = 0; apic id = 00
> fault virtual address = 0x9
> fault code = supervisor write, page not present
> instruction pointer = 0x8:0xc05ac7c9
> stack pointer = 0x10:0xc0820cb4
> frame pointer = 0x10:0xc0820cd0
> code segment = base 0x0, limit 0xfffff, type 0x1b
> = DPL 0, pres 1, def32 1, gran 1
> processor eflags = resume, IOPL = 0
> current process = 0 (swapper)
> [thread pid 0 tid 0 ]
> Stopped at cpu_fork+0x1a1: incl 0x8(%eax)
> db> tr
> Tracing pid 0 tid 0 td 0xc0617e20
> cpu_fork(c0617e20,c1e8b000,c1e83300,60034,c1e8b068,0,c05cd0e1,287,c0619fe0,
>c05cd0e1,283) at cpu_fork+0x1a1
> fork1(c0617e20,60034,0,c0820d4c) at fork1+0xbe5
> kthread_create(c0488eac,0,0,40000,0) at kthread_create+0x33
> ktrace_init(0,c1e70f70,81ec00,81e000,828000) at ktrace_init+0xac
> mi_startup() at mi_startup+0xb3
> begin() at begin+0x2c
> db>
This is well before the link code. Can you use gdb to find the file/line for
cpu_fork+0x1a1?
--
John Baldwin <jhb at FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/
"Power Users Use the Power to Serve" = http://www.FreeBSD.org
More information about the cvs-all
mailing list