

# **SPC Specification**

Version 1.0 Technical Report ARL-98-01 Janurary 8, 1998

> by: William Eatherton Toshiya Aramaki

Applied Research Laboratory Washington University

# DRAFT

# **1 INTRODUCTION**

- 2 Requirements of Target Applications
- **3** SPC Architecture

## 3.1 Overview



1. At power up or after a hard reset, the signal PWROK transitions (via analog reset circuitry) from deasserted to asserted. The PWROK signal enters the System FPGA chip. Initially the System FPGA outputs are all tristated (the reset lines it drives will be pulled down). When the board powers up, the FPGA will download its design from a serial eprom and then "turn on" its pads. When the PWROK signal is

RAFT

3

detected as asserted the system FPGA will with appropriate timing deassert the CPU and PCI reset signals.

- 2. Pentium does internal initialization and then does a memory read from address 0xfffffff0. At reset, the North Bridge chip has this memory area marked as disabled so read is passed to PCI bus.
- 3. The system FPGA will have this address hardwired as a decode to its embedded BIOS ROM. The first word of the bios is read out onto the PCI bus and passed to the CPU.
- 4. The CPU executes this instruction, which is usually a jump to the top half of the normal BIOS memory space 0xffff0000 (since we are 16 bytes from the end of memory).
- 5. The only POST check the BIOS will do is a memory check, where each physical memory address is written and read. When done, the results of the test will be written into a register of the FPGA.
- 6. The BIOS code at this point has the CPU do a simple 1000 iteration loop within an infinite loop that exits when a register in the System FPGA equals a non zero value(which is inited to zero at power up).
- 7. At some point the appropriate control processor (CP) which knows the control VCI of the APIC on the SPC under discussion, will start sending said APIC control cells.
- 8. First the CP processor has the APIC fetch the memory POST test results from the FPGA and send it back. If the test failed the CP processor halts OS loading.
- 9. Next the CP sets up the global APIC registers via control cells.
- 10. Then the CP has the APIC write a Rx descriptor starting a location 0x00000000. It describes an AAL5 packet splitting receive buffer 64Kbyes long at some set location in memory. Then descriptors are written for additional 64K buffers that will adequately hold the kernel. Finally, the CP resumes the connection and the APIC fetches the first descriptor
- 11. The CP then sends the first 64KB of the NetBSD OS as an AAL5 frame, when the RX buffer is full the APIC fetches the next descriptor until the entire OS (new boot loader code, kernel, and application) has been loaded into one contiguous block of memory. The remote control processor then reads all the returned descriptors and checks that the CRC values are correct.
- 12. At this point the DONE register in the system FPGA will be set to a non-zero value, and the next time the CPU checks the register it will jump out of its loop to the beginning of the OS code which will be the "newbootloader".
- 13.. the "newbootloader" does several BIOS emulation tasks: it writes a few parameters to the BIOS data area (Memory size, the time and date from the RTC), inits the interrupt table, enables the APIC and writes its base address for



slave access.

- 14. One the BIOS emulation tasks of the "newbootloader" is done, it executes the kernel (passing in the boot flags [i.e. single user boot, etc.]).
- 15. the kernel inits memory management, then inits devices. The kernel does not use any BIOS functions, but does access the BIOS data area left by the emulated bios.

## 3.2 Intel Embedded Module



## 3.3 System FPGA

#### 3.3.1 Overview





## 3.3.2 External Interface



(\*):These pins are assined but they are always disable.

 $(\ensuremath{\,^{\star\star}})\xspace$  ):These pins are assined but any functions are not implimented .



RAF

DRAFT

## 3.3.3 Block Diagram



#### 3.3.4 Pin Descriptions

| Signal             | Count                                          | Direction | Description                      |  |  |
|--------------------|------------------------------------------------|-----------|----------------------------------|--|--|
| PCI Interface Sign | PCI Interface Signals for both PCI32 and PCI64 |           |                                  |  |  |
| PCICLK             | 1                                              | Ι         | PCI Cock Input (0-33 Mhz)        |  |  |
| MAD(31:0)          | 32                                             | I/O       | Multiplexed Address/Data Bus     |  |  |
| CBE_L(3:0)         | 4                                              | I/O       | Command / Byte Enables           |  |  |
| FRAME_L            | 1                                              | I/O       | Cycle Frame                      |  |  |
| IRDY_L             | 1                                              | I/O       | Initiator Ready                  |  |  |
| TRDY_L             | 1                                              | I/O       | Target Ready                     |  |  |
| STOP_L             | 1                                              | I/O       | Stop indicator                   |  |  |
| DEVSEL_L           | 1                                              | I/O       | Device Select                    |  |  |
| LOCK_L             | 1                                              | Ι         | Bus Lock                         |  |  |
| PERR_L             | 1                                              | I/O       | Parity Error                     |  |  |
| IDSEL_L            | 1                                              | Ι         | Select for Config Space Accesses |  |  |
| PAR                | 1                                              | I/O       | Parity over PCI32                |  |  |
| Interrupt          |                                                |           |                                  |  |  |





