Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 06 Jun 2003 14:06:35 -0400 (EDT)
From:      John Baldwin <jhb@FreeBSD.org>
To:        John Baldwin <jhb@FreeBSD.org>
Cc:        cvs-all@FreeBSD.org
Subject:   RE: cvs commit: src/sys/i386/pci pci_bus.c src/sys/i386/include legacyvar.h
Message-ID:  <XFMail.20030606140635.jhb@FreeBSD.org>
In-Reply-To: <200306061756.h56HuUc8051034@repoman.freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help

On 06-Jun-2003 John Baldwin wrote:
> jhb         2003/06/06 10:56:30 PDT
> 
>   FreeBSD src repository
> 
>   Modified files:
>     sys/i386/pci         pci_bus.c 
>     sys/i386/include     legacyvar.h 
>   Log:
>   - Rename nexus_pcib to legacy_pcib.  I've been meaning to do this for a
>     while after the legacy device was added since this driver hangs from
>     legacy and not nexus.
>   - Make several methods non-static so they can be reused in a mptable
>     host -> pci bridge driver that will be added at a later date.
>   - Let legacy_pcib() use pcibios_pcib_route_interrupt() directly instead of
>     wrapping it in a private function.  Originally, I thought I was going to
>     have the nexus_pcib() driver make a runtime APIC vs. 8259A check and call
>     the appropriate routing method (MPTable vs. PIR) that way, but it ended
>     up being cleaner to make nexus_pcib() just work with PIR and have a
>     separate host -> pci bridge driver for the mptable/apic case.

The eventual MPTable PCI bridge drivers are not pure theory but already
exist in the jhb_acpipci p4 branch.  There are several changes in that
branch to allow for one kernel that supports using both the 8259A's
and the I/O APIC and using a runtime decision as to how to which one to
use.  The upshot is that we will be able to stick SMP in GENERIC on i386
and that UP machines with an MP table or ACPI MADT table will be able to
use the I/O APIC to handle interrupts.  I hope to have it all in the tree
in time for 5.2.  For a bit of a preview:

Copyright (c) 1992-2003 The FreeBSD Project.
Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994
        The Regents of the University of California. All rights reserved.
FreeBSD 5.1-CURRENT #48: Thu Jun  5 17:08:15 EDT 2003
    jbaldwin@bsdboy.atl.weather.com:/usr/work/jbaldwin/p4/acpipci/i386/compile/B
LUE
Preloaded elf kernel "/boot/acpipci/kernel" at 0xc042d000.
Timecounter "i8254"  frequency 1193182 Hz
Timecounter "TSC"  frequency 2394168536 Hz
CPU: Intel(R) Pentium(R) 4 CPU 2.40GHz (2394.17-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,MCA,C
MOV,PAT,PSE36,CLFLUSH,DTS,ACPI,MMX,FXSR,SSE,SSE2,SS,HTT,TM>
real memory  = 1072889856 (1023 MB)
avail memory = 1037742080 (989 MB)
MP Configuration Table version 1.4 found at 0xc00fc440
lapic_init: local apic addr = 0xfee00000, truc_page() = 0xfee00000
ioapic1: Assuming intbase of 0
ioapic1: Routing external 8259A's -> intpin 0
ioapic1: intpin 2 -> irq 0
APIC: Using the MPTable enumerator.
...
pcib0: <MPTable Host-PCI bridge> at pcibus 0 on motherboard
pci0: <PCI bus> on pcib0
pcib0: slot 29 INTA routed to irq 16
pcib0: slot 29 INTB routed to irq 19
pcib0: slot 29 INTC routed to irq 18
pcib0: slot 29 INTA routed to irq 16
pcib0: slot 29 INTD routed to irq 23
pcib0: slot 31 INTA routed to irq 18
pcib0: slot 31 INTB routed to irq 17
pcib0: slot 31 INTB routed to irq 17
agp0: <Intel 82865 host to AGP bridge> mem 0xf4000000-0xf7ffffff at device 0.0 o
n pci0
pcib1: <MPTable PCI-PCI bridge> at device 1.0 on pci0
pci1: <PCI bus> on pcib1
pcib1: slot 0 INTA routed to irq 16
pci1: <display, VGA> at device 0.0 (no driver attached)
uhci0: <Intel 82801EB (ICH5) USB controller USB-A> port 0xcc00-0xcc1f irq 16 at 
device 29.0 on pci0
usb0: <Intel 82801EB (ICH5) USB controller USB-A> on uhci0
usb0: USB revision 1.0
uhub0: Intel UHCI root hub, class 9/0, rev 1.00/1.00, addr 1
uhub0: 2 ports with 2 removable, self powered
uhci1: <Intel 82801EB (ICH5) USB controller USB-B> port 0xd000-0xd01f irq 19 at 
device 29.1 on pci0
usb1: <Intel 82801EB (ICH5) USB controller USB-B> on uhci1
usb1: USB revision 1.0
...
etc.

You can see the mptable and dmesg output at http://www.FreeBSD.org/~jhb/apic/

-- 

John Baldwin <jhb@FreeBSD.org>  <><  http://www.FreeBSD.org/~jhb/
"Power Users Use the Power to Serve!"  -  http://www.FreeBSD.org/



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