summaryrefslogtreecommitdiff
path: root/share/man/man4/man4.i386/pcibios.4
diff options
context:
space:
mode:
Diffstat (limited to 'share/man/man4/man4.i386/pcibios.4')
-rw-r--r--share/man/man4/man4.i386/pcibios.4260
1 files changed, 260 insertions, 0 deletions
diff --git a/share/man/man4/man4.i386/pcibios.4 b/share/man/man4/man4.i386/pcibios.4
new file mode 100644
index 00000000000..124308b6c6f
--- /dev/null
+++ b/share/man/man4/man4.i386/pcibios.4
@@ -0,0 +1,260 @@
+.\" $OpenBSD: pcibios.4,v 1.1 2000/08/17 20:20:46 mickey Exp $
+.\" $NetBSD: pcibios.4,v 1.7 2000/08/03 13:32:39 soda Exp $
+.\"
+.\" Copyright (c) 2000 Michale Shalayeff, All rights reserved.
+.\" Copyright (c) 1999, 2000 The NetBSD Foundation, Inc.
+.\" All rights reserved.
+.\"
+.\" This code is derived from software contributed to The NetBSD Foundation
+.\" by Lennart Augustsson.
+.\"
+.\" 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 by the NetBSD
+.\" Foundation, Inc. and its contributors.
+.\" 4. Neither the name of The NetBSD Foundation nor the names of its
+.\" contributors may be used to endorse or promote products derived
+.\" from this software without specific prior written permission.
+.\"
+.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+.\" ``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 THE FOUNDATION OR CONTRIBUTORS
+.\" 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 July 22, 2000
+.Dt PCIBIOS 4
+.Os
+.Sh NAME
+.Nm pcibios
+.Nd introduction to PCI BIOS support
+.Sh SYNOPSIS
+.Cd "pcibios0 at bios0 flags 0x0000"
+.Cd "option PCIBIOSVERBOSE"
+.\" .Cd "#options PCIBIOS_IRQS_HINT=0x0a00 #IRQ 9,11"
+.\" .Cd "#options PCIBIOS_INTR_FIXUP_FORCE"
+.\" .Cd "options PCIBIOS_INTR_GUESS"
+.\" .Cd "#options PCIINTR_DEBUG"
+.Pp
+.Sh INTRODUCTION
+.Ox
+provides support for setting up PCI controllers, bridges, and devices
+using information extracted from the BIOS.
+.Pp
+Ideally, the boot firmware of a machine (a.k.a. BIOS) should set
+up all PCI devices; assigning them I/O and memory addresses and
+interrupts. Alas, this does not always happen, so there is some
+PC specific code that can do the initialization when
+.Ox
+boots.
+.Pp
+Flags is a bit mask each bit of which specifies which fixup procedures to
+ommit. The following list specifies these procedures and gives
+flags bit values to disable them in case they cause problems.
+
+.Bl -tag -width 0x0000 -offset 3n
+
+.It 0x0001
+fixup PCI I/O and memory addresses.
+.Pp
+Some BIOS implementations don't allocate I/O space and
+memory space for some PCI devices. Especially, a BIOS
+which is
+.Qq PnP OS mode enabled
+shows this behavior.
+Since necessary space isn't allocated, those devices
+will not work without special handling.
+
+Without this flag force allocation of I/O space and memory space
+instead of relying upon the BIOS to do so.
+
+If necessary space is already correctly assigned to the devices,
+this option leaves the space as is.
+
+Although many BIOS implementations leave CardBus bridges'
+space unallocated, the CardBus bridge device driver doesn't
+require this option, since the driver allocates necessary space
+by itself.
+
+.It 0x0002
+fixup PCI bus numbering; needed for many
+.Xr cardbus 4
+bridges.
+.Pp
+Each PCI bus and CardBus should have a unique bus number.
+But some BIOS implementations don't assign a bus number
+for subordinate PCI buses. And many BIOS implementations
+don't assign a bus number for CardBuses.
+
+A typical symptom of this is the following boot message:
+.D1 Sy cardbus0 at cardslot0: bus 0 device 0...
+Please note that this cardbus0 has a bus number
+.Sq 0 ,
+but normally the bus number 0 is used by the machine's
+primary PCI bus. Thus, this bus number for cardbus is
+incorrect
+.Pq not assigned .
+In this situation, a device located in cardbus0 doesn't
+show correct device ID,
+because its bus number 0 incorrectly refers to the primary
+PCI bus, and a device ID in the primary PCI bus is shown
+in the boot message instead of the device's ID in the cardbus0.
+
+Without this flag force assignment of bus numbers for all subordinate
+PCI buses and CardBuses.
+
+Since this procedure renumbers all PCI buses and CardBuses,
+all bus numbers of subordinate buses become different
+when this option is enabled.
+
+.It 0x0004
+fixup PCI interrupt routing.
+.Pp
+Some BIOS implementations don't assign an interrupt for
+some devices.
+
+This procedure assigns an interrupt for such devices instead
+of relying upon the BIOS to do so.
+
+If the BIOS has already assigned an interrupt to a device, this
+procedure leaves the interrupt as is.
+
+.\" .It Nm PCIBIOS_IRQS_HINT
+.\" hint for IRQ use.
+.\" When the
+.\" .Em PCIBIOS_INTR_FIXUP
+.\" cannot guess an adequate IRQ for a device, the hint is used.
+.\" .Pp
+.\" The value is a logical or of power-of-2s of allowable interrupts:
+.\" .Bl -column "XX-0xffff" "XX-0xffff" "XX-0xffff" "XX-0xffff" -compact -offset 2n
+.\" .It Em "IRQ Value" Em "\tIRQ Value" Em "\tIRQ Value" Em "\tIRQ Value"
+.\" .It "\& 0 0x0001" "\t 4 0x0010" "\t 8 0x0100" "\t12 0x1000"
+.\" .It "\& 1 0x0002" "\t 5 0x0020" "\t 9 0x0200" "\t13 0x2000"
+.\" .It "\& 2 0x0004" "\t 6 0x0040" "\t10 0x0400" "\t14 0x4000"
+.\" .It "\& 3 0x0008" "\t 7 0x0080" "\t11 0x0800" "\t15 0x8000"
+.\" .El
+.\" For example,
+.\" .Qq Sy options PCIBIOS_IRQS_HINT=0x0a00
+.\" allows IRQ 9 and IRQ 11.
+.\"
+.\" The kernel global variable
+.\" .Va pcibios_irqs_hint
+.\" holds this value,
+.\" so a user can override this value without kernel recompilation.
+.\" For example:
+.\" .Bl -bullet -compact
+.\" .It
+.\" To specify this value on the fly, type the following command
+.\" at the boot prompt to drop into DDB (the in-kernel debugger;
+.\" you have to specify
+.\" .Qq Sy options DDB
+.\" to make kernel with DDB):
+.\" .Dl Ic boot -d
+.\" And type the following command on
+.\" .Qq Sy db>
+.\" prompt:
+.\" .Dl Ic write pcibios_irqs_hint 0x0a00
+.\" Then type the following to continue to boot:
+.\" .Dl Ic c
+.\" .It
+.\" To modify kernel image without kernel recompilation,
+.\" run the following command on shell:
+.\" .Dl Ic gdb --write /netbsd
+.\" And type the following commands at the
+.\" .Qq Sy (gdb)
+.\" prompt:
+.\" .Dl Ic set pcibios_irqs_hint=0xa00
+.\" .Dl Ic quit
+.\" .El
+.\"
+.\" .It Nm PCIBIOS_INTR_FIXUP_FORCE
+.\" .Pp
+.\" Some buggy BIOS implementations provide inconsistent
+.\" information between the PCI Interrupt Configuration Register
+.\" and the PCI Interrupt Routing table. In such case,
+.\" the PCI Interrupt Configuration Register takes precedence
+.\" by default. If this happens, a kernel with
+.\" .Em PCIBIOSVERBOSE
+.\" shows
+.\" .Qq Sy WARNING: preserving irq XX
+.\" in the PCI routing table.
+.\"
+.\" If
+.\" .Em PCIBIOS_INTR_FIXUP_FORCE
+.\" is specified in addition to the
+.\" .Em PCIBIOS_INTR_FIXUP ,
+.\" the PCI Interrupt Routing table takes precedence.
+.\" In this case, a kernel with
+.\" .Em PCIBIOSVERBOSE
+.\" shows
+.\" .Qq Sy WARNING: overriding irq XX
+.\" in the PCI routing table.
+.\"
+.\" The necessity of this option is doubtful, and we may
+.\" remove this option in the future. If you find that this
+.\" option is worth preserving, please report it with send-pr.
+.\"
+.\" .It Nm PCIBIOS_INTR_GUESS
+.\" make
+.\" .Em PCIBIOS_INTR_FIXUP
+.\" work with unknown interrupt router.
+.\" .Pp
+.\" If a PCI interrupt router is not known, normally interrupt
+.\" configuraion will not be touched.
+.\"
+.\" But if
+.\" .Em PCIBIOS_INTR_GUESS
+.\" is specified in addition to the
+.\" .Em PCIBIOS_INTR_FIXUP ,
+.\" and if a PCI interrupt routing table entry indicates that only
+.\" one IRQ is available for the entry, the IRQ is assumed to be already
+.\" connected to the device, and corresponding PCI Interrupt
+.\" Configuration Register will be configured accordingly.
+.\"
+.\" .It Nm PCIINTR_DEBUG
+.\" make the
+.\" .Em PCIBIOS_INTR_FIXUP
+.\" procedure verbose.
+.\"
+.\" .El
+.Sh SEE ALSO
+.Xr cardbus 4 ,
+.Xr pci 4
+.Sh HISTORY
+The
+.Nm
+code appeared in
+.Nx 1.5 .
+.Ox
+support was added in
+.Ox 2.8 .
+In contrast to
+.Nx
+implementation
+.Nm
+in
+.Ox
+is a real device, where options control is done through the
+.Nm flags
+wich are modifiable through the
+.Xr boot_config 8
+interface.
+.Sh BUGS
+The
+.Em PCIBIOS Adress Fixup
+option may conflict with the PCI CardBus driver's own
+address fixup.