| INTR10CPU InterruptNMI10Non Maskable InterruptSERR_L11PCI System errorAPIC_INT_L11PCI Interrupt from APICEF_INT_L10PCI Interrupt from Experimental FPGAUAR1_INT1IUARTI(COM1) interruptUAR1_INT1IUARTI(COM1) interruptRESETI0CPU RSTPWROK1IPower OKCPURST_L10PCI RSTPCIRST_L10PCI RSTPCIRST_L10PCI RSTPTIST_L10PCI RSTPCIRST_L10PCI RSTPCIRST_L10Experimental on Unlike a CPURST, the caches, write<br>buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation-FCA Configuration (Pin Experimental FPGA configuration dataClockEF_DIN10Experimental FPGA configuration dataEF_CCLK1IExperimental FPGA configuration dataEF_LOCK1IExperimental FPGA configuration stausEF_INIT1IExperimental FP                                         | Signal           | Count       | Direction      | Description                                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|----------------|------------------------------------------------------|
| SERR_L1IPCI System errorAPIC_INT_L1IPCI Interrupt from APICEF_INT_L10PCI Interrupt from Experimental FPGAUAR1_INT1IUART1(COM1) interruptUAR1_INT1IUART1(COM1) interruptRESETI0CPU RSTPWROK1IPower OKCPURST10CPU RSTPCIRST_L10PCI RSTINIT10PCI RSTINIT10PCI RSTPEFOR10Experimental FPGA configuration is put off.)EF_DIN10Experimental FPGA configuration dataEF_CLK10Experimental FPGA configuration dataEF_PROGRAM10Experimental FPGA configuration dataEF_DIN11Experimental FPGA configuration dataEF_DONE11Experimental FPGA configuration dataEF_DONE11Experimental FPGA configuration statusEF_INIT11Experimental FPGA configuration statusEF_INIT11Experimental FPGA configuration statusEF_INIT10Chip Select.UART_CS10Chip Select.UART_CHSL10Chip Select.UART_ADDR20Register SelectUART_ADDR10Master ResetUART_RD_L10Master read                                                                                                                                                                             | INTR             | 1           | 0              | CPU Interrupt                                        |
| APIC_INT_L1IPCI Interrupt from APICEF_INT_L10PCI Interrupt from Experimental FPGAUAR1_INT1IUART1(COM1) interruptUAR1_INT1IUART1(COM1) interruptRESETI0CPU RSTPWROK1IPower OKCPURST10PCI RSTPIRST_L10PCI RSTINIT10PCI RSTINIT10PCI RSTINIT10Experimental FPGA configuration dataEF_DIN10Experimental FPGA configuration dataEF_CLK10Experimental FPGA configuration dataEF_CCLK10Experimental FPGA configuration dataEF_DONE1IExperimental FPGA configuration dataEF_DONE1IExperimental FPGA configuration dataEF_DONE1IExperimental FPGA configuration dataEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration data clockEF_ONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration status                                                              | NMI              | 1           | 0              | Non Maskable Interrupt                               |
| EF_INT_L10PCI Interrupt from Experimental FPGAUAR1_INT1IUART1(COM1) interruptUAR1_INT1IUART1(COM1) interruptRESETIIUART1(COM1) interruptPWROK1IPower OKCPURST1OCPU RSTPCIRST_L1OPCI RSTINIT1OPCI RSTINIT1OExperimental configuration of function is put off.)EF_DIN1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration dataEF_CCLK1IExperimental FPGA configuration dataEF_CCLK1IExperimental FPGA configuration dataEF_DONE1IExperimental FPGA configuration dataEF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_LOCK1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration data clockMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_ADDR1OMaster ResetUART_RD_L1OWART register read <td>SERR_L</td> <td>1</td> <td>Ι</td> <td>PCI System error</td> | SERR_L           | 1           | Ι              | PCI System error                                     |
| UAR1_INTIIUART1(COM1) interruptUAR1_INT1IUART1(COM1) interruptRESETPWROK1IPower OKCPURST1OCPU RSTPCIRST_L1OPCI RSTINIT1OPCI RSTINIT1OExperimentation. Unlike a CPURST, the caches, write buffer, model registers and aloating-point register in Pentium are not reset.Experimentation-FVGA Configuration (Pin exceded sector)EF_DOIN1CPURST1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration dataEF_DONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChannel SelectUART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_ADDR1OMaster ResetUART_RD_L1OUART register read                                                  | APIC_INT_L       | 1           | Ι              | PCI Interrupt from APIC                              |
| LARL_DYIIDefection and primeUAR I_INT1IUART1(COM1) interruptRESETPWROK1IPower OKCPURST1OCPU RSTPCIRST_L1OPCI RSTINIT1OPCI RSTINIT1OExperimentation. Unlike a CPURST, the caches, write<br>in Pentium are not reset.Experimentation-FFGA Configuration (Pin assign only. Implimentation of function is put off.)EF_DIN1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration dataEF_LOCK1IExperimental FPGA configuration dataEF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMain Memory ComparityIIExperimental FPGA configuration error statusMain Memory ComparityIIIUART_CS1OChip Select.UART_CHSL1OChip SelectUART_ADDR2ORegister SelectUART_ADDR1OWaster ResetUART_RD_L1OUART register read                                                                                                                                     | EF_INT_L         | 1           | 0              | PCI Interrupt from Experimental FPGA                 |
| RESETPWROK1IPower OKCPURST1OCPU RSTPCIRST_L1OPCI RSTINIT1OPCI RSTINIT1OInitialization. Unlike a CPURST, the caches, write<br>buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation-FPGA Configuration (Pin assign only. Implimentation of function is put off.)EF_DIN1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration dataEF_LOCK1IExperimental FPGA configuration data clockEF_DNE1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CSL1OChip SelectUART_ADDR2ORegister SelectUART_MR1OUART register read                                                                                                                                                                                        | UAR1_INT         | 1           | Ι              | UART1(COM1) interrupt                                |
| PWROKIIPower OKCPURST1OCPU RSTPCIRST_L1OPCI RSTINIT1OPCI RSTINIT1OInitialization. Unlike a CPURST, the caches, write<br>buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation-FVFA Configuration (Proceed and Configuration of function is put off.)EF_DIN1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration data clockEF_PROGRAM1IExperimental FPGA configuration data clockEF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusEF_INIT1IExperimental FPGA configuration error statusEF_INIT1IExperimental FPGA configuration error statusEF_INIT1IExperimental FPGA configuration error statusEF_INIT1IIMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OUART register read            | UAR1_INT         | 1           | Ι              | UART1(COM1) interrupt                                |
| CPURST1OCPU RSTPCIRST_L1OPCI RSTINIT1OPCI RSTINIT1OInitialization. Unlike a CPURST, the caches, write<br>buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation-FFGA Configuration (Pin exister)Experimental FPGA configuration dataEF_DIN1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration dataEF_CCLK1IExperimental FPGA configuration dataEF_DROGRAM1OExperimental FPGA configuration dataEF_LOCK1IExperimental FPGA configuration data clockEF_DNE1IExperimental FPGA configuration statusEF_DONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChannel Select.UART_CMS1OChannel Select.UART_ADDR2ORegister Select.UART_MR1OWaster ResetUART_RD_L1OWaster read                                                                                                                                                            | RESET            | ·           |                |                                                      |
| PCIRST_L10PCI RSTINIT10PCI RSTINIT10Initialization. Unlike a CPURST, the caches, write<br>buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation-FPGA Configuration (Pin assign only. Implimentation of function is put off.)EF_DIN10EF_CCLK10EF_PROGRAM10EF_LOCK1IEF_LOCK1IEF_DONE1IEF_DONE1IIEF_DONE1IIEF_DONE1IIEF_INIT1IIEF_CCLKIIIIEF_DONEIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII <td>PWROK</td> <td>1</td> <td>Ι</td> <td>Power OK</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PWROK            | 1           | Ι              | Power OK                                             |
| INIT1OInitialization. Unlike a CPURST, the caches, write<br>buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation-FPGA Configuration (Pin are not reset.Experimental FPGA configuration dataEF_DIN1OExperimental FPGA configuration dataEF_CCLK1OExperimental FPGA configuration data clockEF_PROGRAM1IExperimental FPGA configuration data clockEF_LOCK1IExperimental FPGA configuration data clockEF_DNE1IExperimental FPGA configuration data clockEF_DNE1IExperimental FPGA configuration data clockEF_INIT1IExperimental FPGA configuration data clockMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB,<br>10=64MB, 11=128MB.UART_CS1OChip Select.UART_CS1OChip Select.UART_ADDR2ORegister SelectUART_ADDR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                     | CPURST           | 1           | 0              | CPU RST                                              |
| buffer, model registers and aloating-point register<br>in Pentium are not reset.Experimentation of function is put off.)EF_DIN1OExperimental FPGA configuration dataEF_CLK1OExperimental FPGA internal configuration dataEF_PROGRAM1OExperimental FPGA internal configuration dataEF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMemory CorrectorIIIMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB,<br>10=64MB, 11=128MB.UART_CS1OChip Select.UART_CS1OChip Select.UART_ADDR2ORegister SelectUART_ADDR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                        | PCIRST_L         | 1           | 0              | PCI RST                                              |
| EF_DIN10Experimental FPGA configuration dataEF_DIN10Experimental FPGA configuration dataEF_CCLK10Experimental FPGA configuration data clockEF_PROGRAM10Experimental FPGA internal configuration dataEF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMain Memory ConfigurationIIExperimental FPGA configuration error statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CHSL1OChip SelectUART_ADDR20Register SelectUART_MR1OUART register read                                                                                                                                                                                                                                                                                                                                                                | INIT             | 1           | 0              | buffer, model registers and aloating-point register  |
| EF_CCLK1OExperimental FPGA configuration data clockEF_PROGRAM1OExperimental FPGA internal configuration data<br>reset.EF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration data clockEF_INIT1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMain Memory ConfigurationIIExperimental FPGA configuration error statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB,<br>10=64MB, 11=128MB.UART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                 | Experimentation- | FPGA Config | uration (Pin a | assign only. Implimentation of function is put off.) |
| EF_PROGRAM1OExperimental FPGA internal configuration data<br>reset.EF_LOCK1IExperimental FPGA configuration data clockEF_DONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMain Memory ConfigurationIExperimental FPGA configuration error statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | EF_DIN           | 1           | 0              | Experimental FPGA configuration data                 |
| EF_LOCK1IExperimental FPGA configuration data clockEF_LOCK1IExperimental FPGA configuration statusEF_DONE1IExperimental FPGA configuration error statusEF_INIT1IExperimental FPGA configuration error statusMain Memory ConfigurationIExperimental FPGA configuration error statusMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | EF_CCLK          | 1           | 0              | Experimental FPGA configuration data clock           |
| EF_DONE1IExperimental FPGA configuration statusEF_INIT1IExperimental FPGA configuration error statusMain Memory ConfigurationMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.MEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART_CS1OChip Select.UART_CS1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | EF_PROGRAM       | 1           | 0              |                                                      |
| EF_INIT1IExperimental FPGA configuration error statusMain Memory ConfigurationMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART interfaceUART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | EF_LOCK          | 1           | Ι              | Experimental FPGA configuration data clock           |
| Main Memory ConfigurationMEMSIZE2IMain Memory Size. 00=16MB, 01=32MB, 10=64MB, 11=128MB.UART interfaceUART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | EF_DONE          | 1           | Ι              | Experimental FPGA configuration status               |
| MEMSIZE2IMain Memory Size. 00=16MB, 01=32MB,<br>10=64MB, 11=128MB.UART interfaceUART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | EF_INIT          | 1           | Ι              | Experimental FPGA configuration error status         |
| UART interfaceUART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Main Memory Co   | nfiguration | •              |                                                      |
| UART_CS1OChip Select.UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MEMSIZE          | 2           | I              | •                                                    |
| UART_CHSL1OChannel SelectUART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | UART interface   | ·           | ·              |                                                      |
| UART_ADDR2ORegister SelectUART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | UART_CS          | 1           | 0              | Chip Select.                                         |
| UART_MR1OMaster ResetUART_RD_L1OUART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | UART_CHSL        | 1           | 0              | Channel Select                                       |
| UART_RD_L 1 O UART register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | UART_ADDR        | 2           | 0              | Register Select                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | UART_MR          | 1           | 0              | Master Reset                                         |
| UART_WR_L 1 O UART register write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | UART_RD_L        | 1           | 0              | UART register read                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | UART_WR_L        | 1           | 0              | UART register write                                  |



Table 1:

DRAFT

| Signal    | Count | Direction | Description                                                                                                   |
|-----------|-------|-----------|---------------------------------------------------------------------------------------------------------------|
| UART_DATA | 8     | I/O       | Data to/from UART                                                                                             |
|           |       |           |                                                                                                               |
| Misc      |       |           |                                                                                                               |
| A20M      | 1     | I         | Address Bit 20 Mask. When enabled, this causes<br>the processor to emulate the address wraaparound<br>at 1MB. |
| 12MKBCLK  | 1     | I         | 12MHz Clock. This clock is not used in the Sytem FPGA.                                                        |
| 14MREFCLK | 1     | I         | 14.318MHz Clock. This clock is not used in the Sytem FPGA.                                                    |
| 24MIOCLK  | 1     | I         | 24MHz Clock. This clock is not used in the Sytem FPGA.                                                        |
| FERR_L    | 1     | I         | Numeric Coprocessor Error. This signal is not used in the Sysytem FPGA                                        |
| IGNNE_L   | 1     | 0         | Ignore Error. Always disable.                                                                                 |
| SMI_L     | 1     | 0         | System Management Interrupt. Always disable.                                                                  |
| STPCLK_L  | 1     | 0         | Stop Clock. Always disable.                                                                                   |
|           |       |           |                                                                                                               |
|           |       |           |                                                                                                               |



Table 1:

#### 3.3.5 Register Overview

Table2, Table3 show the I/O assignments for PCI Configuration Registers and System Resource Registers. I/O register address to access System Resources in this FPGA is compatible with Intel PIIX3(82371FB).

| Configuration<br>Offset | Register              | Access |
|-------------------------|-----------------------|--------|
| PCI Device Independen   | t Region              |        |
| 00-01h                  | Vendor Identification | RO     |
| 02-03h                  | Device Identification | RO     |
| 04-05h                  | PCI Command           | R/W    |
| 06-07h                  | PCI Status            | R/WC   |

| Configuration<br>Offset       | Register                         | Access |  |
|-------------------------------|----------------------------------|--------|--|
| 08h                           | Revision ID                      | RO     |  |
| 09-0Bh                        | Class Code                       | RO     |  |
| PCI Device Header Type Region |                                  |        |  |
| 10h                           | Base Address Register for Memory | R/W    |  |
| 14h                           | Base Address Register for I/O    | R/W    |  |
| SYSTEM FPGA dependent Region  |                                  |        |  |
| 60-63h                        | PCI IRQ[A:D] Route Control       | RO     |  |

