Home | History | Annotate | Line # | Download | only in man9
pci_configure_bus.9 revision 1.4
 $NetBSD: pci_configure_bus.9,v 1.4 2002/02/11 18:43:39 kleink Exp $

Copyright 2001 Wasabi Systems, Inc.
All rights reserved.

Written by Allen Briggs for Wasabi Systems, Inc.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
3. All advertising materials mentioning features or use of this software
must display the following acknowledgement:
This product includes software developed for the NetBSD Project by
Wasabi Systems, Inc.
4. The name of Wasabi Systems, Inc. may not be used to endorse
or promote products derived from this software without specific prior
written permission.

THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC
BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.

.Dd February 11, 2002 .Dt PCI_CONFIGURE_BUS 9 .Os .Sh NAME .Nm pci_configure_bus , .Nm pci_conf_hook , .Nm pci_conf_interrupt .Nd perform PCI bus configuration .Sh SYNOPSIS .Fd #include <dev/pci/pciconf.h> .Ft int .Fo pci_configure_bus .Fa "pci_chipset_tag_t pc" .Fa "struct extent *ioext" .Fa "struct extent *memext" .Fa "struct extent *pmemext" .Fc .Sh DESCRIPTION The .Fn pci_configure_bus function configures a PCI bus for use. This involves: l -bullet t Defining bus numbers for all busses on the system, t Setting the Base Address Registers for all devices, t Setting up the interrupt line register for all devices, and t Configuring bus latency timers for all devices. .El

p In traditional PCs and Alpha systems, the BIOS or firmware takes care of this task, but that is not the case for all systems. .Fn pci_configure_bus should be called prior to the auto-configuration of the bus.

p The .Fa pc argument is a machine-dependent tag used to specify the PCI chipset to the system. This should be the same value used with .Fn pci_make_tag . The extent arguments define memory extents from which the address space for the cards will be taken. These addresses should be in the PCI address space. The .Fa ioext extent is for PCI I/O accesses. The .Fa memext extent is for PCI memory accesses that might have side effects. I.e., that can not be cached. The .Fa pmemext extent is for PCI memory accesses that can be cached. The .Fa pmemext extent will be used for any ROMs and any memory regions that are marked as .Dq prefetchable in their BAR. If an implementation does not distinguish between prefetchable and non-prefetchable memory, it may pass NULL for .Fa pmemext . In this case, prefetchable memory allocations will be made from the non-prefetchable region.

p An implementation may choose to not have full configuration performed by .Fn pci_configure_bus on certain PCI devices, such as PCI host bridges or PCI bus analyzers which are instantiated as devices on the bus. In order for this to take place, the header .Aq Pa machine/pci_machdep.h must define the .Dv __HAVE_PCI_CONF_HOOK symbol (without a value), and a machine-dependent function .Fn pci_conf_hook (declared in the same header) must be defined. The prototype for this function is

p .Fn "int pci_conf_hook" "pci_chipset_tag_t pc" "int id" \ "int bus" "int device" "int function"

p In this function, .Fa bus , .Fa device , and .Fa function uniquely identify the item being configured; in addition to this, the value of the device's PCI identification register is passed in .Fa id . For each device .Fn pci_conf_hook can then decide upon the amount of configuration to be performed by returning a bitwise inclusive-or of the following flags: l -tag -width PCI_CONF_ENABLE_MEM -offset indent t Dv PCI_CONF_MAP_IO Configure Base Address Registers that map I/O space t Dv PCI_CONF_MAP_MEM Configure Base Address Registers that map memory space t Dv PCI_CONF_MAP_ROM Configure Expansion ROM Base Address register t Dv PCI_CONF_ENABLE_IO Enable I/O space accesses t Dv PCI_CONF_ENABLE_MEM Enable memory space accesses t Dv PCI_CONF_ENABLE_BM Enable bus mastering .El

p In addition, .Dv PCI_CONF_ALL specifies all of the above.

p One of the functions of .Fn pci_configure_bus is to configure interrupt .Dq line information. This must be done on a machine-dependent basis, so a machine-dependent function .Fn pci_conf_interrupt must be defined. The prototype for this function is

p .Fn "void pci_conf_interrupt" "pci_chipset_tag_t pc" "int bus" \ "int device" "int function" "int swiz" "int *iline"

p In this function, .Fa bus , .Fa device , and .Fa function , uniquely identify the item being configured. The .Fa swiz argument is a .Dq swizzle , a sum of the device numbers of the primary interface of the bridges between the host bridge and the current device. The function is responsible for setting the value of .Fa iline . See chapter 9 of the .Dq PCI-to-PCI Bridge Architecture Specification for more information on swizzling (also known as interrupt routing). .Sh RETURN VALUES If successful .Fn pci_configure_bus returns 0. A non-zero return value means that the bus was not completely configured for some reason. A description of the failure will be displayed on the console. .Sh ENVIRONMENT The .Fn pci_configure_bus function is only included in the kernel if the kernel is compiled with the .Dv PCI_NETBSD_CONFIGURE option enabled. .Sh EXAMPLES The .Fn pci_conf_hook function in the walnut implementation looks like:

p d -literal -compact int pci_conf_hook(pci_chipset_tag_t pc, int bus, int dev, int func, int id) { if ((PCI_VENDOR(id) == PCI_VENDOR_IBM && PCI_PRODUCT(id) == PCI_PRODUCT_IBM_405GP) || (PCI_VENDOR(id) == PCI_VENDOR_INTEL && PCI_PRODUCT(id) == PCI_PRODUCT_INTEL_80960_RP)) { /* Don't configure the bridge and PCI probe. */ return 0; } return (PCI_CONF_ALL & ~PCI_CONF_MAP_ROM); } .Ed

p The .Fn pci_conf_interrupt function in the sandpoint implementation looks like:

p d -literal -compact void pci_conf_interrupt(pci_chipset_tag_t pc, int bus, int dev, int func, int swiz, int *iline) { if (bus == 0) { *iline = dev; } else { *iline = 13 + ((swiz + dev + 3) & 3); } } .Ed

p The BeBox has nearly 1GB of PCI I/O memory starting at processor address 0x81000000 (PCI I/O address 0x01000000), and nearly 1GB of PCI memory starting at 0xC0000000 (PCI memory address 0x00000000). The .Fn pci_configure_bus function might be called as follows:

p d -literal -compact struct extent *ioext, *memext; ... ioext = extent_create("pciio", 0x01000000, 0x0fffffff, M_DEVBUF, NULL, 0, EX_NOWAIT); memext = extent_create("pcimem", 0x00000000, 0x0fffffff, M_DEVBUF, NULL, 0, EX_NOWAIT); ... pci_configure_bus(0, ioext, memext, NULL); ... extent_destroy(ioext); extent_destroy(memext); ... .Ed

p Note that this must be called before the PCI bus is attached during autoconfiguration. .Sh SEE ALSO .Xr pci 4 , .Xr extent 9 .Sh HISTORY .Fn pci_configure_bus was added in .Nx 1.6 .