"If I have seen further, it is by standing on the shoulders of giants."
-Sir Isaac Newton
Disclaimer
This document defines how the PCI Local Bus Rev. 2.3 specification is implemented in the AmigaPCI. It is not a substitute for the PCI Local Bus Specification or relevant Motorola user manuals. It is expected the reader has reviewed and understands the tenants of the PCI Bus as defined in the PCI Local Bus Specification, Rev 2.3, and the relevant Motorola user manuals.
This document is a work in progress and is presented "as-is" with no waranty expressed or implied.
**THIS DOCUMENT IS A WORK IN PROGRESS AND IS SUBJECT TO CHANGE WITHOUT NOTICE.**
Conventions
- Signals are presented as bold font, such as _FRAME or _TA.
- A leading underscore (_) is used to indicate a signal is active low.
- Examples of bus data are italicized, such as DATA0 or ADDRESS1.
- A bus's most significant bit will be listed first and least significant last. For example, [31..0] indicates bit 31 as the most significant bit. Zero is the least. Thus, [31..0] indicates a little endian device. The opposite will be true for a big endian device.
- Hex values are presented with a leading $ (dollar sign) and a space inserted every 4 characters for clarity.
- AmigaPCI refers to this specification or any implementation of this specification, in part or whole.
- CPU refers to the Motorola MC68040 or MC68060 processor, unless otherwise specified.
Revision History
Revision | Date | Status |
---|---|---|
0.0 | June 1, 2024 | FIRST DRAFT |
0.1 | June 3, 2024 | Fixed(?) Endianness Discussion |
AmigaPCI PCI Hardware Developer Reference by Jason Neus is licensed under Creative Commons Attribution-NonCommercial 4.0 International
The PCI Local Bus (PCI, herein) is a processor independent, 32-bit expasion bus. The AmigaPCI specification is designed to comply with the PCI Local Bus Revision 2.3 specificiation. Each slot supports Universal and 5V cards, as defined in the PCI Local Bus Revision 2.3 specification. Like Zorro 2 and Zorro 3, PCI supports auto configuration of devices on power up. This allows for the use of Amiga AUTOCONFIG to configure devices at start up. This fits well with Amiga OS as PCI devices can be configured as Zorro 3 devices, which function natively with Amiga OS.
The PCI Bridge is implemented via a Motorola MC68040/MC68060 to PCI Bridge (Local PCI Bridge, herein). The Local PCI Bridge logic translates data requests from the Motorola processor and PCI devices in order that they may communicate. This specification is compatable with Motorola MC68040 and newer predecessors. While this document is written with the Motorola MC68040 in mind, the information can be applied to newer Motorola processors, such as the MC68060.
Each PCI slot on the PCI Local Bridge can operate in either AUTOCONFIG mode or Prometheus mode, but not both simultaneously.
Motorola MC68000 series processors are big endian devices. PCI devices, by contrast, are little endian devices. This means we must byte swap the data signals to provide compatability between devices with different endianness*. The AmigaPCI specification implements address invariance to achieve the endian conversion necessary for the CPU and PCI devices to communicate.
Table 1.1a. Order of byte consumption in big and little endian devices.
Endianess | Hex Value Order of Consumption |
---|---|
$0002 0804 | |
Big | START----> |
Little | <----START |
The smallest unit of data considered by the PCI specification is one byte. With this consideration, data bytes are swapped to accomodate the conversion in endianess. This byte swapping is implemented in the AmigaPCI Local PCI Bridge hardware.
Table 1.1b. Byte swapping between big and little endian devices.
Endianess | Hex Value | Address $00 | Address $01 | Address $02 | Address $03 |
---|---|---|---|---|---|
Big | $0002 0804 | $00 | $02 | $08 | $04 |
Little | $0408 0200 | $04 | $08 | $02 | $00 |
*Application Note AN2285. Data Movement Between Big-Endian and Little-Endian Devices. Rev 2.2. Freescale Semiconductor. 2008
Each PCI slot has four interrupt signals, identified as _INTA, _INTB, _INTC, and _INTD. Single function PCI devices are only allowed to use _INTA. The remaining signals are used in the event of a multifunction PCI device, with one interrupt line per PCI function. As a hyptothetical example, a multifunction I/O device may use _INTA for a floppy drive interface, _INTB for a hard drive interface, _INTC for a serial interface, etc. For the purposes of the AmigaPCI design, _INTA, _INTB, _INTC, and _INTD are OR'd together and connected to _INT2. Drivers are expected to look for assertion of _INT2 to signal an interrupt request from devices on the PCI bus. When an interrupt is asserted, the driver needs to poll its device on the PCI bus to determine if its device is asserting the interrupt. The Local PCI Bridge will continue to assert _INT2 until all PCI devices have negated their interrupt requests.
Amiga PCI slots can operate in AUTOCONFIG mode or Prometheus compatable mode. Each individual PCI slot may operate in one of these modes, but never both simultaneously.
In AUTOCONFIG mode, the PCI target device will be configured on startup like any Amiga AUTOCONFIG device. The advantage of AUTOCONFIG mode is the ability to use a PCI device upon startup without the need to load drivers from disk. This supports devices such as auto booting hard drives, video, sound cards, etc. Once the PCI target device is configured by the AUTOCONFIG process, the target device may be directly accessed by its base address(es).
Prometheus mode requires the PCI target device be configured in software in order to function. This mode can support PCI target devices not designed for the Amiga. During startup, the Local PCI Bridge is configured via AUTOCONFIG in the 32-bit Zorro 3 address space, which will supply a base address for the Local PCI Bridge through which the slots in Prometheus mode may be accessed. Driver software may then poll the Local PCI Bridge base address with each device selection bit. The Local PCI bridge will return $FFFF FFFF if an AUTOCONFIG slot is polled via the Local PCI Bridge base address.
New PCI hardware developed specifically for the AmigaPCI should be based on specifications for the Universal* PCI card. Should demand justify it, future upgrade options may include the move to a 3.3V signaling environment capable of running at 66MHz**. Plug in hardware based on the Universal concept will permit cards to work in either 5V or 3.3V signaling environments. In addition, any hardware developed for the AmigaPCI must limit address spaces to Memory and Configuration only. The I/O address space is not recommended for new hardware development*** and is not supported by the AmigaPCI with AUTOCONFIG devices.
*PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 4.1.1. Transition Road Map. pp. 113.
**PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 7.6.3. Signaling Environment. pp. 230.
***PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 3.2.2. Addressing. pp. 27.
Each PCI target device may be configured by the Amiga AUTOCONFIG process or by software configuration (Prometheus). During configuration, each PCI slot in turn, is polled to obtain the capabilities and address space needs of the target device. Each PCI slot is polled by asserting the IDSEL signal, which is approximately equivalent to the _CFGIN signal of the Zorro bus. However, unlike the _CFGIN signal, the IDSEL is asserted by a specific address bit during the address phase of a configuration command access*. Because the Local PCI Bridge addresses each slot directly, as opposed to the fall through system of Zorro, there is no equivalent, or need, of a _CFGOUT signal.
*PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 3.2.2.3.5. System Generation of IDSEL. pp. 36-37.
The Local PCI Bridge is always configured via the AUTOCONFIG process at startup before other PCI devices. The Local PCI Bridge base address allows direct access of the Local PCI Bridge configuration registers and a means to access Prometheus configured PCI cards on the PCI bus (See 2.3 Prometheus Configuration). All PCI devices are accessed through the Local PCI Bridge, which acts as an interface between the devices on the CPU bus and devices on the PCI bus. The Local PCI Bridge also handles bus arbitration. During each CPU data transfer cycle, the address information is broadcast by the Local PCI Bridge to the PCI bus. If any devices respond by asserting _DEVSEL, the Local PCI Bridge proceeds with the PCI cycle. Otherwise, the Local PCI Bridge returns to an idle state.
The following 16-bit registers are available on the Local PCI Bridge device. All registers can be read. This allows polling of the Local PCI Bridge settings and status. Reading a long word at offset $04 will return both registers. Accessing the registers from the MC68040 will result in big endian ordering of the bytes. Accessing the registers from the PCI bus will result in little endian ordering. Reads from unsupported registers will return 0. Registers are not user configurable.
Table 2.1a. Local PCI Bridge Status Register.
Little Endian Bit | Big Endian Bit | Description | Supported by Local PCI Bridge Device |
---|---|---|---|
31 | 7 | Detected Parity Error | Yes |
30 | 6 | Signaled System Error | Yes |
29 | 5 | Received Master Abort | Yes |
28 | 4 | Received Target Abort | Yes |
27 | 3 | Signaled Target Abort | No |
26-25 | 2-1 | DEVSEL Timing | No |
24 | 0 | Master Data Parity Error | Yes |
23 | 15 | Fast Back-to-Back Capable | No |
22 | 14 | Reserved | No |
21 | 13 | 66 MHz Capable | No |
20 | 12 | Capabilties | No |
19 | 11 | Interrupt Status | Yes |
18-16 | 10-8 | Reserved | No |
Table 2.1b. Local PCI Bridge Command Register.
Little Endian Bit | Big Endian Bit | Description | Default Value |
---|---|---|---|
15-11 | 23-19 | Reserved | 0 |
10 | 18 | Interrupt Disable | 0 |
9 | 17 | Fast Back-to-Back Enable | 0 |
8 | 16 | _SERR Enable | 1 |
7 | 31 | Reserved | 0 |
6 | 30 | Parity Error Response | 1 |
5 | 29 | VGA Palette Snoop | 0 |
4 | 28 | Memory Write and Invalidate Enable | 0 |
3 | 27 | Special Cycles | 0 |
2 | 26 | Bus Master | 0 |
1 | 25 | Memory Space | 1 |
0 | 24 | I/O Space | 0 |
PCI cards designed specifically with support for the AmigaPCI will be configured via the AUTOCONFIG process at startup. AUTOCONFIG slots will be configured by the Local PCI Bridge in the 32-bit Zorro 3 address space.
NOTE: A Type 0 configuration transaction is used to access a device on the current bus segment and a Type 1 configuration transaction is used to access a device that resides behind another bridge on the bus. For example, a daughter card plugged into a PCI slot can supply additional PCI slots via a bridge on the daughter card. A Type 0 configuration transaction is not forwarded across a bridge but is used to configure a bridge or other PCI devices that are connected to the PCI bus on which the Type 0 configuration transaction is generated*.
*PCI-to-PCI Bridge Architecture Specification Revision 1.1. PCI Special Interest Group. Section 3.1. Overview of Hierarchical Configuration. pp. 19.
During configuration, specifications such as the device manufacturer, product number, device capabilities, etc, are read from the device. Each PCI device is capable of supporting up to six base address registers (BAR0 - BAR5, between $10 - $24 in the configuration register). The required address space for each of the six possible registers are determined and presented to Amiga OS for assigning of base addresses in the 32-bit Zorro 3 address space. This is done through the normal Zorro 3 AUTOCONFIG procedure. As an example, if BAR0 requests 512k of configuration space, this request will be passed to Amiga OS as a Zorro 3 device requiring 512k of AUTOCONFIG space. Amiga OS will then assign a base address to this request. This assigned base address will be programmed into BAR0 of the target PCI device. This process repeats for BAR1 - BAR5 of the same PCI device. This procedure is then repeated for each PCI device installed. Once complete, each PCI device may be accessed by the assigned base address(es), just as any other AUTOCONFIG device. PCI target devices configured by the AUTOCONFIG process may only access memory and configuration spaces. Use of the I/O space is not recommended for new PCI designs* and is not supported.
NOTE: PCI allows for 16-bit Product ID's. Amiga OS supports 8-bit Product ID's. The Product ID should be stored in the most significant byte of the least significant word of the Device ID field. Remember, PCI is little endian! So, this is bits 23 - 16 of register $00.
*PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 3.2.2. Addressing. pp. 27.
PCI devices may have onboard ROMs that enhance functionality, such as for auto booting. PCI ROMs may contain multiple images that support multiple architectures. During PCI configuration, the ROM address requirement is read from the PCI configuration header. This is then presented to the AUTOCONFIG process as a 16-bit ROM Vector, which is an offset from the base address where the ROM will respond. The Expansion ROM Base Address register is a 32-bit long word. Of these 32 bits, 10-0 are reserved. Of the remaining bits, Amiga OS can access bits 15-11. This allows ROM Vectors in the range of $0800 to $8000.
NOTE: PCI allows for 32-bit ROM Vectors (ROM Base Address). Amiga OS supports 16-bit ROM Vectors. The ROM vector should be stored in the most significant bits of the Rom Base Address register. Remember, PCI is little endian! So, this is bits 15 - 0 of register $30.
PCI defines multiple address spaces that exist in parallel. PCI command encodings select a specific address space for the current cycle. PCI devices added by the AUTOCONFIG process may be accessed in memory or configuration spaces. Each device is accessed via the assigned base address with the command type determined by sampling the R_W, UPA0, and UPA1 signals. For example, you can access the Configuration Type 0 space of an AUTOCONFIG PCI device by driving the base address on the CPU address bus and setting UPA0 = 1 and UPA1 = 0. The Local PCI Bridge will interpret this as a Configuration Type 0 command and set the C/BE[3..0] bits accordingly. UPA0 and UPA1 are driven by the user defined U0 and U1 user page attributes when an external bus transfer occurs. The UPA1 and UPA0 signals are not implemented in other Amiga architectures and developers may not be familiar with them. The Motorola MC68040 or MC68060 user manual should be reviewed for better understanding of these signals.
Table 2.2.3a. PCI Commands for AUTOCONFIG Devices.
R_W | UPA0 | UPA1 | PCI Command |
---|---|---|---|
1 | 0 | 0 | Memory Space Read |
0 | 0 | 0 | Memory Space Write |
1 | 1 | 0 | Configuration Type 0 Space Read |
0 | 1 | 0 | Configuration Type 0 Space Write |
1 | 0 | 1 | Configuration Type 1 Space Read |
0 | 0 | 1 | Configuration Type 1 Space Write |
- | 1 | 1 | Reserved |
During the AUTOCONFIG process, up to 21 AUTOCONFIG capable PCI device slots may be addressed by the Local PCI Bridge, although the AmigaPCI has only five. During the configuration access, the Local PCI Bridge asserts IDSEL with one of 21 address bits, A[31..11]. Once the device has been configured, the device should only be accessed through its AUTOCONFIG assigned base address. Shown below is the list of possible AmigaPCI slot IDSEL addresses. This list maintains compatability with Prometheus* IDSEL addresses while allowing for expansion in the number of slots in new system designs.
Examples:
- Applying address $0200 0000 will enable IDSEL of the card in slot 9.
- Applying address $8000 0000 will enable IDSEL of the card in slot 15.
Table 2.2.3a. AUTOCONFIG Capable Slots.
PCI Slot | Address Bit | Offset | Prometheus Compatable |
---|---|---|---|
0 | AD[16] | $0001 0000 | Yes |
1 | AD[17] | $0002 0000 | Yes |
2 | AD[18] | $0004 0000 | Yes |
3 | AD[19] | $0008 0000 | Yes |
4 | AD[20] | $0010 0000 | No |
5 | AD[21] | $0020 0000 | No |
6 | AD[22] | $0040 0000 | No |
7 | AD[23] | $0080 0000 | No |
8 | AD[24] | $0100 0000 | No |
9 | AD[25] | $0200 0000 | No |
10 | AD[26] | $0400 0000 | No |
11 | AD[27] | $0800 0000 | No |
12 | AD[28] | $1000 0000 | No |
13 | AD[29] | $2000 0000 | No |
14 | AD[30] | $4000 0000 | No |
15 | AD[31] | $8000 0000 | No |
16 | AD[11] | $0000 0800 | No |
17 | AD[12] | $0000 1000 | No |
18 | AD[13] | $0000 2000 | No |
19 | AD[14] | $0000 4000 | No |
20 | AD[15] | $0000 8000 | No |
*Prometheus daughter cards historically have 4 PCI Local Bus slots. It is assumed drivers designed for Prometheus will only search for devices at offsets $0001 0000 - $0008 0000.
The AmigaPCI aims to maintain a high level of compatabitly with Prometheus drivers. However, Prometheus implements non-standard PCI bridge registers. This means some drivers may need modification to work with the AmigaPCI. PCI devices not supporting AUTOCONFIG should be installed in a Prometheus configuration slot. Each slot designated as a Prometheus configuration slot may be accessed through the base address of the Local PCI Bridge, which is always configured by AUTOCONFIG at startup. Each slot on the PCI bus may be addressed individually by its offset value to read or write from that device's configuration register. To maintain compatability with existing Prometheus drivers, the system must support IDSEL on four slots driven by A[19..16]. These four slots also support AUTOCONFIG. Up to 17 additional slots may be added to support AUTOCONFIG only devices. See 2.2 AUTOCONFIG PCI Slots.
For a full understanding of intefacing Prometheus enabled devices, documentation of the Prometheus firmware should be reviewed.
Examples, assuming the PCI Local Bridge base address is $6000 0000:
- Applying address $6001 0000 will enable IDSEL of the card in slot 0.
- Applying address $6008 0000 will enable IDSEL of the card in slot 3.
Table 2.3a. Address Offset of PCI Slots For IDSEL.
PCI Slot | Address Bit | Offset From Base Address |
---|---|---|
0 | AD[16] | $0001 0000 |
1 | AD[17] | $0002 0000 |
2 | AD[18] | $0004 0000 |
3 | AD[19] | $0008 0000 |
Direct bus* access is available to the CPU and PCI devices via bus mastering. When a device has mastered the bus, it has control of the entire AmigaPCI system and may directly access any valid address location. This is typically done for direct reading and writing of memory (DMA) or direct control of chipset or other functions. The AmigaPCI bus arbiter accepts bus requests from the CPU and each device on the PCI bus. Each slot on the PCI bus has a dedicated bus request signal. The bus arbiter implements a fairness protocol to prevent a single device from owning the bus for extended lengths of time. When there is no pending bus request, the CPU is given implicit ownership of the bus (_BG is asserted with _BB held in a high impedence state) until it the CPU begins a bus cycle or a bus request from a PCI device is granted.
*In this discussion, "bus" is a term for the data, address, and AD buses, collectively, of the Amiga.
Unlike previous Motorola MC68000 series processors, the Motorola MC68040 does not preferentially own the bus. It is considered for bus access with all other bus mastering devices on the system. Thus, bus arbitration includes consideration for the CPU when assigning bus ownership. When it is ready to take ownership of the system bus the CPU will assert _BR (bus request) to indicate its need to own the system bus. When there are no current bus cycles in progress, the arbiter will assert _BG (bus grant) in response so that the CPU may begin its bus activities. Once _BG is asserted by the arbiter, the CPU will assert _BB (bus busy) to indicate ownership of the bus. _BG is asserted until the CPU bus access is complete, indicated by negation of _BR. While posessing explicit ownership of the bus, the CPU may start a bus cycle at any time by asserting _BB. The CPU is granted implicit ownership of the bus when no other device is requesting, or has been granted, bus ownership. During implicit ownership of the bus, the CPU leaves the bus in an undefined state, while _BG is asserted, _BR is negated, and _BB is tri-state.
CPU access to PCI target devices supports burst (MOVE16) and non-burst (normal) cycles in read and write modes. The PCI and CPU busses operate at different clock rates. This raises concerns about metastability and honoring setup and hold times for data transfers. In order to account for these concerns, the AmigaPCI Local Bridge implements a FIFO approach. FIFO allows clock domain crossing supporting the quickest release of the CPU, shortening cycle times.
When a data transfer cycle is initiated by the CPU, the Local PCI Bridge broadcasts the address and related bus command to the PCI bus. If a target device responds by asserting _DEVSEL within two PCI clock cycles, the Local PCI Bridge completes the transfer. If no device asserts _DEVSEL by the second falling edge of the PCI clock, the Local PCI Bridge returns to an idle state. See Master Terminated, Section 8.2.
A normal mode transfer is capable of moving byte, word, or long word data. The data size to be transfered is determined from A[1..0] and the SIZ0 and SIZ1 CPU signals. That information is used to drive the correct byte enables on C/BE[3..0] during the data transfer.
A burst mode is defined as a line transfer initiated by the CPU with the MOVE16 instruction*. This results in the burst transfer of four long words to or from the target device. Each long word being aligned to a 16-byte memory boundary. During CPU initiated burst transfers, all four bytes are enabled. The PCI target device must internally increment A3 and A2 of the supplied address for each transfer, causing the address to wrap around at the end of the block. This is consistent with the Cacheline Wrap Mode burst order defined in the PCI specifications**.
*Motorola MC68040 User Manual. Motorola. Sections 7.4.2 Line Read Transfer and 7.4.4 Line Write Transfers. **PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Table 3-2. Burst Ordering Encoding. pp. 29.
A DMA cycle is defined as a PCI device taking control of the system bus of the AmigaPCI during normal bus arbritration. The PCI device owning the bus may access any valid address space of the AmigaPCI, including other devices on the PCI bus. When accessing memory spaces of the AmigaPCI, only memory space PCI commands are allowed.
When a PCI device wants to take ownership of the system bus, it will assert _REQx, where x is the slot designation of the device. Once the arbiter has granted the bus to the requesting PCI device, the arbiter will assert _GNTx and _BB to indicate a bus operation is in progress, allowing the requesting PCI device to take ownership of the bus and begin the data transfer cycle. The PCI device should never start a DMA cycle until it has been granted exclusive bus access by assertion of the relevant _GNTx signal. _BB will remain asserted while either the PCI bus or CPU bus remains active in the current cycle.
During DMA cycles, the cycle is directed by the initiating PCI device. The Local PCI Bridge is responsible for driving MC68040 compatable signals on the CPU bus to support the current cycle. These signals are _TS, _TIP, R_W, TT0, TT1, SIZ0, SIZ1, A[31..0], and D[0..31] (write cycle only). When not actively driving a DMA cycle on the CPU bus, these Local Bridge holds these signals in a high impedence state. The Local PCI Bridge must respond to the assertion of _TA in order to recognize when data is placed on D[0..31] for read cycles, or when data has been latched by the target device for write cycles. Unless actively driving a DMA cycle against onboard AmigaPCI resources, AD[31..0], _TRDY, _DEVSEL must be held in a high impedence state by the Local PCI Bridge during DMA cycles.
The Local PCI Bridge will assert TT0 and TT1, as required, in response to a normal or burst transfer request from the PCI initiating device. The assertion of transfer type (TT0 and TT1) is determined by whether _FRAME is held asserted after the address phase of the current cycle. If _FRAME is negated on the first rising PCI clock edge after the address phase, this is a normal cycle. If _FRAME is held asserted on the first rising PCI clock edge after the address phase, this is a burst cycle. This means the Local PCI Bridge cannot set TT0 and TT1 until the first falling BCLK edge after the first rising PCLK edge after the cycle address phase.
It must be considered that the PCI bus clock and the MC68040 bus clocks are asynchronous. If not handled correctly, this can lead to a condition where the devices become out of sync. This will result in data transfer errors. While PCI initiator devices may, or may not, insert wait states, we must consider this possiblity as wait states are defined in the PCI specification for all cycle types. Synchronozation of the bus clocks is acheived by the PCI Local Bridge implementing a FIFO approach. Data is latched into a register in one clock domain and passed out to the other clock domain at the appropriate timings.
The PCI cycle can end in several ways and may be terminated by the Local PCI Bridge or target device.
This condition is asserted when the master device has completed the intended transaction without error. This terminiation condition is signaled by negating _FRAME while _IRDY is asserted.
This condition exists when no target device responds to the address phase of a PCI cycle. Normally, a PCI Target Device will claim the cycle by asserting the _DEVSEL signal in response to the address phase of the cycle. If no device claims the cycle, it is assumed to be the absence of a target device with a matching base address, rather than a bus error. The Local PCI Bridge will return to an idle state. No signals are asserted in response to this condition.
This condition is signaled when the target device asserts _STOP after claiming the cycle, by asserting _DEVSEL, before data has been transfered. When the target device asserts the retry condition, the Local PCI Bridge will assert _TA and _TEA together, which signals the CPU to immediately abort and retry the cycle.
This condition is signaled when the target device asserts _STOP while _TRDY is asserted. The Disconnect condition is different from the Retry condition in that Disconnect is asserted after some data has already been transfered, but the target device is unable to continue transferring the requested data. When this condition exists, the Local PCI Bridge will assert _TEA. This indicates to the CPU that an error condition exists and the cycle cannot continue. This condition can only exist for burst cycles.
This condition can exist any time after a target device has asserted _DEVSEL and is signaled when the target device asserts _STOP and negates _DEVSEL simultaneously. This is considered an abnormal termination in that the target device will never be able to supply to requested data. When this condition exists, the Local PCI Bridge will assert _TEA. This indicates to the CPU that an error condition exists and the cycle cannot continue. This condition may occur for both burst and normal cycles. This condition is treated the same as the Target Terminated - Disconnect condition by the CPU (Section X.X.X). See Figure X.X.X for example timing.
Add something here. This is timeout during DMA situations.
Data transfer cycle errors are detected using an even parity system. Except for video and HID devices, all PCI devices are required to support parity*. Even parity is generated by the initiating device and PAR is valid one clock after the associated address or data block. The target device determines even parity on the data received and compares the calculated value to PAR. Even parity is set when the number of set bits on AD[31..0], C/BE[3..0], and PAR is an even number. Parity error conditions are expected to be reported through the device driver whenever possible**. The reporting chain of target to bus master to driver to operating system enables recovery options at every level. The information below specifically explains how the Local PCI Bridge of the AmigaPCI handles parity errors.
*PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 3.7.2. Parity Checking. pp. 95.
**PCI Local Bus Specification Revision 2.3. PCI Special Interest Group. Section 3.7.4. Error Reporting. pp. 95.
An address parity error occurs when a parity mismatch is detected during the address phase of the PCI cycle and is generally considered a fatal condition. When a target device detects an address parity error, it will set the Detected Parity Error bit (Status register, bit 15). If the Parity Error Response bit is set (Command Register, bit 6), the target device will assert _PERR. If the _SERR Enable bit is set (Command Register, bit 8), the System Error Bit is set (Command Register, bit 8).
When a parity mismatch occurs during the address phase, one of three things can happen:
- A device, possibly an unintended target, claims the transaction and proceeds as normal.
- A device, possibly an unintended target, claims the transaction and terminates with a Target-Abort.
- No target device claims the transaction and the cycle will time out with a Master-Abort.
The Local PCI Bridge considers two back-to-back address parity errors to be a fatal condition. In the event of an address parity error during a CPU driven data transfer cycle, the Local PCI Bridge will request the MC68040 retry the cycle one time. In the case of a second address parity error, if the _SERR Enable bit is set (Command Register, bit 8), the Local PCI Bridge will set the Signaled System Error bit (Status Register, bit 14). This is a signal to drivers that a fatal condition exists within the PCI bus and efforts should be made to save any needed data, cease accessing the PCI bus, and warn the user. Once in a fatal condition, the Local PCI Bridge will return $FFFF FFFF for all reads and writes will have no effect. Once set, the Signaled System Error bit will remain set until a system reset.
Note: During CPU driven cycles, the PCI device is the target device. During DMA cycles, the Local PCI Bridge or other PCI device is the target device.
A data parity error occurs when there is a parity mismatch during the data phase of the cycle. Data parity is calculated on all data blocks except during special cycles. When the target device detects a data parity error, it will set the Detected Parity Error bit (Status register, bit 15). If the Parity Error Response bit is set (Command Register, bit 6), it will assert _PERR. In response to the assertion of _PERR, the Local PCI Bridge will assert _INT2 and set the Interrupt Status bit (Status Register, Bit 3), indicating the interrupt is generated from a device on the PCI bus. PCI drivers are expected to respond to this interrupt and poll their device's Parity Error Bit. The driver should clear the interrupt from the device and retry the transfer cycle. If an excessive number of parity errors occur, the driver should attempt to gracefully disconnect (cease using) the device with a user warning. All efforts should be made to save the user session. Failure to do so will likely result in a system crash and possibly lost data.
Note: During CPU driven cycles, the PCI device is the target device. During DMA cycles, the Local PCI Bridge or other PCI device is the target device.
END