## Table 2:

| Address                | Register                          | Access |  |  |
|------------------------|-----------------------------------|--------|--|--|
| System Resource Region | System Resource Region            |        |  |  |
| 0020h                  | INT1 Control                      | R/W    |  |  |
| 0021h                  | INT1 Mask                         | R/W    |  |  |
| 0040h                  | Timer Counter 1 - Counter 0 Count | R/W    |  |  |
| 0061h                  | NMI Status and Control            | R/W    |  |  |
| 0070h                  | CMOS RAM Address and NMI Mask Reg | WO     |  |  |
| 00A0h                  | INT2 Control                      | R/W    |  |  |
| 00A1h                  | INT2 Mask                         | R/W    |  |  |
| 04D0h                  | INT-1 edge/level control          | R/W    |  |  |
| 04D0h                  | INT-1 edge/level control          | R/W    |  |  |
| 0CF9h                  | Reset Control                     | R/W    |  |  |
| 0D00h                  | Exp. FPGA Configuration start     | R/W    |  |  |
| 0D04h                  | Exp. FPGA Configuration data      | WO     |  |  |
| 0D08h                  | Exp. FPGA Configuration status    | R/WC   |  |  |



Table 3:

DRAFT

| Address                                                | Memory | Access |
|--------------------------------------------------------|--------|--------|
| Emulated BIOS                                          |        |        |
| FFFE 0000h-FFFE<br>FFFFh<br>(000E 0000h-000E<br>FFFFh) | BIOS   | RO     |

Table 4:

## **3.4 APIC**

## 4 NetBSD and SPC

- 4.1 Overview
- 4.2 Boot Loader Code Modifications
- 4.3 Memory based Filesystem

## **5** System FPGA Register Descriptions

## 5.1 PCI Configuration register

#### 5.1.1 Vender Identification

| Address Offset: | 00h 01h   |
|-----------------|-----------|
| Default value:  | xxxxh     |
| Attribute:      | Read Only |

This register uniquely identifies any PCI device along with the Device Identification Register.

| Bit  | Description                                           |
|------|-------------------------------------------------------|
| 15:0 | Vendor Identification Number. This is a 16 bit-value. |



#### 5.1.2 Device Identification

| Address Offset: | 02h 03h   |
|-----------------|-----------|
| Default value:  | xxxxh     |
| Attribute:      | Read Only |

This register uniquely identifies any PCI device along with the Vendor Identification Register.



LE VU

DRAFT

| Bit  | Description                                                   |
|------|---------------------------------------------------------------|
| 15:0 | <b>Device Identification Number</b> . This is a 16 bit-value. |

#### Table 6:

## 5.1.3 Command Register

