B-2
I/O Address Mapping
KPCI-PIO32IOA and KPCI-PDISO8A User’s Manual
NOTE
A typical user of the KPCI-PIO32IOA or KPCI-PDISO8A board does
not need to read this appendix (except perhaps for the supplementary
interrupt illustration under “
”). Register
level programming of the KPCI-PIO32IOA or KPCI-PDISO8A board is
neither practical nor necessary for most users. Register level interfacing
with the PCI bus is more complex than with the ISA bus. PCI board
addresses are mapped automatically in I/O space or memory, whereas
ISA board addresses are assigned manually by the user in I/O space.
The DriverLINX driver shipped with your board provides a user-friendly Application
Programming Interface (API) that supports Visual C++, Visual Basic, and Delphi programming
languages under Windows 98/Me and Windows NT 4.0, 2000, and XP. You are encouraged to
use the capabilities of DriverLINX and ignore the rest of the information in this chapter (except
perhaps the subsection “
,” which may help you to understand how
external interrupts work).
However, there are circumstances in which advanced users may desire or need to bypass
DriverLINX entirely and write their own drivers. Alternatively, advanced users may wish to
program the KPCI-PIO32IOA or KPCI-PDISO8A at the register level using an ActiveX hosting
language. Finally, some users may wish to reuse an existing application program that makes port
I/O calls to an ISA-bus digital I/O board.
discusses the following:
•
General PCI address assignments
•
Control and data register address assignments inside the I/O space, as follows:
–
Assignments for a control and data register map
–
Assignments for bits of a special interrupt control/status register, including an example
scenario showing how the bits are used
•
Some general requirements for manipulating control and data registers
•
Reuse of an existing port I/O application program with the KPCI-PIO32IOA or
KPCI-PDISO8A board
General PCI address assignments
The PCI specification allows each PCI-bus board to be assigned up to five distinct address
regions for general use at the discretion of the hardware designer. The first region, at base
address BADDR0, is mandatory per the PCI specification, as published by the PCI Special
Interest Group (PCISIG). The other four address regions, located at base addresses BADDR1,
BADDR2, BADDR3, and BADDR4, are optional. The PCI BIOS or the Plug and Play operating
system automatically allocates BADDR0 through BADDR4 at power-up, based on the PCI
boards that it finds installed at that time. After power-up, computer software can read PCI
configuration space to determine the location of BADDR0 through BADDR4. (The term
“computer software” hereafter in
refers to the combination of the application
programming interface (API)/driver—normally, DriverLINX—and the application program. For
information about application programming through DriverLINX, refer to your DriverLINX
documentation.)
The KPCI-PIO32IOA and KPCI-PDISO8A use both BADDR0 and BADDR1 mapped in I/O
and memory space, respectively.
Содержание KPCI-PIO32IOA
Страница 11: ...1 Overview...
Страница 14: ...2 General Description...
Страница 17: ...3 Installation...
Страница 32: ...4 External Interrupts...
Страница 36: ...5 Troubleshooting...
Страница 52: ...A Specifications...
Страница 57: ...B I O Address Mapping...
Страница 64: ...C Glossary...