| Address Offset: | 04h 05h         |
|-----------------|-----------------|
| Default value:  | 0003h           |
| Attribute:      | Read/Write Bit[ |

This register provides basic control over the System FPGA to respond to PCI cycle.

| Bit   | Description                                                                                                                                           |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:10 | Reserved.                                                                                                                                             |
| 9     | <b>Fast back to back Enable</b> . This bit must be a 1 since the System FPGA does not have Fast Back to Back function.                                |
| 8     | <b>SERR Enable</b> . 1=SERR signal drive Enable, 0=SERR signal drive Disable.                                                                         |
| 7     | Wait Cycle Control. This bit must be 0. Read Only.                                                                                                    |
| 6     | Parity Error Response. 1=Enable, 0=dsiable.                                                                                                           |
| 5     | <b>VGA Palette Snoop</b> . This must be 0 since the System FPGA does not have VGA Palette Snooping function.                                          |
| 4     | <b>Memory Write and Invalidate Enable</b> . This bit must be 0 since the System FPGA does not have this function.                                     |
| 3     | <b>Special Cycle Enable</b> . 1=Enable, the System FPGA recognizes shutdown special cycle. 0=Disable, the System FPGA ignores all PCI Special Cycles. |
| 2     | <b>Bus Master Access Enable</b> . This bit is hardwired to 0 since the System FPGA does not have this function.                                       |
| 1     | <b>Memory Access Enable</b> . This bit hardwired to 1 since the System FPGA cans response to Memory space access.                                     |
| 0     | <b>I/O Space Access Enable</b> . This bit hardwired to 1 since the System FPGA can response to I/O Space Address.                                     |

Table 7:

## 5.1.4 PCI Device Status Register

| Address Offset: | 06h 07h                        |
|-----------------|--------------------------------|
| Default value:  | 0200h                          |
| Attribute:      | Read/Write Clear(by writing 1) |



| Bit  | Description                                                                                                                                                                                                                                                                                                              |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15   | <b>Detected Parity Error</b> . Status. 0=the System FPGA did not detect a parity error. 1=the System FPGA detected parity error.                                                                                                                                                                                         |  |
| 14   | <b>Detected Signaled System Error Status</b> . 0=the System FPGA did not generate a system error on the SERR line. 1=the System FPGA detected parity error generates a system error on the SERR line.                                                                                                                    |  |
| 13   | <b>Received Master Abort Status</b> . This bit must be 0 since the System FPGA does not have the bus master function.                                                                                                                                                                                                    |  |
| 12   | <b>Received Target Abort Status</b> . This bit must be 0 since the System FPGA does not have the bus master function.                                                                                                                                                                                                    |  |
| 11   | <b>Signaled Target Abort Status</b> . This bit is set when the System FPGA is targeted with a transaction that the System FPGA terminates with a target abort. Writing a 1 clear this bit.                                                                                                                               |  |
| 10:9 | Device Select Timing Status. The System FPGA always generates DEVSEL with<br>slow(??) timing. These bits are read only.<br>bits[10:9]bits[10:9]Functions00The System FPGA asserts DESEL in the fast mode.01The System FPGA asserts DESEL in the medium mode.10The System FPGA asserts DESEL in the slow mode.11reserved. |  |
| 8    | <b>Device Parity Status</b> . This bit must be 0 since the System FPGA does not support the bus master function. Writing a 1 clear this bit.                                                                                                                                                                             |  |
| 7    | <b>Fast Back to Back</b> . This bit must be 0 since the System FPGA does not support this function.                                                                                                                                                                                                                      |  |
| 6:0  | Reserved. Read as 0s                                                                                                                                                                                                                                                                                                     |  |

Table 8:

## 5.1.5 Revision Identification

| Address Offset: | 08h       |
|-----------------|-----------|
| Default value:  | xxxxh     |
| Attribute:      | Read Only |

This register contains device stepping information.

| Bit  | Description                                          |
|------|------------------------------------------------------|
| 15:0 | Revision ID Byte. These bits are hardwired to xxxxh. |

Table 9:

#### 5.1.6 Class Code

| Address Offset: | 0Bh     |
|-----------------|---------|
| Default value:  | 060100h |



Attribute:

Read Only

This register indicates the device programming interface information related to the Sub-Class Code and Base Class Code definition fro the System FPGA. This register also identifies the Base Class Code and the function sub class in relation to the Base Class Code.

| Bit   | Description                                                  |
|-------|--------------------------------------------------------------|
| 23:16 | Base Class Code (BASEC). 06h=Bridge device.                  |
| 15:8  | Sub-Class Code(SCC). 01h= PCI-to-ISA Bridge.                 |
| 7:0   | Programming Interface. 00h=hardwired as a PCI-to-ISA Bridge. |

| Table | 10: |
|-------|-----|
|-------|-----|

#### 5.1.7 PIRQ[A:D] Route Control Register

Address Offset: PIRQRCA#-060h -- PIRQRCD#-063h

This resister is in PCI configuration Registers space.

Default value: PIRQRCA:80h, PIRQRC[B:D]:00h

Attribute: Read Only

These registers control the routing of the PIRQ[A:D] signals to the IRQ inputs of the interrupt controller. In the Sysytem FPGA, Interrupt Routing bits in these registers are hardwired. When a PIRQ signal is routed to an interrupt controller IRQ, the System FPGA can mask the corresponding IRQ signal.

| Bit | Description                                                                                                                                                                              |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | <b>Interrupt Routing Enable</b> . 1=Disable; 0=Enable. In PIRQRC[B:D], this bit is hard-<br>wired to 1 because PIRQ[B:D] are not used in SPC. In PIRQRCA, this bit is hardwired<br>to 0. |
| 6:4 | Reserved. These bit are hardwired to 0s.                                                                                                                                                 |
| 3:0 | Interrupt Routing.<br>In PIRQRCA, these bits are hardwired to 0101b to connect to IRQ5. In other registers, these bits are hardwired to 0000b.                                           |

#### Table 11:

## 5.2 System Resource Register

#### 5.2.1 Timer/Counter Registers

The System FPGA contains the functionality of 8254 Programmable Interval Timer(PIT) like a Intel PIIX3. The registers are compatible with the registers in PIIX3. The interrupt registers control the operation of PIT. However, some functions which are not essential to SPC are deleted from the original 8254.

#### 5.2.1.1. TCW: Timer Control Word Register

I/O Address: 043h



Default value:bit[7:6]=00b, bit[5:4]=undefined, bit[3:0]=0101bAttribute:Write Only

The Timer Control Word Register specifies the counter selection, the operating mode, the counter byte programming order and size of count value, and whether the counter counts down in a 16-bit or BCD format. After writing the control word, anew count can be written at any time. The new value takes effect according to the programmed mode.

| Bit | Description                                                                                                                                                                                                                            |  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7:6 | Counter select. If a timer is selected, bits[7:6] are be both 0 since the System FPGAhas a timer0 only. The read back Command is selected when bit s[7:6] are both 1. Writing other values are ignored.Bit[7:6]Function00Timer0 select |  |
| 5:4 | Read/Write select.Bit[5:4]Function00Counter Latch Command01R/W Least Significant Byte10R/W Most Significant Byte11R/W LSB then MSB                                                                                                     |  |
| 3:1 | <b>Counter Mode Select</b> . The System FPGA supports Rate Generator mode only. These bits is hardwired to 010b. Writing other value is ignored.                                                                                       |  |
| 0   | <b>Binary/BCD Countdown Select</b> . The Stem FPGA supports binary countdown mode only. This bit is hardwired to 1. The largest possible binary count is 2**16.                                                                        |  |

#### **Table 12:**

#### **Counter Latch Command**

The Counter Latch Command latches the current count value at the time the command is received. If a counter is latched once and then, come time later, latched again before the count is read, the second Counter latch Command is ignored. If the counter is programmed for two byte counts, two bytes must be read. The two bytes do not have to be read successively.

| Bit | Description                                                                                                                                                                                                                                                             |  |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7:6 | Counter Latch Command.Bit[7:6]Function00latch counter 0 select11Read Back CommandThese bits must be set to 00 to select the Counter Latch Command. Other values areignored since the System FPGA does not support other counters.                                       |  |
| 5:4 | <b>Counter Latch Command</b> . When bits[5:4] = 00, the Counter Latch Command is selected during a write to the Timer Control Word Register. Following the Counter Latch Command, I/O read from the selected counter's I/O addresses produce the current latched count. |  |

#### 5.2.1.2. Counter Access Port Register

| I/O Address:   | Counter 0 040h    |
|----------------|-------------------|
| Default value: | All bit undefined |
| Attribute:     | Read/Write        |

This register is used for writing count values to the Count Registers; reading the current count value from the counter by either an I/O read, after a counter-latch command.

| Bit | Description                                                                                                                                                                                                                                                                                |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | <b>Counter Port bit</b> . These bits are used to program the 16bit Count Register. The order of programming, either LSB only, or LSB then MSB, is defined with the interval Counter Control Register. The counter I/O port is also used to read the current count from the Count Register. |

**Table 14:** 

#### 5.2.2 Interrupt Controller Registers

The System FPGA contains the functionality of two 82C59 interrupt controllers like a Intel PIIX3. The registers are compatible with the registers in PIIX3. The interrupt registers control the operation of the interrupt controller. However, some functions which are not essential to SPC are deleted from the original 82C59.

#### 5.2.2.1. ICW1: Initialization Command Wor1 Register

| I/O Address:   | INT CTRL-1020h; INT CTRL-10A0h |
|----------------|--------------------------------|
| Default value: | 11h                            |
| Attribute:     | Write Only                     |

A write to Initialization Command Word 1 starts the interrupt controller initialization sequence. An I/O write to the CTRL-1 or CTRL-2 base address (020h or 0A0h) with bit 4 in data equal to 1 is interpreted as ICW1. The interrupt controller initialization must follow sequence described in Fig X.

ICW1 starts the initialization sequence during which the following automatically occur;

16.The Interrupt Mask register is cleared.

17.IRQ7 input is assigned priority7.

18. The slave mode address is set to 7.

19.Special Mask Mode is cleared and Status Read is set to IRR

20.If IC4(see bellow) was set to 0, then all functions selected by ICW4 are set to 0.

| Bit | Description                                                                                                                                                                                                               |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5 | ICW/OCW select. Theses bits should be 000 to select ICW1.                                                                                                                                                                 |
| 4   | <b>ICW/OCW select</b> . Bit 4 must be a 1 to select ICW1. A 1 on this bit at any time will force the interrupt controller to interpret the write as an ICW1. The controller will then expect to see ICW2, ICW3, and ICW4. |
| 3   | <b>Edge/Level Bank Select (LTIM)</b> . This bit is ignored. Its function is replaced by the Edge/Level Triggered Control (ELCR) Registers.                                                                                |
| 2   | ADI. Ignored for the System-FPGA.                                                                                                                                                                                         |
| 1   | Single of Cascade(SNGL). This bit is hardwired to a 0(cascade).                                                                                                                                                           |
| 0   | ICW4 Write Required(IC4). This bit is hardwired to a 1(ICW4 is required).                                                                                                                                                 |

#### Table 15:

#### 5.2.2.2. ICW3:Initialization Command Wor2 Register

| I/O Address:   | INT CTRL-1021h; INT CTRL-10A1h        |
|----------------|---------------------------------------|
| Default value: | bits[7:3]= undefined, bits[2:0]=000b. |
| Attribute:     | Write Only                            |

Initialization Command Word 2 is used to initialize the interrupt controller with the time most significant bits of the interrupt vector address.

| Bit | Description                                                                                                                                                                          |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3 | <b>Interrupt Vector Base Address</b> . Bit[7:3] define the base address in the interrupt vector table for the interrupt routines associated with each interrupt request level input. |
| 2:0 | Interrupt Request Level. These bits are hardwired to all 0s.                                                                                                                         |

#### Table 16:

#### 5.2.2.3. ICW3: Initialization Command Word3 Register for Master PIC

| I/O Address:   | INT CTRL-1021h |
|----------------|----------------|
| Default value: | 02h            |
| Attribute:     | Write Only     |



The meaning of ICW3 differs between CTRL-1(Master) and CTRL-2(Slave). On CTRL-1, ICW3 indicates which CTRL-1 IRQ line physically connects the INTR output of CTRL-2 to CTRL-1.

| Bit | Description                                                                                                                                                |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3 | Reserved. These bits are hardwired to all 0s.                                                                                                              |
| 2   | <b>Cascade Mode Enable</b> . This bit is hardwire to 1 to select the cascade mode. This indicates IRQ2 of the master controller connects the slave's INTR. |
| 1:0 | Reserved. These bits are hardwired to all 0s.                                                                                                              |



#### 5.2.2.4. ICW3: Initialization Command Word3 Register for Slave PIC

| I/O Address:   | INT CTRL-20A1h     |
|----------------|--------------------|
| Default value: | All bits undefined |
| Attribute:     | 02h                |

#### On CTRL-2, ICW3 is the slave identification code broadcast by CTRL-1.

| Bit | Description                                                                                                                                  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3 | Reserved. These bits are hardwired to all 0s.                                                                                                |
| 2:0 | <b>Slave Identification Code</b> . These bits are hardwired to 010b. This indicates IRQ2 of the master controller connects the slave's INTR. |



#### 5.2.2.5. ICW4:Initialization Command Word4 Register

| I/O Address:   | INT CNTRL-1021h; CTRL-20A1h |
|----------------|-----------------------------|
| Default value: | 01h                         |
| Attribute:     | Write Only                  |

ICW4 must be programmed as part of their initialization sequence.

| Bit | Description                                         |
|-----|-----------------------------------------------------|
| 7:5 | <b>Reserved</b> . These bits must be set to all 0s. |



| _ |
|---|
|   |
|   |
|   |
|   |

| Bit | Description                                                                                                                                                                                  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | <b>Special Fully Nested Mode(SFNM)</b> . Bit4 is hardwired to 0. Special Fully Nested Mode is not supported by the System FPGA.                                                              |
| 3   | <b>Buffered mode</b> ( <b>BUF</b> ). This bit is hardwired to 0. Writing 1 on this bit is ignored.                                                                                           |
| 2   | Master/Slave in Buffered mode(BUF). This bit is hardwired to 0.                                                                                                                              |
| 1   | <b>AEOI</b> (Automatic End of Interrupt). This bit should normally be programmed to 0.<br>This is the normal end of interrupt. If this bit is 1, the automatic end of interrupt mode is set. |
| 0   | <b>Microprocessor Mode</b> . This bit is harwired to 1. A 1 on this bit indicate Intel 8086 architecture-based system.                                                                       |

Table 19:

#### 5.2.2.6. OCW1: Operational Control Wor1 Register

| I/O Address:   | INT CNTRL-1021h; CTRL-20A1h |
|----------------|-----------------------------|
| Default value: | OOh                         |
| Attribute:     | Read/Write                  |

OCW1 sets and clears the mask bits in the Interrupt Mask Register(IMR). The IMR operates on the IRR. Masking of a higher priority input does not affect the interrupt request of lower priority. For reading the IMR, OCW3 is not needed. The output bus contains the IMR when an I/O read is active and the I/O address is 021h or 0A1h. All writes to OCW1 must occur following the ICW1-ICW4 initialization sequence, since the same I/O ports are used for OCW1, ICW2, OCW3, and ICW4.

| Bit | Description                                                                                                                                                                                                                                                                                                                                                            |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | <b>Interrupt Request Mask (Mask[7:0]).</b> When a 1 is set on any bit in this register, the corresponding IRQx line is masked and do not set the Interrupt Request Register(IRR) When a 0 is set on any bit in this register, the corresponding IRQx line is unmasked. Masking IRQ2 on CTRL-1 also masks the interrupt request from CTRL-2, which is cascaded to IRQ2. |

#### **Table 20:**

#### 5.2.2.7. OCW2: Operational Control Wor2 Register

| I/O Address:   | INT CNTRL-1020h; CTRL-20A0h                        |
|----------------|----------------------------------------------------|
| Default value: | bits[7:5]=001b, bits[4:3]=undefined, bit[2:0]=000b |
| Attribute:     | Write Only                                         |



OCW2 controls the Rotate Mode and the End of Interrupt mode. Following a CPURST or ICW initialization, the controller enters the fully nested mode of operation. Both rotation mode and specific EOI mode are disabled following initialization.

| Bit | Description                                                                                                                                                                                                                  |  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7:5 | Rotate and EOI codes.R,SL,EOI - These bits control the Rotate and EOI mode and<br>combinations of the two. The System FPGA supports the following mode only.Bits[7:5]Functions001:Non-specific EOI command                   |  |
| 4:3 | <b>OCW2 Select</b> . These bits must be set to 00 to select OCW2                                                                                                                                                             |  |
| 2:0 | <b>Interrupt Level Select(L2,L1,L0)</b> . L2, L1, and L0 determine the interrupt level acted upon when SL bit(bit 6) is active. In the System FPGA, the SL bit is hardwired to non active. Then, L2, L1, and L0 are ignored. |  |

**Table 21:** 

#### 5.2.2.8. OCW3: Operational Control Wor3 Register

| I/O Address:   | INT CNTRL-1020h; CTRL-20A0h                        |
|----------------|----------------------------------------------------|
| Default value: | bit[7:5]=100b, bits[4:3]=undefined, bits[2:0]=010b |
| Attribute:     | Read/Write                                         |

OCW3 serves Enable Special Mask Mode, Poll Mode control, and IRR/ISR register read control.

| Bit | Description                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7   | <b>Reserved</b> . This bit is hardwired to 1.                                                                                                                                                                                                                                                                                                                                                                        |  |
| 6   | <b>Special Mask Mode(SMM)</b> . This bit is hardwired to 0. Special Mask Mode is always disabled.                                                                                                                                                                                                                                                                                                                    |  |
| 5   | <b>Enable Special Mask Mode(ESMM)</b> . This bit is hardwired to 0. This disables SMM bit.                                                                                                                                                                                                                                                                                                                           |  |
| 4:3 | OCW3 Select. These bits must be set to 01 to select OCW3                                                                                                                                                                                                                                                                                                                                                             |  |
| 2   | <b>Poll Mode Command</b> . 0= Disable Poll Mode Command. This bit is hardwired to 0.                                                                                                                                                                                                                                                                                                                                 |  |
| 1:0 | Register Read Command. Bits[1:0] provides control for reading the In-Service Register(ISR) and the interrupt Request Register(IRR). Following ICW initialization, the<br>default OCW3 port address read will be "read IRR". To retain the current selection,<br>always write a 0 to bit 1 when programming this register.Bits[2:0]Functions<br>00:00:No Action<br>10:10:Read IRR Register<br>11:11:Read ISR Register |  |



#### 5.2.3 NMI Register

The NMI logic incorporates two different 8-bit registers. The CPU reads the NMISC Register to determine the NMI source. In this SYSTEM-FPGA, the NMI source is only PCI SERR. After the NMI interrupt routine processes the interrupt, software clears the NMI status bit by setting the corresponding enable/disable bit to a 1. The NMI Enable and Real-Time Clock register can mask the NMI signal and disable/enable all NMI sources.

To ensure that all NMI requests are serviced, the NMI service routine software flow should be as follows,

1.NMI is detected by the processor on the rising edge of the NMI input.

2. The processor will read then set to the status stored in port 061h to determine what sources caused the NMI. The Processor may the set to 0 the register bits controlling the sources that it has determined to be active. Between the time the processor reads the NMI sources and sets them to a 0, an NMI may have been generated by another source. The level of NMI will then remain active. This new NMI source will not be recognized by the processor because there was no edge on NMI.

3. The processor must then disable all NMIs by setting bit 7 of port 070h to a 1 and then enable all NMIs by setting bit 7 of port 070h to a 0. This will cause the NMI output to transition low then high if there are any pending NMI sources. The CPU's NMI input logic will then register a new NMI.

#### 5.2.3.1. NMI Status And Control Register (NMISC)

| I/O Address:   | 061h       |
|----------------|------------|
| Default value: | 00h        |
| Attribute:     | Read/Write |

This register reports the status of PCI SERR status as a NMI source.

| Bit | Description                                                                                                                                                                                                                                                                             |  |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7   | <b>SERR# NMI Source Status</b> . Bit 7 is set if a PCI device detects a system board error and pulses the PCI SERR# line. This interrupt source is enabled by setting bit2 to 0. To reset the interrupt, set bit2 to 0 and then set it to 1. When writing to port 061h, bit7 must be 0. |  |
| 6:3 | <b>Reserved</b> . These bits are hardwired to 0s.                                                                                                                                                                                                                                       |  |
| 2   | <b>PCI SERR# Enable</b> . 1= Clear and Disable; 0= Enable.                                                                                                                                                                                                                              |  |
| 1:0 | Reserved. These bits are hardwired to 0s.                                                                                                                                                                                                                                               |  |

**Table 23:** 

#### 5.2.3.2. NMI Enable and Real-Time Clock Address Register

| I/O Address: | 070h |
|--------------|------|
|              |      |

Default value: Bit[6:0]=undefined; Bit7=1

Attribute: Write Only

This register is shared with the real-time clock.



RAFT

| Bit | Description                                                                                                                        |
|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 7   | NMI Enable. 1=Disable; 0=Enable.                                                                                                   |
| 6:0 | <b>Real Time Clock Address</b> . These bits are used by the real Time Clock on the Base I/O component to address memory locations. |

#### **Table 24:**

#### 5.2.3.3. PIRQ[A:D] Route Control Register

Refer to 4.1.7.

#### 5.2.4 Real Time Controller Registers

Registers in Real Time Controller can be accessed via address and data register ports 70h (address register) and 71h (data register). Bit7 of port 70h is also used for NMI mask register. Then, registers in Real Time Controller must be read/written according as the following sequence:

-- Read the old byte via 70h and write the address of the data byte to access using bits[4:0].

-- Read or write the accessed data byte via port 71h.

#### 5.2.4.1. Address/Data Registers

#### **Address Register**

See NMI Enable and Real-Time Clock Address Register

| I/O Address:   | 070h                       |
|----------------|----------------------------|
| Default value: | Bit[6:0]=undefined; Bit7=1 |
| Attribute:     | Read/Write                 |

| Bit | Description                                                                                                                        |
|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 7   | NMI Enable. 1=Disable; 0=Enable.                                                                                                   |
| 6:0 | <b>Real Time Clock Address</b> . These bits are used by the real Time Clock on the Base I/O component to address memory locations. |

#### Table 25:

#### Data Register

| I/O Address:   | 071h       |
|----------------|------------|
| Default value: | Undefined  |
| Attribute:     | Read/Write |

| Bit | Description                                                                                        |
|-----|----------------------------------------------------------------------------------------------------|
| 7:0 | <b>Real TIme Clock Data</b> . These bits indicate a byte data of the address assigned on port 70h. |

The contents and address of RTC register will be described in the following sections.

#### 5.2.4.2. Seconds

Address in RTC: 00h

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: undefined

Attribute: Read/Write

| Bit | Description                                                                                |
|-----|--------------------------------------------------------------------------------------------|
| 6:0 | Seconds. Entry seconds. Binary data mode: 0-3B. The System FPGA supports binary mode only. |

Table 27:

#### 5.2.4.3. Minutes

Address in RTC: 02h

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: undefined

Attribute: Read/Write

| Bit | Description                                                                                        |
|-----|----------------------------------------------------------------------------------------------------|
| 6:0 | <b>Minutes</b> . Entry minutes. Binary data mode: 0-3B. The System FPGA supports binary mode only. |

#### **Table 28:**

#### 5.2.4.4. Hours

Address in RTC: 05h

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: undefined

Attribute: Read/Write

| Bit | Description                                                                                                                    |
|-----|--------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | <b>Hours</b> . Entry hours. When Hours-24-hr mode, Binary data mode. The system FPGA supports 24-hr mode and binary mode only. |

#### **Table 29:**

#### 5.2.4.5. Day of the Week

Address in RTC: 06h

This address will be set at bits[4:0] in the RTC address register 70h.

DRAFT

Default value: undefined

Attribute:

 Bit
 Description

 7:0
 Day of the Week. Binary data mode: 01-07, BCD data mode. The System FPGA supports binary mode only.

Table 30:

#### 5.2.4.6. Day of the Month

Address in RTC: 07h

This address will be set at bits[4:0] in the RTC address register 70h.

Read/Write

Read/Write

Default value: undefined

Attribute:

| Bit | Description                                                                                    |
|-----|------------------------------------------------------------------------------------------------|
| 7:0 | <b>Date of the Month</b> . Binary data mode: 01-1F. The System FPGA supports binary mode only. |

#### **Table 31:**

#### 5.2.4.7. Month

Address in RTC: 08h

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: undefined

Attribute: Read/Write

| Bit | Description                                                                |
|-----|----------------------------------------------------------------------------|
| 7:0 | Month. Binary data mode: 01-0C. The System FPGA supports binary mode only. |

#### **Table 32:**

#### 5.2.4.8. Year

Address in RTC: 09h

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: undefined

Attribute: Read/Write



DRAFI

| Bit | Description                                                               |
|-----|---------------------------------------------------------------------------|
| 7:0 | Year. Binary data mode: 00-63. The System FPGA supports binary mode only. |

## Table 33:

## 5.2.4.9. RegisterA

Address in RTC: 0Ah

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: 80h

Attribute: Read/Write

| Bit | Description                                                                                                                                                                                                                            |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | <b>Update In Progress</b> . This bit is hardwired to a 0, which means the update transfer will not occurbecause the Sysytem FPGA does not support real time clock update function. The System FPGA provides read/write registers only. |
| 6:4 | <b>DV[2:0]</b> . These bits are meaningless in the System FPGA.                                                                                                                                                                        |
| 3:0 | <b>RS[3:0]</b> . These bits are meaningless in the System FPGA.                                                                                                                                                                        |

#### Table 34:

#### 5.2.4.10.RegisterB

Address in RTC: 0Bh

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: 06h

Attribute: Read/Write

| Bit | Description                                                          |
|-----|----------------------------------------------------------------------|
| 7   | SET. This bit is meaningless in the System FPGA.                     |
| 6   | <b>PIE</b> . This bit is meaningless in the System FPGA.             |
| 5   | AIE. This bit is meaningless in the System FPGA.                     |
| 4   | UIE. This bit is meaningless in the System FPGA.                     |
| 3   | SQWE. This bit is meaningless in the System FPGA.                    |
| 2   | <b>DM</b> . This bit is meaningless in the System FPGA.              |
| 1   | <b>24/12</b> . This bit is hardwired to 1.                           |
| 0   | Daylight Savings Enable. This bit is meaningless in the System FPGA. |

#### Table 35:



DRAFT

#### 5.2.4.11.RegisterC

Address in RTC: 0Ch

This address will be set at bits[4:0] in the RTC address register 70h.

Default value: 00h

Attribute: Read Only

The System FPGA does not support the interrupt function in RTC. Then, whenever this register is read, the value is always x00h.

| Bit | Description                                                            |
|-----|------------------------------------------------------------------------|
| 7   | <b>Interrupt Request Flag(IRQF)</b> . This bit is hardwired to a 0.    |
| 6   | <b>Periodic Interrupt Flag(PF)</b> . This bit is hardwired to a 0.     |
| 5   | <b>AF</b> . This bit is hardwired to a 0.                              |
| 4   | <b>Update Ended Interrupt Flag(UF)</b> . This bit is hardwired to a 0. |
| 3:0 | <b>Reserved</b> . These bits are hardwired to 0s.                      |

#### Table 36:

#### 5.2.4.12.RegisterD

Address in RTC: 0Dh

This address will be set at bits[4:0] in the RTC address register 70h.

Read only

Default value: 80h

Attribute:

| Bit | Description                               |
|-----|-------------------------------------------|
| 7   | Valid RAM and Time(VRT). This bit is a 1. |
| 6:0 | Reserved.                                 |

**Table 37:** 

#### 5.2.4.13.CMOS-RAM memory

address 0Eh -- 3Fh TBD

#### 5.2.5 Emulated BIOS Memory

| Address:   | 0000E0000h-000FFFFFh |
|------------|----------------------|
| Attribute: | Read only            |



Emulated BIOS memory contains FAR JMP to E0000h and codes which copies all of BIOS codes to main memory(E0000h -- Fxxxxh) and which checks the sanity of writing/reading the main memory address area. The BIOS codes also include a function that prohibits the access to the Emulated BIOS Memory area after copying the BIOS code into main memory. Instead of access to the Emulated BIOS Memory area, the main memory ad-

(Jump to the top of BIOS address space)

FFFF FFF0hJMP FAR 0000:E000 (E0 00 E0 00 F0)(Copy BIOS codes itself into main memory)000E xxxxhSTART:PUSHDS

dress space which BIOS codes are copied into can be accessed.

| λλλλΙΙ | START.   | rusii | DS  |        |
|--------|----------|-------|-----|--------|
|        |          | PUSH  | ES  |        |
|        |          | CLD   |     |        |
|        |          | MOV   | AX, | 0F000H |
|        |          | MOV   | DS, | AX     |
|        |          | MOV   | SI, | 0FFF5H |
|        |          | MOV   | AX, | 0000H  |
|        |          | MOV   | ES, | AX     |
|        |          | MOV   | DI, | 8000H  |
|        |          | MOV   | CX, | 8H     |
|        | DATE_LP: | MOVS  | В   |        |

LOOP DATA\_LP

POP ES POP DS

(Prohibit the access to Emulated BIOS memory directly and provide the access to the shadow memory area) TBD

(Check the sanity of writing/reading the main memory address space)

TBD

#### 5.2.6 Reset Control Registers

| Address:       | CF9h       |
|----------------|------------|
| Default value: | 00h        |
| Attribute:     | Read/write |

| Bit | Description |
|-----|-------------|
| 7:3 | Reserved.   |

Table 38:

DRAFT

| Bit | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | <b>Reset CPU (RCPU)</b> . This bit is used to initiate (transitions from 0 to 1) a hard reset (bit1 in this register is set to 1) or a soft reset to the CPU. During a hard reset, the System FPGA asserts CPURST, PCIRST, and RSTDRV. The System FPGA initiates a hard reset when this register is programmed for a hard reset or PWORK is asserted. This bit cannot be read as a 1. |
| 1   | <b>System Rest(SRST)</b> . This bit is used in conjunction with bit in this register to initiate a hard reset. When SRST=1, the System FPGA initiates a hard reset to the CPU when bit2 transitions from 0 to 1. When SRST=0, the System FPGA initiates a soft reset when bit2 transitions from 0 to 1.                                                                               |
| 0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |

#### Table 38:

#### 5.2.7 Experimental FPGA Configuration Registers (Put off for now)

Experimental FPGA Configuration Registers are used to configure a experimental FPGA on SPC and check the configuration status.

#### 5.2.7.1. Configuration Start Register

| Address:       | 0D00h      |
|----------------|------------|
| Default value: | 00h        |
| Attribute:     | Read/write |

| Bit | Description                                                                                                                                                                                                                                                                                                  |  |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7:1 | Reserved.                                                                                                                                                                                                                                                                                                    |  |
| 0   | Configuration Start. When this bit is set to a 1, the PROGRAM signal pin will be asserted. When this bit is set to a 0, the PROGRAM signal pin will be deasserted. If this bit is set to a 1 to start the Experimental FPGA configuration, the value must be main-tained until the end of the configuration. |  |

#### Table 39:

#### **5.2.7.2.** Configuration Data Register

| Address:       | xxxxh      |
|----------------|------------|
| Default value: | 0D04h      |
| Attribute:     | Write Only |

| Bit  | Description                                                                                                                                                                                                                                                                                      |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | <b>Configuration Data</b> . The Experimental FPGA configuration data is set to these bits.<br>When Configuration Start bit in Configuration Start Register is set and Configuration<br>data write status bit is set, the Configuration Data bits can be written into the experi-<br>mental FPGA. |

#### Table 40:

#### 5.2.7.3. Configuration Status Register

| Address:       | sextets          |
|----------------|------------------|
| Default value: | 0D08h            |
| Attribute:     | Read/Write Clear |

This register indicates some status during the Experimental FPGA configuration. This register is meaningless when Configuration Start bit is not set.

| Bit  | Description                                                                                                                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:3 | Reserved.                                                                                                                                                                                                                                                                                               |
| 2    | <b>Configuration Data Write Status</b> . This bit indicates whether all bits of configuration data in the Configuration Data Register have been written into the Experimental System FPGA. When this bit is set to a 1, the configuration data have been written into the Experimental FPGA. Read only. |
| 1    | <b>Configuration Error Status</b> . This bit indicates whether any errors occur in the Experimental FPGA configuration. When this bit is set to a 0, errors occur in course of the configuration. Write clear.                                                                                          |
| 0    | <b>Configuration Status</b> . This bit indicates status of configuring the Experimental FPGA. When this bit is set to a 0, the configuration is done. When this bit is a 1, the configuration is not completed. Read Only.                                                                              |



## 6 System FPGA Functional Description

## 6.1 Interrupt control

#### 6.1.1 Accommodating interrupt requests

The System FPGA has the function of Programmable Interrupt Controller (PIC). The PIC accommodate the following interrupt requests.

1.A interrupt request from a Programmable Interval Timer (PIT)

2.A interrupt request from a Serial Port (COM1)

3.A interrupt request from a Serial Port (COM2)

4.A interrupt request from APIC.

The interrupt requests from the PIT, COM1, and COM2 are connected to IR0, IR3, adn IR4 of the PIC respectively. These connections are same as PC platforms do.

The interrupt request from APIC uses PIRQA signal and the signal is connected to IR5 of the PIC. IR5 is usually connected to the request from Parallel port2 on PC platforms but Parallel port2 is not necessary for SPC. Then, the PIRQA signal could be connected to IR5 on the SPC. The interrupt software driver must hook IRQ5:INT5 entry in Interrupt Vector Table in order to use IRQ5 as APIC's interrupt routine.



DRAF

PCI interrupt signal from a experimental FPGA is also run to the System FPGA. However, the implementation of the function in the System FPGA will be put off until the experimental FPGA is implemented on SPC.

#### 6.1.2 IRQ routing

The System FPGA has registers that control the routing of the PIRQ[A:D] signals to the IR inputs of the PIC. The register for PIRQA are hardwired to the value which indicates routing to IRQ5 and other registers are hardwired to be disabled because PIRQA is connected to IRQ5 as above mentioned and PIRQ[B:D] are not used in SPC. When the experimental FPGA is implemented and the FPGA uses one of PIRQ[B:D], the corredponding register will be hardwired to the interrupt to one of IRQs. These registers may be read by NeBSD in interrupt configuration process.

#### 6.1.3 Interrupt Priority

The PIC in the System FPGA support two priority ordering modes. Other modes which are provided by the priginal PIC are not supported. This is because of NetBSD does not use other modes. In one mode, IR0 has the highest prioriy, IR3 has the second, IR4 has the third, and IR5 has the fifth. In another mode, IR3 has the highest prioriy, IR4 has the second, IR5 has the third, and IR0 has the fifth.

#### 6.1.4 Special Mask Mode

NetBSD set special mask mode to PIC if the mode is available. Then, the System FPGA supports Special Mask Mode. In this mode, when a mask bit is set in OCW1, it inhibits further interrupts at that level and enables interrupts from all other levels (lowe as well as higher) that are not masked.

When special mask mode is not set, if an Interrupt Request is acknowledged and an End of Interrupt command did not reset its IS bit, the System FPGA whould have inhibited all lower priority requests.

#### 6.1.5 Automatic End of Interrupt mode

If automatic end of interrupt mode is set, a requested ISR bit is reset automatically when the System FPGA receives the second Interrupt Acknowledge. In non-automatic end of interrupt mode, the requested ISR bit is cleared when the System FPGA receives the specific EOI command. The system FPGA supports automatic end of interrupt mode because NetBSD may require this mode.

#### 6.1.6 Poll command

The System FPGA does not support Poll command since NetBSD does not require this command.

#### 6.1.7 Fully Nested Mode

The System FPGA does not support fully nested mode since NetBSD does not require this mode.

#### 6.1.8 Level Interrupt Mode

The System FPGA will operate in the level interrupt mode. The assertions of interrupt request with One or more clocks width could be detected as interrupt requests occur.

#### 6.1.9 Interrupt Request Mask

The IMRI (Interrupt Mask Register) stores the bits which disable the interrupt lines to be masked. The IMR operates on the output of the IRR. Masking og a hihger priority input will not affect the interrupt request lines of lower priority.

#### 6.1.10 Initialization

The PIC in the System FPGA requires the following initialization sequence. In this sequence, some registeres in the System FPGA are hardwired in advance as mentioned in the following picture.



+

NetBSD executes the PIC initialization according to the following sequence. Refer to NetBSD, ~arch/i386/isa/ isa\_machdep.c.

```
isa_defaultirq()
{
             int i;
              /* icu vectors */
             for (i = 0; i < ICU_LEN; i++)</pre>
                           setgate(&idt[ICU_OFFSET + i], IDTVEC(intr)[i], 0,
SDT_SYS386IGT,
                               SEL_KPL);
              /* initialize 8259's */
             outb(IO_ICU1, 0x11);
                                         /* reset; program device, four bytes */
             outb(IO_ICU1+1, ICU_OFFSET);/* starting at this vector index */
             outb(IO_ICU1+1, 1 << IRQ_SLAVE); /* slave on line 2 */</pre>
#ifdef AUTO_EOI_1
             outb(IO_ICU1+1, 2 | 1);
                                         /* auto EOI, 8086 mode */
#else
             outb(IO_ICU1+1, 1);
                                         /* 8086 mode */
#endif
             outb(IO_ICU1+1, 0xff);
                                         /* leave interrupts masked */
             outb(IO_ICU1, 0x68);
                                         /* special mask mode (if available) */
                                         /* Read IRR by default. */
             outb(IO_ICU1, 0x0a);
#ifdef REORDER_IRQ
             outb(IO_ICU1, 0xc0 | (3 - 1));/* pri order 3-7, 0-2 (com2 first) */
```

#endif

32

```
outb(IO_ICU2, 0x11);
                                         /* reset; program device, four bytes */
             outb(IO_ICU2+1, ICU_OFFSET+8);/* staring at this vector index */
             outb(IO_ICU2+1, IRQ_SLAVE);
#ifdef AUTO_EOI_2
             outb(IO_ICU2+1, 2 | 1);
                                         /* auto EOI, 8086 mode */
#else
             outb(IO_ICU2+1, 1);
                                         /* 8086 mode */
#endif
             outb(IO_ICU2+1, 0xff);
                                         /* leave interrupts masked */
             outb(IO_ICU2, 0x68);
                                         /* special mask mode (if available) */
             outb(IO_ICU2, 0x0a);
                                        /* Read IRR by default. */
}
```

#### 6.1.11 Master/Slave

The System FPGA has a master PIC function only because all interrupt requests which are accomodated could be managed by the master PIC. Hoewver, the System FPGA provides resisters for a slave PIC because Net-BSD try to write and read the resisters in its initialization.

#### 6.1.12 NMI

The System FPGA has NMI status And Control register and NMI Enable and Real-Time Address Register. Bit7 of NMI status And Control register reports the status of PCI SERR. When bit2 of the register is set to 0, the assertion of PCI SERR will cause NMI to CPU.

Bit7 of NMI Enable and Real-Time Address Register is NMI enable. If the CPU detects NMI, the CPU must disable all NMIs by setting the bit7 to a 1 and then enable all NMIs by setting the bit7 to a 0. This will cause a new NMI aassertion if there are any pending NMI sources. In the System FPGA, NMI source is only PCI SERR.

## 6.2 Time Control

#### 6.2.1 Counter0

The PIT (Programmable Interval Timer) in the System FPGA supports counter0 and rate generate mode. Other counters and other modes, which are supported by the original PIT, are not provided by the System FPGA. This is because other counters are for DMA8237 and the speaker but they are not necessary for SPC. In addition, the counter0 is used for system clock and in the rate generate mode. The couter0 provides binary counter not BCD counter. The following code is the NetBSD PIT initialization code. Refer to NetBSD, ~arch/i386/isa/isa\_machdep.c.

```
void
startrtclock()
{
    int s;
    findcpuspeed(); /* use the clock (while it's free)
    to find the cpu
speed */
```



DRAFT

#### 6.2.2 Write Operation

}

For counter0, the Timer Control Word must be written to port 0x40h before the initial count is written. The initial count must follow the count format specified in the Timer Control Word (LSB only, MSB only, or LASB and MSB).

#### 6.2.3 Read Operation

There are two possible method for reading the counter, a simple read operation and the Counter latch command. Read Back command, which is provided by 82C54 PIT, is not support by the System FPGA since NetBSD do not use this operation.

With s simple read operation, to read the counter0, the CLK input of the counter0 must be inhibited. Otherwise, the count may be in the process of changing when it is read, giving an defined result. This operation should not be used because the CLK input can not be inhibited in the FPGA. NetBSD use the Counter Latch Command which is explained in the following paragraph.

The Counter Latch Command, like a Timer Control Words, is written to the Control Word at port 0x43h. Bit[7:4] must be set x"1100" in this case. Bit[7:4] = x"1100" indicates the Counter Latch Command to the counter0. The selected Counter's output latch latches the count at the time the Counter Latch Command is received. This count is held in the latch until it is read by the CPU. The count is the unlatched automatically and the output latch returns to following the counting element.

#### 6.2.4 Rate Generation

This mode functions like a divide-by-N. Interrupt request from the PIT will initially be low. When the initial count has decremented to 1, the interrupt request goes high for one CLK pulse. The interrupt request goes low again, the Counter reloads the initial count and the process is repeated. This interrupt request run to the IRO of interrupt control.

#### 6.2.5 Clock to Counter0

The clock to counter0 is generated from dividing 33 MHz clock by 27 or 28. In the PC plarforms, 1.19318MHz clock is used as the clock to counter0. In the System FPGA, the divide clock is used to synchronize the all circuits by the 33MHz clock to be easy to implement. The following picture explain the divided clock wave form. With this scheme, couter0 is faster 0.87 ns 3 1.193182MHz clocks or 0.015ns per 105 1.193182MHz clocks.



|  | Cycle | Devided-N         | Gap                                  |  |
|--|-------|-------------------|--------------------------------------|--|
|  | 0     | 27/28/28          | 0.87ns                               |  |
|  | 1     | 27/28/28          | 0.87ns                               |  |
|  | 2     | 27/28/28          | 0.87ns                               |  |
|  |       |                   |                                      |  |
|  | 33    | 27/28/28          | 0.87ns                               |  |
|  | 34    | 27/ <u>27</u> /28 | 0.015ns. This cycle scrinks the gap. |  |



## 6.3 Real Time Clock control

#### 6.3.1 No Real Time Clock function

Registers of Real Time Clock(RTC), which a microprocessor can read/write, are supported by the Sysytem FPGA. However, the System FPGA does not provide the calendar function of the original RTC function.

NetBSD read the calendar in the RTC in initialization sequence. However, NetBSD does not use RTC to update sec, minutes, hour, day, month, and year in the calendar function during run-time. It use the interupt from the PIT to update the calendar of NetBSD. On SPC, a boot loader writes initial value of calendar to registers of RTC and then NetBSD read the value in initialization. This could make the System FPGA implimentation easier. The second and minitue of calendar will be slow but it is negligible in experiment situations.

#### 6.3.2 NVRAM area

The system FPGA provide the following register in NVRAM area which NetBSD may read.

| Offset | Description                                                                                           |  |  |
|--------|-------------------------------------------------------------------------------------------------------|--|--|
| 0Eh    | diagnosis status. The value is hardwired to                                                           |  |  |
|        | RTC power supply is OK, Checksum is OK, Configuration is OK, Evaluated memory size is OK,             |  |  |
|        | Harddisk is conroller or drive initialization failed, and time is OK.                                 |  |  |
| 0Fh    | Shutdown Staus. Default: 00h=normal system reset. This register is possible to read and write.        |  |  |
| 10h    | type of Floppy drives. Hardwired to x"00" to indicate first and second floppy drive is not installed. |  |  |
| 12h    | type of Hard disk drives. Hardwired to x"00" to indicate first and second Hard disk drive is not      |  |  |
|        | installed.                                                                                            |  |  |
| 14h    | Device type. The value is hardwired to                                                                |  |  |
|        | floppy drive is not installed, coprocessor 80x87 is not installed, and graphic adapter is ???.        |  |  |
| 15h    | base memory size(low byte). The value is set based on external pins to indicate Main memory size.     |  |  |
| 16h    | base memory size(high byte). The value is set based on external pins to indicate Main memory size.    |  |  |
| 17h    | extended memory size(low byte).                                                                       |  |  |
|        | The value is set based on external pins to indicate Main memory size.                                 |  |  |
| 18h    | extended memory size(high byte).                                                                      |  |  |
|        | The value is set based on external pins to indicate Main memory size.                                 |  |  |
| 32h    | Century. This register will be hardwired to 1997.                                                     |  |  |

## 6.4 Reset Control

#### 6.4.1 Hard Reset

Hard reset will be generated when bit1 in Reset Control Register is a 1 and bit2 translates a 0 to a 1 or when PWORK signal is asserted. Hard reset assert three external signals (CPURST and PCIRST#) and resets the current state in the System FPGA.

The assertion of PWORK indicates to the System FPGA that power and PCICLK have been stable for at least 1ms. PCIRST# an CPURST are driven inactive a minimum of 1ms after PWORK is driven active. PCIRST# and CPURST are driven active for a minimum of 1ms when initiated through the RC register.

Pentium requires;

CPURST for a minimum of 15 clk cycles

PCI bus specification requires;

The RST# signal line is asserted a minimum of 1ms.

The CLK signal line has been oscillating a minimum of 100microseconds.

Voltage level outlined in table 11-1 have remained above the minimum leves(PWR\_GOOD# asserted) for about 100 ms.

#### 6.4.2 Soft Reset

Soft reset will occur at the time bit2 in Reset Control Register tansits 0 to 1 and bit1 is equal to 0. Soft reset asserts INIT signal to microprocessor for a minimum two 66MHz clock cycles.

## 6.5 Emulated BIOS

Pentium read a instruction at FFFF FFF0h in BIOS memory space in the System FPGA. The instruction is FAR JMP to the top of the instruction sets which ecceutes Main Memory Check and Loop to wait for OS download. The FAR JMP and the instruction sets are read-only register in the System FPGA.

Memory Check codes write a data to a address in main memory space and compare. If the written data and the read data are same, the succeeding address is testified. If all addresses in main memory are testified and any error have not been found, the codes goes into Loop process. Some external pins should be set to indicate main memory size to the System FPGA before the System FPGA is configured.

During of loop execution, OS and application software are downloaded through APIC. Microprocessor will be execute loop process that read and check a value of a register in the System FPGA until the value transits 0 to 1.

Other functions which are provided by the original BIOS are executed by the down-loaded boot-loader.

## 6.6 UART

## 6.7 Experimental FPGA configuration control (put off for now)

#### 6.7.1 Overview of FPGA configuration

The basic operation of the FPGA configuration schemes is composed of the following stages.

1. The device configuration memory is cleared.

- 2. Configuration data is clocked into the device.
- 3. After a successful download, the FPGA asserts its DONE signal.

#### 6.7.2 Slave Serial Mode

The System FPGA use the Slave Serial mode to configure the experimental FPGA on SPC. The Slave Serial mode requires only three active signals.

- 1. DIN, the data in pin.
- 2. Configuration Clock, CCLK.
- 3. PROGRAM which has been asserted during the configuration.

#### 6.7.3 Configuration Sequence through the System FPGA

- 1: Set bit1 in Configuration Start Register in order to assert PROGRAM signal pin.
- 2: Read bit2 in Configuration Status Register. If the value is a 0, it is possible to write a configuration data to Configuration Data Register.
- 3: If a configuration data is written to bit[7:0] in the System FPGA, the System FPGA output the data bit by bit with Configuration Clock. During this output sequence, bit2 in Configuration Data



DRAFT

Write Status is set 1 automatically. If all bit have been sent to the experimental FPGA, Configuration Clock get non-activated and bit2 in Configuration Data Write Status is set 1.

- 4: Repeat 2 and 3 until microprocessor write all of configuration data into the Configuration Data Register. If the configuration has been finished, the experimental FPGA asserts DONE signal. Assertion of the DONE signal set bit0 Configuration Status Register to 1.
- 5: Lock signal to the experimental FPGA is asserted. The signal will have been asserted in order to prevent further access.



## 7 System FPGA Implementation

## 7.1 Detailed BLock Diagram





| 7.3   | Register Manager |
|-------|------------------|
| 7.3.1 | Decode           |

I/O, Memory Address

020h (I/O)

021h (I/O)

0A0h (I/O)

0A1h (I/O)

061h (I/O)

070h (I/O)

040h (I/O)

FFFEFFFh -- FFFEFFFFh,

000EFFFFh

-- 000EFFFFh(memory)

The following list indicates the address which the decoder decodes to initiate the read/write cycle.

Interrupt\_Control:Master PIC

Interrupt\_Control:Master PIC

Interrupt\_Ccontrol:Slave PIC

Interrupt\_Control:SlavePIC

Timer\_Control:Counter0

Interrupt Control

Interrupt\_Control:NMI status and control

( shared with Address register of RTC): CMOS RAM address and NMI enalbe

Function block to select

| 043h (I/O)        | Timer_Control:Timer Control Register                                                         |
|-------------------|----------------------------------------------------------------------------------------------|
| 070h (I/O)        | Real_Time_Control:<br>( shared with NMI enable register):<br>CMOS RAM address and NMI enable |
| 071h (I/O)        | Real_Time_Control:CMOS RAM data                                                              |
| 03F8h 03FEh (I/O) | UART1 (This will be connected to external bus.)                                              |
| 02F8h 02FEh (I/O) | UART2 (This will be connected to external bus.)                                              |
| 0CF9h (I/O)       | Rest_Control                                                                                 |
| 0D00h 0D08h       | Ex_FPGA_Config_Control                                                                       |

**Table 42:** 

Bios\_Control

When the register manager detects the assertion of IOstrobe, it decodes the received address as a address to I/O space. On the other hands, when MEMstrobe is asserted, the register manager decodes the address as memory address.

In order to read/write a data from/to a register in RTC, first, the address register at 070h should be set to a accessed address, then, the data register at 071h should be accessed. When the data register is accessed, the register manager send the address which is set at 070h previously, as a address to RTC. When the address register is accessed to write a data, the register manager keeps the data and does not assert signals to RTC. However, bit7 of the address register is located in interrupt\_control because this register is shared with NMI and RTC.

7.2 PCI Slave

The adress and the data are transfered to the external bus at the time UART1/2 is accessed.

#### 7.3.2 Read/Write Operation to other internal Function Blocks

The register manager expects non-wait access to the registers in other internal function blocks. The following figure notes the read/write access to other internal function blocks.



#### 7.3.3 Read/Write Operation to external Function Block (UART)

The following figure notes the read/write access to UART which is located at outside of this FPGA.



# -

#### 7.3.4 PIRQ[A:D] Route Register

The register manager has PIRQ[A:D] route registers. This registers are hardwired the output of these registers are run to PCI-SLAVE stuff. These registers address is decoded as a address in PCI Configuration space.

RAH

## 7.4 Interrupt Control





#### 7.4.2 Blocking Interrupt Request

In the normal mode, if an interrupt request is acknowledged and an End of Interrupt command did not reset its IS bit (i.e., while executing a service routine), the Sysytem FPGA would have inhibited all lower prority requests.

In the Special Mask Mode, when a msk bit is set in OCW1, it inhibits further interrupt at that level and enables interrupts from all other levels (lower as well as higher) that are not masked. Any interrupts may be selectively enabled by loading the mask register.

Between first INTA and second INTA, the status of IRR (Interrupt Request Register ) is freezed (latched). Then, interrupt requests are blocked and are not stored in IRR.

Between second INTA and EOI command, lower interupt requests than the processed interrupt request are stored in IRR but could not request a interrupt service routine (assertion of INTR) even if the according IMR bit is no set int the normal mode. Interrupt requests in Special Mask Mode could be stored in IRR and request a interrupt service routine (assertion of INTR) if the according IMR bit is not set.

#### 7.4.3 Ininitialization Sequence

The System FPGA requires the initial sequence which is described in 5.1.10. The state in the Sysytem FPGA transit to the succeding state at the time each ICW is received. After reset, the Sysytem FPGA goes to the state which is waiting for writeing ICW1 immedeatly. After writeing ICW1, goes to the state which is waiting for ICW2. Finally, initialization is completed after ICW4 is written.

#### 7.4.4 NMI

## 7.5 Timer Control

#### 7.5.1 Internal Block Diagram



#### 7.5.2 Control Word Register

The System FPGA supports counter0 and mode2 (rate generator) only. The according registers are hardwired to set this mode. Control Word Register and Read/Write logic has control states which are Counter Latch Command state, Read/Write LSB only state, Read/Write MSB only state, and Read/Write LSB first, then MSB state. These states are set by writing a data to Control Register.

In Counter Latch Command state, the System FPGA latches the value of counter0 at Output Latch, and expects CPU reads LSB first and then MSB. After reading LSB and MSB, these value are unlatched respectively.

In Read/Write LSB only state, Read/Write MSB only state, and Read/Write LSB first, then MSB state, the value of counter0 is not latched. CPU reads the output from Output Latch according to the state which is set into Control Word register.

#### 7.5.3 Counter Enable

Writing the inial counter data to Couner Register enables counter0 operation. After reset, counter0 is dsable. After set of Counter Register, counter0 operation is started. On the other hand, 33MHz divider is always enabled and is not enable by setting a register.

#### 7.5.4 Counter0 Operation with Mode2 (Rate Generator)

This mode functions like a divide-by-N counter. Interupt request to interrupt control is initially low. When the initial count has decremented to 1. The interrupt request goes high 1 33MHz clock. The interrupt request then



goes low again, the counter0 reloads the initial count and the process is repeated. For an initial count of M, the sequence repeats every M clk cycles. After writing a Timer Control Word and initial count, the counter0 will be loaded on the next clk pulse.

The following picture describes the mode 2 operation.



#### 7.5.5 33MHz clock divider

The operation of 33MHz clock is described in 5.2.5. This divider is always enabled to generate the 1.19318MHz clock. This divider has three counters in it. One is the counter which divide 33MHz clk by 27 or 28. Other two counters are used for deciding whether 33MHz clk should be divided by 27 or 28.

Assumed Cij is the cycle number which indicate 33MHz clk should be divided by 27 or 28, and i is one of (0,1,2) and j is one of (0,1,2,...,33,34). Cij is incremented and repeated like C0.0, C0.1, C0.2, C1.0, C1.1, C1.2,...,C34.0, C34.1, C34.2, C0.0, C0.1, C0.2,.... The other two counters are for representing i and j. In the cycle: Cij with j=0 and Cij with j=2 and i=34, 33MHz clk is divided by 27. In other cycles, 33MHz clk is divided by 28.

## 7.6 Real\_Time\_Clock\_Control

As described in 5.3, real\_time\_clock\_control comprises a bunch of registers. Some registers are hardwired and some registers are read/write enabled.

## 7.7 Emulated BIOS Control

Emulated bios control comprises an array of read only registers.

#### 7.8 Reset\_Control

#### 7.8.1 Internal Block





#### 7.8.2 Hardware Reset

Hard reset will be generated when bit1 in Reset Control Register is a 1 and bit2 translates a 0 to a 1 or when PWORK signal is asserted. Hard reset assert three external signals (CPURST and PCIRST#) and resets the current state in the System FPGA.

The following figures describes the time-chart of reset sequence. Internal Reset signal, CPURST, and PCIR-ST are asserted when PWORK is negated or hard reset trigger signal is asserted. The hard reset trigger signal is asserted when bit1 in Reset Control Register is a 1 and bit2 translates a 0 to a 1. Then, Internal Reset signal, CPURST, and PCIRST will be asserted for 1msec (33K 33MHz Clock pulses). Hard reset generator has 16bit counter. The counter starts to count and internal reset signal, CPURST, and PCIRST are asserted after PWORK is asserted. When the The count is incremented to 33K, couting is stopped and internal reset signal, CPURST, and PCIRST are deasserted.





#### 7.8.3 Soft Rest

Soft reset will be generated when bit1 in Reset Control Register is a 0 and bit2 translates a 0 to a 1.

The following figures describes the time-chart of reset sequence. INIT is asserted when soft reset trigger signal is asserted. The soft reset trigger signal is asserted when bit1 in Reset Control Register is a 0 and bit2 translates a 0 to a 1. INIT will be asserted for a 2 clock.



## 7.9 EXP-FPGA Config\_Control (put off now)

DRAFT

## 8 Development Board Design



