# AXIS ETRAX 100LX Designer's Reference Axis Communications AB cannot be held responsible for any technical or typographical errors, and reserves the right to make changes to this manual and to the product without prior notice. If you do detect any inaccuracies or omissions, please inform us at: E-mail: technology@axis.com Axis Communications AB Emdalavägen 14 SE-223 69 Lund, Sweden Phone:+46 46 272 1800 Fax: +46 46 13 61 30 Copyright © Axis Communications AB | 1 In | troduction | 1 | |--------------|------------------------------------------|----| | 1.1 | Overview | 1 | | 1.2 | Features | 2 | | 1.3 | Functional Block Diagram | | | 9 DI | SC CPU | _ | | | | | | 2.1 2.2 | Registers Flogs and Condition Codes | | | 2.3 | Flags and Condition Codes | | | | Data Organization in Memory | | | 2.4<br>2.4.1 | Instruction Format | | | | Addressing Modes | | | 2.4.2 | Data Transfers | | | 2.4.3 | Arithmetic Instructions | | | 2.4.4 | Logical Instructions | | | 2.4.5 | Shift Instructions | | | 2.4.6 | Bit Test Instructions | | | 2.4.7 | Condition Code Manipulation Instructions | | | 2.4.8 | Jump and Branch Instructions | | | 2.4.9 | No Operation Instruction | | | 2.5 | MMU Support | | | 2.5.1 | Overview | | | 2.5.2 | Protected Registers and Flags | | | 2.5.3 | Transition Between Operation Modes | | | 2.5.4 | Bus Fault Sequence | | | 2.5.5 | Format of the CPU Status Record | | | 2.6 | Integral Read-Write Operations | | | 2.7 | Interrupts | | | 2.7.1 | NMI | | | 2.8 | Software Breakpoints | | | 2.9 | Hardware Breakpoint Mechanism | 20 | | 3 Si | ngle step | 21 | | 3.1 | General | | | 3.2 | Programming Considerations | | | | | | | | emory Management Unit | | | 4.1 | MMU Memory Areas | | | 4.1.1 | Kernel/User Address Space | | | 4.1.2 | Kernel Address Space | | | 4.2 | Translation Lookaside Buffer | | | 4.2.1 | TLB Memory Sets | | | 4.2.2 | TLB Entries | | | 4.2.3 | TLB Register Interface | | | 4.2.4 | Virtual Address from the CPU | | | 4.2.5 | MMU Exceptions | | | 4.3 | MMU Registers | | | 4.4 | MMU Test Mode | | | 4.5 | Example of Virtual Memory Configuration | 34 | | 5 Bu | ıs Interface | 37 | |----------------|------------------------------------------------------------|-------------| | 5.1 | Data Bus | 37 | | 5.2 | Bus Interface Registers | | | 5.3 | Address and Chip Selects | | | 5.4 | Internal Bus Arbitration | | | 5.5 | Bus Width, Cycle Timing and Wait States | | | 5.6 | Memory Timing | | | 5.7 | Write Modes | | | 5.7.1 | Normal and Extended Write Mode | | | 5.7.2 | Bytewise and Common Write Enable Mode | | | 5.8 | External Interrupt Acknowledge | | | 5.9 | Access to Internal I/O | | | 5.10 | Wait Input and Bus Cycle Rerun | | | 5.11 | DRAM Interfaces | | | 5.12 | Asynchronous DRAM Interface | | | 5.12.1 | · | | | 5.12.2 | | | | | Synchronous DRAM Interface | | | 5.13.1 | • | | | 5.13.2 | • | | | 5.13.3 | | | | 5.13.4 | | | | 5.13.5 | | | | 5.13.6 | | | | 6 Bo | ootstrap Methods | 57 | | 6.1 | Bootstrap Methods | | | 6.1.1 | Normal Bootstrap | | | 6.1.2 | Serial Bootstrap | | | 6.1.3 | Network Bootstrap | | | 6.1.4 | Parallel Bootstrap | | | ~ D | • | | | | MA | . <b>59</b> | | 7.1 | DMA Operation | | | 7.1.1 | Overview of the ETRAX 100LX DMA Architecture | | | 7.1.2 | Data Transfer | | | 7.2 | The DMA Channels | | | 7.3 | DMA Registers, Linked Lists, and Descriptor Format | | | 7.3.1 | DMA Links Lists | | | 7.3.2 | DMA Descriptor Franct | | | 7.3.3 | DMA Descriptor Format | | | 7.4 | DMA Registers, Linked Lists, and Descriptor Format for USB | | | 7.4.1<br>7.4.2 | DMA Registers for USB DMA Linked Lists for USB | | | 1 /1 7 | LINIA LINKEA LISIS TOT LINK | . 09 | | | | | | 7.4.3 | DMA Descriptor Format for USB | . 70 | | | | . 70<br>75 | | 7.6.1 | Initiate and Setup a DMA Transfer | 76 | |-------|---------------------------------------------|-----| | 7.6.2 | Reset DMA Channel | 76 | | 7.6.3 | Initiating Linked List | 77 | | 7.6.4 | Start a DMA Transfer | 77 | | 7.6.5 | Restart a DMA Transfer | 77 | | 7.6.6 | Hold DMA Temporarily and Continue Later | 78 | | 7.7 | Memory to Memory DMA | 78 | | 7.8 | External DMA Channels | 79 | | 7.8.1 | External DMA Configuration | 80 | | 7.8.2 | External DMA Address | | | 7.8.3 | Initialization | 80 | | 7.8.4 | Request/Acknowledge Signaling | 81 | | 7.8.5 | Start and Stop of the Transfers | | | 7.8.6 | Transfer Counter | | | 7.8.7 | External DMA Interrupts | 82 | | 8 U1 | niversal Serial Bus | 83 | | 8.1 | Principle of Operation | 84 | | 8.1.1 | Basic Architecture of the USB Interface | 84 | | 8.1.2 | Modes of Operation of the USB Interface | 84 | | 8.2 | Operational States of the USB Controller | 85 | | 8.3 | USB Registers | 86 | | 8.3.1 | Register Access Timing | 86 | | 8.3.2 | USB Mode Registers | 86 | | 8.4 | USB Host mode | 88 | | 8.4.1 | USB Controller Commands in Host Mode | 89 | | 8.4.2 | USB Port (Root Hub) Commands in Host Mode | 90 | | 8.5 | USB Data Structures in Host Mode | 91 | | 8.5.1 | Transfer Frames | 91 | | 8.5.2 | DMA Descriptors | 93 | | 8.5.3 | Endpoint Table in Host Mode | 99 | | 8.5.4 | Host Mode Interrupts | 100 | | 8.6 | Device Mode | 102 | | 8.6.1 | USB Controller Commands in Device Mode | 102 | | 8.6.2 | USB Port (Root Hub) Commands in Device Mode | 103 | | 8.6.3 | USB Data Structures in Device Mode | 103 | | 8.6.4 | EP Table in Device Mode | 105 | | 8.6.5 | Device Mode Interrupts | 106 | | 8.7 | Physical Interface | 107 | | 8.7.1 | Data Transmission | 107 | | 8.7.2 | Power Management | 107 | | 8.7.3 | Hardware Reset | | | 8.8 | Procedures | | | 8.8.1 | Configuring the USB Interface for Host Mode | 108 | | 8.8.2 | Starting and Stopping the Host Mode | | | 8.8.3 | Starting and Stopping Traffic in Host Mode | | | 8.8.4 | Managing EP Descriptor Lists in Host Mode | 109 | | 8.8.5 | Managing SB Descriptor Lists in Host Mode | 110 | |--------|--------------------------------------------|-----| | 8.8.6 | Managing the EP Table in Host Mode | 111 | | 8.8.7 | Managing the DMA Channel 9 Descriptor List | 112 | | 8.8.8 | Managing the Root Hub | 112 | | 8.8.9 | Managing USB IN Traffic in Device Mode | 113 | | 8.8.10 | | | | 8.8.11 | USB Control Traffic in Device Mode | 117 | | 9 Ne | twork Interface | 119 | | | The Ethernet II and IEEE 802.3 Standards | | | 9.2 | Network interface registers | 120 | | 9.3 | Network Interface Configuration | 121 | | | Pin Usage in MII and SNI Modes | | | 9.5 | Receiver Logic Functions | 122 | | 9.5.1 | Data Transfer to the Receiving FIFO | 123 | | 9.5.2 | Address Recognition | | | 9.5.3 | Receiver CRC Check. | 124 | | 9.5.4 | Received Frame Length Check | 124 | | 9.6 | Transmitter Logic Functions | 125 | | 9.6.1 | Transmission of Frames | 125 | | 9.6.2 | CSMA/CD Access Protocol | 126 | | 9.6.3 | Demand Priority Access Protocol | 126 | | 9.7 | Management Interface | 127 | | 9.8 | Ethernet Error and Statistics Counters | 127 | | 9.9 | Network interrupts | 128 | | 10 EII | DE/ATA-2/ATA-3 Interface | 129 | | 10.1 | ATA Interface Pin Connection | 129 | | 10.2 | EIDE/ATA-2/ATA-3 Interface Registers | 130 | | 10.3 | Data Transfer | 130 | | 10.3.1 | Programmed Input/Output (PIO) | 130 | | 10.3.2 | ATA DMA Handshaking | 130 | | 10.3.3 | ETRAX 100LX Register Access | 131 | | 10.3.4 | ETRAX 100LX DMA Access | 131 | | 10.4 | Timing | 131 | | 10.5 | Interrupts | 132 | | 11 Asy | ynchronous Serial Ports | 133 | | | General | | | 11.2 | Connection to Input/Output Pins | 133 | | 11.3 | Asynchronous Serial Port Registers | 134 | | 11.4 | Operation Modes | 135 | | 11.5 | Baud Rate Selection | 136 | | 11.6 | CPU Controlled Operation | 137 | | 11.7 | DMA Controlled Operation | 137 | | 11.8 | Asynchronous Serial Port Interrupts | 138 | | 12 Syı | nchronous Serial Interface | 139 | | 12.1 | Overview | 139 | |--------|--------------------------------------------------|-------| | 12.2 | Mode Selection | 139 | | 12.3 | Pin Usage | 140 | | 12.3.1 | l Pin Configuration | . 140 | | 12.3.2 | Pin Usage in the Different Modes | . 140 | | 12.4 | Synchronous Serial Port Registers | | | 12.5 | Configuration | | | 12.6 | Word Length | | | 12.7 | Frame Synchronization | 145 | | 12.7.1 | Frame Synchronization Modes | . 145 | | 12.7.2 | Prame Strobe Generation | . 146 | | 12.7.3 | 3 Stream Mode | . 146 | | 12.8 | Clocking | 147 | | 12.8.1 | l Clock Generator | . 147 | | 12.8.2 | Pata Sampling | . 147 | | 12.8.3 | 3 Clock Gating | . 148 | | 12.9 | Flow Control | 149 | | 12.10 | Interrupts | 149 | | 12.11 | Using The Sync Serial Ports with DMA | 150 | | 13 Pa | ırallel Ports | 151 | | | Parallel Port Registers | | | | Modes of Operation | | | 13.2.1 | • | | | 13.2.2 | | | | 13.2.3 | , | | | 13.2.4 | 4 IEEE-1284 Byte Mode | . 159 | | 13.2.5 | · | | | 13.2.6 | B ECP Wide (16-Bit) Mode | . 163 | | 13.2.7 | 7 EPP Mode | . 165 | | 13.2.8 | B Manual Mode | . 169 | | 13.3 | Parallel Port Interrupts | 170 | | 13.3.1 | Peripheral Interrupt | . 170 | | 13.3.2 | 2 ECP Command Interrupt | . 170 | | 13.3.3 | B Data Available Interrupt | . 170 | | 13.3.4 | 4 Ready Interrupt | . 171 | | 13.3.5 | EPP Interrupts | . 171 | | 14 Sh | nared RAM Interface | 173 | | | Shared RAM Interface Configuration | | | | Shared RAM Interrupts | | | 15 Ti | mers | 175 | | 15.1 | General | | | 15.2 | Timer Registers | | | | Clock Prescaling: The Programmable Clock Divider | | | | Programmable Timers. | | | 15.4.1 | <b>8</b> | | ## **Contents** | 15.5 Timer Input Clock | 177 | |-----------------------------------------------------------------|-----| | 15.5.1 Timer0 Input Clock | 177 | | 15.5.2 Timer1 Input Clock | 178 | | 15.6 Cascade Mode | 178 | | 15.7 Watchdog Timer | 178 | | 15.8 Timer Interrupts | 179 | | 16 General I/O Ports | 181 | | 16.1 General Port PA | | | 16.1.1 Interrupts at General Port PA | 181 | | 16.2 General Port PB | | | 16.2.1 Configuration of Signal Directions at General Port PB | 183 | | 16.2.2 General Port PB and the I2C Interface | | | 16.2.3 General Port PB and the Peripheral Chip-Select Signals | | | 16.2.4 General Port PB and the Synchronous Serial Ports | | | 16.2.5 General Port PB and the SCSI Ports | | | 16.2.6 General Port PB and the USB Ports | 185 | | 16.3 Discrete General Ports | | | 16.4 General I/O Registers | 186 | | 17 Interrupts | 187 | | 17.1 Interrupt Masks | | | 17.2 Interrupt Status | | | 17.3 USB Interrupts | | | 17.4 Interrupt Registers | | | 17.5 Non-Maskable Interrupts | | | 17.6 Masked Interrupts with Internally Generated Vector Numbers | | | 17.6.1 Interrupts in Register Sub-Set 0 | | | 17.6.2 Interrupts in Register Sub-Set 1 | | | 17.6.3 Interrupts in Register Sub-Set 2 | | | 17.6.4 Interrupts in the USB Register Set | 201 | | 17.6.5 Vector Number Register Sub-Set | 202 | | 17.7 External Maskable Interrupt with an External Vector Number | 204 | | 17.8 Software Interrupts | 204 | | 18 Internal Registers | 207 | | 18.1 Conventions | | | 18.1.1 Notation | 207 | | 18.1.2 Base Address | 207 | | 18.2 Bus Interface Configuration Registers | 207 | | 18.2.1 R_WAITSTATES | 207 | | 18.2.2 R_BUS_CONFIG | 209 | | 18.2.3 R_BUS_STATUS | 210 | | 18.2.4 R_DRAM_TIMING | 211 | | 18.2.5 R_SDRAM_TIMING | 212 | | 18.2.6 R_DRAM_CONFIG | 213 | | 18.2.7 R_SDRAM_CONFIG | 215 | | 18.3 External DMA Registers | 217 | | 18.3.1 | R_EXT_DMA_0_CMD | 217 | |---------|-------------------------------------|-----| | 18.3.2 | R_EXT_DMA_0_STAT | 218 | | 18.3.3 | R_EXT_DMA_0_ADDR | 219 | | 18.3.4 | R_EXT_DMA_I_CMD | 220 | | 18.3.5 | R_EXT_DMA_I_STAT | 221 | | 18.3.6 | R_EXT_DMA_I_ADDR | 222 | | 18.4 Ti | mer Registers | 223 | | 18.4.1 | R_TIMER_CTRL | | | 18.4.2 | R TIMER DATA | | | 18.4.3 | R TIMER01 DATA | 226 | | 18.4.4 | R_TIMERO_DATA | 227 | | 18.4.5 | R_TIMER1_DATA | | | 18.4.6 | R WATCHDOG | | | 18.4.7 | R_CLOCK_PRESCALE | | | 18.4.8 | R_TIMER_PRESCALE | | | 18.4.9 | R PRESCALE STATUS | | | 18.4.10 | R_TIM_PRESC_STATUS | | | | ared RAM Interface Registers | | | 18.5.1 | R SHARED RAM CONFIG | | | 18.5.2 | R_SHARED_RAM_ADDR | | | | eneral Configuration Registers | | | 18.6.1 | R GEN CONFIG | | | 18.6.2 | R_GEN_CONFIG_II | | | 18.6.3 | R_PORT_G_DATA | | | 18.7 Ge | eneral Port Configuration Registers | | | 18.7.1 | R_PORT_PA_SET | | | 18.7.2 | R_PORT_PA_DATA | | | 18.7.3 | R PORT PA DIR | | | 18.7.4 | R PORT PA READ | | | 18.7.5 | R_PORT_PB_SET | | | 18.7.6 | R_PORT_PB_DATA | | | 18.7.7 | R PORT PB DIR | | | 18.7.8 | | | | 18.7.9 | R_PORT_PB_I2C | | | 18.7.10 | R_PORT_PB_READ | | | | rial Port Registers | | | 18.8.1 | R SERIALO CTRL | | | 18.8.2 | R_SERIALO_BAUD | | | 18.8.3 | R_SERIALO_REC_CTRL | | | 18.8.4 | R_SERIALO_TR_CTRL | | | 18.8.5 | R_SERIALO_TR_DATA | | | 18.8.6 | R_SERIALO_READ | | | 18.8.7 | R SERIALO STATUS | | | 18.8.8 | R_SERIALO_REC_DATA | | | 18.8.9 | R_SERIALO_XOFF | | | 18.8.10 | | | | | | | | 18.8.11 | R_SERIAL1_BAUD | 263 | |---------|----------------------------|-----| | 18.8.12 | R_SERIAL1_REC_CTRL | 264 | | 18.8.13 | R_SERIAL1_TR_CTRL | 265 | | 18.8.14 | R_SERIAL1_TR_DATA | 266 | | 18.8.15 | R_SERIAL1_READ | 267 | | 18.8.16 | R_SERIAL1_STATUS | 268 | | 18.8.17 | R_SERIAL1_REC_DATA | 269 | | 18.8.18 | R_SERIAL1_XOFF | 270 | | 18.8.19 | R_SERIAL2_CTRL | 271 | | 18.8.20 | R_SERIAL2_BAUD | 273 | | 18.8.21 | R_SERIAL2_REC_CTRL | 274 | | 18.8.22 | R_SERIAL2_TR_CTRL | 275 | | 18.8.23 | R_SERIAL2_TR_DATA | 276 | | 18.8.24 | R SERIAL2 READ | | | 18.8.25 | R_SERIAL2_STATUS | 278 | | 18.8.26 | R SERIAL2 REC DATA | | | 18.8.27 | R SERIAL2 XOFF | | | 18.8.28 | R_SERIAL3_CTRL | | | 18.8.29 | R_SERIAL3_BAUD | | | 18.8.30 | R_SERIAL3_REC_CTRL | | | 18.8.31 | R_SERIAL3_TR_CTRL | | | 18.8.32 | R_SERIAL3_TR_DATA | | | 18.8.33 | R SERIAL3 READ | | | 18.8.34 | R_SERIAL3_STATUS | | | 18.8.35 | R_SERIAL3_REC_DATA | | | 18.8.36 | R_SERIAL3_XOFF | | | | R_ALT_SER_BAUDRATE | | | 18.8.38 | R_SERIAL_PRESCALE | | | 18.8.39 | R_SER_PRESC_STATUS | | | | etwork Interface Registers | | | 18.9.1 | R_NETWORK_SA_0 | | | 18.9.2 | R_NETWORK_SA_1 | | | 18.9.3 | R_NETWORK_SA_2 | | | 18.9.4 | R_NETWORK_GA_0 | | | 18.9.5 | R_NETWORK_GA_1 | | | 18.9.6 | R_NETWORK_REC_CONFIG | | | 18.9.7 | R_NETWORK_GEN_CONFIG | | | 18.9.8 | R_NETWORK_TR_CTRL | | | 18.9.9 | R_NETWORK_MGM_CTRL | | | | R_NETWORK_STAT | | | | R_REC_COUNTERS | | | | R_TR_COUNTERS | | | | R_PHY_COUNTERS | | | | rallel Port Registers | | | | R_PARO_CTRL_DATA | | | | R_PARO_CTRL | | | 10.10.2 | N_I ANU_C1NL | 510 | | 18.10.3 | R_PAR0_STATUS_DATA | 311 | |----------|----------------------------------|-----| | | R_PAR0_STATUS | | | | R PAR ECP16 DATA | | | | R PARO CONFIG | | | | R_PAR0_DELAY | | | | R_PAR1_CTRL_DATA | | | | R PAR1 CTRL | | | | R_PAR1_STATUS_DATA | | | | R PAR1 STATUS | | | 18.10.12 | R PAR1 CONFIG | 327 | | | R_PAR1_DELAY | | | | <br>'A Interface Registers | | | | R_ATA_CTRL_DATA | | | | R_ATA_STATUS_DATA | | | | R_ATA_CONFIG | | | | R_ATA_TRANSFER_CNT | | | | SI Registers. | | | | R_SCSI0_CTRL | | | | R SCSIO CMD DATA | | | | R_SCSI0_DATA | | | | R SCSIO CMD | | | | R SCSIO STATUS CTRL | | | | R_SCSI0_STATUS | | | | R_SCSI0_DATA_IN | | | | R SCSI1 CTRL | | | | R_SCSI1_CMD_DATA | | | | R_SCSI1_DATA | | | | R SCSI1 CMD | | | | R_SCSI1_STATUS_CTRL | | | | R_SCSI1_STATUS | | | | R_SCSI1_DATA_IN | | | | errupt Mask and Status Registers | | | | R_IRQ_MASK0_RD | | | | R_IRQ_MASK0_CLR | | | | R_IRQ_READ0 | | | | R_IRQ_MASK0_SET | | | | R IRQ MASK1 RD | | | | R_IRQ_MASK1_CLR | | | | R_IRQ_READ1 | | | | R_IRQ_MASK1_SET | | | | R_IRQ_MASK2_RD | | | | R_IRQ_MASK2_CLR | | | | R_IRQ_READ2 | | | | R_IRQ_MASK2_SET | | | | R_VECT_MASK_RD | | | | R_VECT_MASK_CLR | | | 10.10.14 | | 500 | | 18.13.15 R_VECT_READ | 388 | |-----------------------------|-----| | 18.13.16 R_VECT_MASK_SET | 390 | | 18.14 DMA Registers | 391 | | 18.14.1 R_SET_EOP | 391 | | 18.14.2 R_DMA_CH0_HWSW | 392 | | 18.14.3 R_DMA_CH0_DESCR | 393 | | 18.14.4 R_DMA_CH0_NEXT | 394 | | 18.14.5 R_DMA_CH0_BUF | 395 | | 18.14.6 R_DMA_CH0_FIRST | 396 | | 18.14.7 R_DMA_CH0_CMD | 397 | | 18.14.8 R_DMA_CH0_CLR_INTR | 398 | | 18.14.9 R_DMA_CH0_STATUS | 399 | | 18.14.10 R_DMA_CH1_HWSW | 400 | | 18.14.11 R_DMA_CH1_DESCR | 401 | | 18.14.12 R_DMA_CH1_NEXT | 402 | | 18.14.13 R DMA CH1 BUF | 403 | | 18.14.14 R_DMA_CH1_FIRST | 404 | | 18.14.15 R DMA CH1 CMD | | | 18.14.16 R DMA CH1 CLR INTR | 406 | | 18.14.17 R_DMA_CH1_STATUS | | | 18.14.18 R_DMA_CH2_HWSW | | | 18.14.19 R DMA CH2 DESCR | | | 18.14.20 R_DMA_CH2_NEXT | | | 18.14.21 R_DMA_CH2_BUF | | | 18.14.22 R_DMA_CH2_FIRST | | | 18.14.23 R_DMA_CH2_CMD | | | 18.14.24 R_DMA_CH2_CLR_INTR | | | 18.14.25 R_DMA_CH2_STATUS | | | 18.14.26 R_DMA_CH3_HWSW | | | 18.14.27 R_DMA_CH3_DESCR | | | 18.14.28 R_DMA_CH3_NEXT | | | 18.14.29 R_DMA_CH3_BUF | | | 18.14.30 R_DMA_CH3_FIRST | | | 18.14.31 R_DMA_CH3_CMD | | | 18.14.32 R DMA CH3 CLR INTR | | | 18.14.33 R_DMA_CH3_STATUS | | | 18.14.34 R_DMA_CH4_HWSW | | | 18.14.35 R_DMA_CH4_DESCR | | | 18.14.36 R_DMA_CH4_DESCR | | | 18.14.37 R_DMA_CH4_BUF | | | 18.14.37 R_DMA_CH4_BUF | | | 18.14.39 R_DMA_CH4_FIRS1 | | | | | | 18.14.40 R_DMA_CH4_CLR_INTR | | | 18.14.41 R_DMA_CH4_STATUS | | | 18.14.42 R_DMA_CH5_HWSW | | | 18.14.43 R_DMA_CH5_DESCR | 433 | | 18.14.44 R_DMA_CH5_NEXT | 434 | |----------------------------------|-----| | 18.14.45 R_DMA_CH5_BUF | 435 | | 18.14.46 R_DMA_CH5_FIRST | 436 | | 18.14.47 R_DMA_CH5_CMD | 437 | | 18.14.48 R_DMA_CH5_CLR_INTR | 438 | | 18.14.49 R_DMA_CH5_STATUS | 439 | | 18.14.50 R_DMA_CH6_HWSW | 440 | | 18.14.51 R_DMA_CH6_DESCR | 441 | | 18.14.52 R_DMA_CH6_NEXT | 442 | | 18.14.53 R_DMA_CH6_BUF | 443 | | 18.14.54 R_DMA_CH6_FIRST | 444 | | 18.14.55 R_DMA_CH6_CMD | 445 | | 18.14.56 R_DMA_CH6_CLR_INTR | 446 | | 18.14.57 R_DMA_CH6_STATUS | 447 | | 18.14.58 R_DMA_CH7_HWSW | 448 | | 18.14.59 R_DMA_CH7_DESCR | 449 | | 18.14.60 R_DMA_CH7_NEXT | 450 | | 18.14.61 R_DMA_CH7_BUF | 451 | | 18.14.62 R_DMA_CH7_FIRST | 452 | | 18.14.63 R_DMA_CH7_CMD | 453 | | 18.14.64 R_DMA_CH7_CLR_INTR | 454 | | 18.14.65 R_DMA_CH7_STATUS | 455 | | 18.14.66 R_DMA_CH8_HWSW | 456 | | 18.14.67 R_DMA_CH8_DESCR | 457 | | 18.14.68 R_DMA_CH8_NEXT | 458 | | 18.14.69 R_DMA_CH8_BUF | 459 | | 18.14.70 R_DMA_CH8_FIRST | 460 | | 18.14.71 R_DMA_CH8_CMD | 461 | | 18.14.72 R_DMA_CH8_CLR_INTR | 462 | | 18.14.73 R_DMA_CH8_STATUS | 463 | | 18.14.74 R_DMA_CH8_SUB | 464 | | 18.14.75 R_DMA_CH8_NEP | 465 | | 18.14.76 R_DMA_CH8_SUB0_EP | 466 | | 18.14.77 R_DMA_CH8_SUB0_CMD | 467 | | 18.14.78 R_DMA_CH8_SUB0_CLR_INTR | 468 | | 18.14.79 R_DMA_CH8_SUB1_EP | 469 | | 18.14.80 R_DMA_CH8_SUB1_CMD | 470 | | 18.14.81 R_DMA_CH8_SUB1_CLR_INTR | 471 | | 18.14.82 R_DMA_CH8_SUB2_EP | 472 | | 18.14.83 R_DMA_CH8_SUB2_CMD | 473 | | 18.14.84 R_DMA_CH8_SUB2_CLR_INTR | 474 | | 18.14.85 R_DMA_CH8_SUB3_EP | 475 | | 18.14.86 R_DMA_CH8_SUB3_CMD | | | 18.14.87 R_DMA_CH8_SUB3_CLR_INTR | | | 18.14.88 R_DMA_CH9_HWSW | 478 | | 18.14.89 R_DMA_CH9_DESCR | | | 18.14.90 | R_DMA_CH9_NEXT | 480 | |----------|-------------------------------------------------|-----| | 18.14.91 | R_DMA_CH9_BUF | 481 | | 18.14.92 | R_DMA_CH9_FIRST | 482 | | 18.14.93 | R_DMA_CH9_CMD | 483 | | 18.14.94 | R_DMA_CH9_CLR_INTR | 484 | | 18.14.95 | R_DMA_CH9_STATUS | 485 | | | st Mode Registers | | | 18.15.1 | R_TEST_MODE | 486 | | 18.15.2 | R_SINGLE_STEP | 488 | | 18.16 Un | uiversal Serial Bus Interface Control Registers | 489 | | | R_USB_REVISION | | | 18.16.2 | R_USB_COMMAND | 490 | | 18.16.3 | R_USB_COMMAND_DEV | 491 | | 18.16.4 | R_USB_STATUS | 492 | | 18.16.5 | R_USB_IRQ_MASK_SET | 493 | | 18.16.6 | R_USB_IRQ_MASK_READ | 494 | | 18.16.7 | R_USB_IRQ_MASK_CLR | 495 | | 18.16.8 | R_USB_IRQ_READ | 496 | | 18.16.9 | R_USB_IRQ_MASK_SET_DEV | 497 | | 18.16.10 | R_USB_IRQ_MASK_READ_DEV | 498 | | 18.16.11 | R_USB_IRQ_MASK_CLR_DEV | 499 | | 18.16.12 | R_USB_IRQ_READ_DEV | 500 | | 18.16.13 | R_USB_FM_NUMBER | 501 | | 18.16.14 | R_USB_FM_NUMBER_DEV | 502 | | 18.16.15 | R_USB_FM_INTERVAL | 503 | | 18.16.16 | R_USB_FM_REMAINING | 504 | | 18.16.17 | R_USB_FM_PSTART | 505 | | 18.16.18 | R_USB_RH_STATUS | 506 | | 18.16.19 | R_USB_RH_PORT_STATUS_1 | 507 | | 18.16.20 | R_USB_RH_PORT_STATUS_2 | 508 | | 18.16.21 | R_USB_EPT_INDEX | 509 | | 18.16.22 | R_USB_EPT_DATA | 510 | | 18.16.23 | R_USB_EPT_DATA_ISO | 511 | | 18.16.24 | R_USB_EPT_DATA_DEV | 512 | | 18.16.25 | R_USB_EPID_ATTN | 513 | | 18.16.26 | R_USB_PORT1_DISABLE | 514 | | 18.16.27 | R_USB_PORT2_DISABLE | 515 | | 18.17 MI | MU Registers | 516 | | 18.17.1 | R_MMU_CONFIG | 516 | | 18.17.2 | R_MMU_KSEG | 518 | | 18.17.3 | R_MMU_CTRL | 519 | | 18.17.4 | R_MMU_ENABLE | 520 | | 18.17.5 | R_MMU_KBASE_LO | 521 | | 18.17.6 | R_MMU_KBASE_HI | 522 | | 18.17.7 | R_MMU_CONTEXT | 523 | | 18.17.8 | R_MMU_CAUSE | 524 | | | 525 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | 18.17.10 R_TLB_LO | 526 | | 18.17.11 R_TLB_HI | 527 | | 18.18 Synchronous Serial Port Registers | 528 | | 18.18.1 R_SYNC_SERIAL1_REC_DATA | 528 | | 18.18.2 R_SYNC_SERIAL1_REC_WORD | 529 | | 18.18.3 R_SYNC_SERIAL1_REC_BYTE | 530 | | 18.18.4 R_SYNC_SERIAL1_STATUS | 531 | | 18.18.5 R_SYNC_SERIAL1_TR_DATA | 532 | | 18.18.6 R_SYNC_SERIAL1_TR_WORD | 533 | | 18.18.7 R_SYNC_SERIAL1_TR_BYTE | 534 | | 18.18.8 R_SYNC_SERIAL1_CTRL | 535 | | 18.18.9 R_SYNC_SERIAL3_REC_DATA | 538 | | 18.18.10 R_SYNC_SERIAL3_REC_WORD | 539 | | 18.18.11 R_SYNC_SERIAL3_REC_BYTE | 540 | | 18.18.12 R_SYNC_SERIAL3_STATUS | 541 | | 18.18.13 R_SYNC_SERIAL3_TR_DATA | 542 | | 18.18.14 R_SYNC_SERIAL3_TR_WORD | 543 | | 18.18.15 R_SYNC_SERIAL3_TR_BYTE | 544 | | 18.18.16 R_SYNC_SERIAL3_CTRL | | | 18.18.17 R_SYNC_SERIAL_PRESCALE | 548 | | 19 Electrical Information | 551 | | 19.1 Pinout | | | 19.2 Clock and PLL Signals | | | 0 | | | 19.3 Power and Ground Signals | 552 | | 19.3 Power and Ground Signals | | | 19.4 Bus Interface Signals | 553 | | <ul><li>19.4 Bus Interface Signals</li><li>19.5 Logic Analyzer Mode and Test Signals</li></ul> | 553<br>556 | | <ul> <li>19.4 Bus Interface Signals</li> <li>19.5 Logic Analyzer Mode and Test Signals</li> <li>19.6 General Port PA Signals</li> </ul> | 553<br>556<br>557 | | <ul> <li>19.4 Bus Interface Signals</li> <li>19.5 Logic Analyzer Mode and Test Signals</li> <li>19.6 General Port PA Signals</li> <li>19.7 Asynchronous Serial Port 0 Signals</li> </ul> | 553<br>556<br>557 | | 19.4 Bus Interface Signals | 553 556 557 558 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups | 553 556 557 557 558 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A | 553 556 557 558 561 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A | 553 556 557 558 561 561 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B | 553 556 557 558 559 561 562 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C | 553 556 557 558 561 562 562 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D | 553 556 557 558 561 562 562 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E | 553 556 557 558 561 562 563 563 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E 19.9.6 Multiplexed I/O Signals - Group F | 553<br>556<br>557<br>558<br>561<br>562<br>562<br>563<br>563 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E 19.9.6 Multiplexed I/O Signals - Group F 19.10 Multiplexed Interfaces | 553 556 557 558 561 562 563 563 564 | | 19.4 Bus Interface Signals | 553<br>556<br>557<br>558<br>561<br>562<br>562<br>563<br>563<br>564 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E 19.9.6 Multiplexed I/O Signals - Group F 19.10 Multiplexed Interfaces 19.10.1 SCSI Ports 19.10.2 ATA | 553 556 557 558 561 562 562 563 563 564 567 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E 19.9.6 Multiplexed I/O Signals - Group F 19.10 Multiplexed Interfaces 19.10.1 SCSI Ports 19.10.2 ATA 19.10.3 Parallel Ports | 553 556 557 558 561 562 562 563 564 564 564 565 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E 19.9.6 Multiplexed I/O Signals - Group F 19.10 Multiplexed Interfaces 19.10.1 SCSI Ports 19.10.2 ATA 19.10.3 Parallel Ports 19.10.4 Shared RAM and Shared RAM-W 19.10.5 Asynchronous Serial Ports 19.10.6 Synchronous Serial Ports p1 and p3 | 553 556 557 558 561 562 562 563 564 564 567 570 | | 19.4 Bus Interface Signals 19.5 Logic Analyzer Mode and Test Signals 19.6 General Port PA Signals 19.7 Asynchronous Serial Port 0 Signals 19.8 Network Interface Signals 19.9 Multiplexed Signal Groups 19.9.1 Multiplexed I/O Signals - Group A 19.9.2 Multiplexed I/O Signals - Group B 19.9.3 Multiplexed I/O Signals - Group C 19.9.4 Multiplexed I/O Signals - Group D 19.9.5 Multiplexed I/O Signals - Group E 19.9.6 Multiplexed I/O Signals - Group F 19.10 Multiplexed Interfaces 19.10.1 SCSI Ports 19.10.2 ATA 19.10.3 Parallel Ports 19.10.4 Shared RAM and Shared RAM-W 19.10.5 Asynchronous Serial Ports | 553 556 557 558 561 562 562 563 564 564 567 567 572 573 | ## Contents | 19.10.9 | I2C | 577 | |-----------|---------------------------------------|------------| | 19.10.10 | General Port PB | 577 | | 19.11 I/C | O Pin Default Values | 578 | | | C Electrical Specifications | | | | Absolute Maximum Ratings | | | | Recommended Operating Conditions | | | | Capacitance | | | | DC Electrical Characteristics | | | 19.12.5 | Input Buffer Types | 580 | | | Electrical Specifications | | | | Conditions | | | 19.13.2 | SRAM/Flash/Peripheral Timing | 583 | | | Synchronous DRAM | | | 19.13.4 | Asynchronous DRAM | 590 | | 19.13.5 | General Bus Interface Timing Diagrams | 594 | | | External DMA Timing Diagrams | | | | irq and nmi Timing | | | | Shared RAM Interface Timing | | | 19.13.9 | Network Interface Timing | 604 | | 19.13.10 | Reset and Clock Timing | 605 | | | ysical Dimensions | | | Appendi | ix A Register Address Index | <b>309</b> | | | | 615 | | | | | # 1 Introduction Optimized Network Controller with RISC CPU, Cache and Multiple I/O Ports ### 1.1 Overview The AXIS ETRAX 100LX is a single-chip integrated circuit designed for embedded network connectivity applications. The ETRAX 100LX improves upon the features available for the AXIS ETRAX 100, including support for Universal Serial Bus 1.1. It is compatible with the widespread ETRAX family, and offers further advances in microprocessor design and performance. The ETRAX 100LX chip incorporates the AXIS CRIS CPU which not only suits all the requirements of a network connectivity product, but also acts as an integrated core especially suited for our system. The ETRAX 100LX is ideal in executing multi protocol network stacks on one chip. The ETRAX 100LX has a 100 MIPS RISC CPU, 8 kilobyte unified instruction/data cache, high bandwidth DMA controlled I/O ports, and an on-chip Fast Ethernet controller. Its integrated functions, minimal power consumption, and high code density makes it highly suitable for a wide range of embedded applications that require high performance and low system cost. The ETRAX 100LX programmable bus interface supports both 16-bit and 32-bit data bus widths, and interfaces directly to SDRAM, EDO DRAM, SRAM, EPROM, parallel EEPROM, and FlashPROM. ## 1.2 Features - High performance 100 MIPS (200 MIPS/W) 32-bit RISC CPU, 112k Dhrystones. - Designed specifically for running Linux by including an MMU. - Ethernet controller supports 100Mbit/10Mbit MII (Compatible with IEEE 802.3 and Fast Ethernet standards). - Four asynchronous serial ports with an internal baudrate programmable from 48 Hz to 6.25 MHz, and an external baudrate up to 3.125 MHz. - Two synchronous serial ports. Master or Slave synchronous serial mode with a codec clock between 32 kHz and 4.096 MHz. - Universal Serial Bus 1.1 Host and Device mode operation. Hardware support for dynamic connect/disconnect, suspend/resume and remote wakeup. - Configuration of up to four EIDE/ATA-2 ports for up to 8 IDE disk drives. - 16-bit general I/O port. The direction of each bit can be individually controlled. - Two configurable parallel I/O ports for Centronics, IEEE 1284 byte, ECP, and EPP mode, and Shared RAM interface. - Optimized for compact code and high speed with configurable 16-bit or 32-bit bus width. - Bus interface supporting SDRAM, EDO DRAM, SRAM, EPROM, parallel EEPROM, and FlashPROM. - 8 kilobyte on chip cache memory. - DMA controlled network and port I/O for high performance - Excellent C/C++ language support and high code density. - Configurable bootstrap through network, serial, and parallel ports as well as FlashPROM. - Low power consumption, 350 mW typically. - 256-pin PBGA package, 27 x 27 x 2.15 mm. # 1.3 Functional Block Diagram The CPU in ETRAX 100LX is a RISC CPU with internal cache memory. Data handling is provided by internal DMA within the chip as well as to and from external units. The internal clocks are generated by a PLL clock multiplier that takes its input from an external clock generator. ETRAX 100LX provides internal and external vectorized interrupt. # 2 RISC CPU The CPU in ETRAX 100LX is a 32-bit RISC CPU with a 16-bit wide instruction. The CPU complies with the Axis Code Reduced Instruction Set (CRIS) architecture. It runs at a cycle frequency of 100 MHz, giving a peak performance of 100 MIPS. A summary of the CRIS architecture is given below. The CRIS CPU architecture is described in more detail in the "ETRAX 100LX Programmer's Manual". # 2.1 Registers The processor contains 14 32-bit *General Registers* (R0 - R13), one 32-bit *Stack Pointer* (R14 or SP), and one 32-bit *Program Counter* (R15 or PC). The processor architecture also contains 16 *Special Registers* (P0 - P15), ten of which are implemented. The registers are presented in the figures below: #### **General Registers:** Figure 2-1 General Registers #### **Special Registers:** Figure 2-2 Special Registers # 2.2 Flags and Condition Codes The Condition Code Register (CCR) and its 32-bit extension, the Dword Condition Code Register (DCCR), for the ETRAX 100LX contain eleven different flags. The remaining bits are always zero: Figure 2-3 The Condition Code Register (CCR)/Dword Condition Code Register (DCCR) These flags can be tested using one of the 16 *condition codes* specified below: | Code | Alt | Condition | Encoding | <b>Boolean Function</b> | |------|-----|------------------|----------|-----------------------------------------------------------| | CC | HS | Carry Clear | 0000 | C | | CS | LO | Carry Set | 0001 | С | | NE | | Not Equal | 0010 | Z | | EQ | | Equal | 0011 | Z | | VC | | Overflow Clear | 0100 | $\overline{V}$ | | VS | | Overflow Set | 0101 | V | | PL | | Plus | 0110 | $\overline{N}$ | | MI | | Minus | 0111 | N | | LS | | Low or Same | 1000 | C + Z | | HI | | High | 1001 | $\overline{C} * \overline{Z}$ | | GE | | Greater or Equal | 1010 | $N * V + \overline{N} * \overline{V}$ | | LT | | Less Than | 1011 | $N*\overline{V}+\overline{N}*V$ | | GT | | Greater Than | 1100 | $N*V*\overline{Z}+\overline{N}*\overline{V}*\overline{Z}$ | | LE | | Less or Equal | 1101 | $Z + N * \overline{V} + \overline{N} * V$ | | A | | Always True | 1110 | 1 | | WF | | Write Failed | 1111 | P | Table 2-1 Condition Codes # 2.3 Data Organization in Memory The data types supported by the CRIS are: | Name | Description | Size Modifier | |-------|---------------------------|---------------| | Byte | 8-bit integer | .B | | Word | 16-bit integer | .W | | Dword | 32-bit integer or address | .D | Table 2-2 Data Types supported by the CRIS Each address location contains one byte of data. Data is stored in memory with the least significant byte at the lowest address ("little endian"). The CRIS CPU in ETRAX 100LX has a 32-bit wide data bus. A conversion from 32 bits to 16 bits is performed by the bus interface in the case of an external 16-bit data bus mode. Data can be aligned to any address. If the data crosses a 32-bit boundary, the CPU will split the data access into two separate accesses. So, the use of unaligned word and dword data will degrade performance. The figures below show examples of data organization with a 16-bit bus and a 32-bit bus: Figure 2-4 Example of Data Organization with a 16-bit Bus Figure 2-5 Example of Data Organization with a 32-bit Bus ## 2.4 Instruction Format The basic instruction word is 16 bits long. Instructions must be 16-bit aligned. When the CPU fetches 32 bits, containing two 16-bit aligned instructions, it saves the upper two bytes in an internal prefetch register. Thus, the CPU will only perform one read for every second instruction when running consecutive code. The most common instructions follow the same general instruction format: Figure 2-6 General Instruction Format The following definitions apply to the instruction descriptions: | Syntax | Definition | |--------|------------------------------------------------------------------------------| | m | Size modifier, byte, word or dword | | z | Size modifier, byte or word | | Rm | General register | | Rn | General register | | Rp | General register | | Rs | Source operand, register addressing mode | | [Rs] | Source operand, indirect addressing mode | | [Rs+] | Source operand, auto increment addressing mode | | S | Source operand, any addressing mode except quick immediate | | si | Source operand, any mode except register or quick immediate | | se | Source operand, indexed, offset, double indirect or absolute addressing mode | | Pn | Special register | | Ps | Source operand, special register | | i | 6-bit signed immediate operand | | j | 6-bit unsigned immediate operand | | c | 5-bit immediate shift value | | Rd | Destination operand, register addressing mode | | [Rd] | Destination operand, indirect addressing mode | | [Rd+] | Destination operand, auto increment addressing mode | | d | Destination operand, any addressing mode except quick immediate | | di | Destination operand, any mode except register or quick immediate | | Pd | Destination operand, special register | | 0 | 8-bit branch offset, bit 0 is the sign bit | | x | 8-bit signed immediate value | | xx | 16-bit signed immediate value | | xxxx | 32-bit signed immediate value | | u | 8-bit unsigned immediate value | | uu | 16-bit unsigned immediate value | | uuuu | 32-bit unsigned immediate value | | cc | Condition code | | n | 4-bit breakpoint entry number | Table 2-3 Syntax Definitions For a description of how the flags are affected, the following definitions apply: | Syntax | Definition | |--------|--------------------------------------------------------| | - | Flag not affected | | 0 | Flag cleared | | 1 | Flag set | | * | Flag affected according to the result of the operation | Table 2-4 Flags Behavior Definitions Instructions that do not have size modifiers operate on 32-bit data. The exception to this rule are those instructions that operate on 8-bit and 16-bit special registers. ## 2.4.1 Addressing Modes The CRIS CPU has four basic addressing modes, which are encoded in the mode field of the instruction word. The basic addressing modes are: - Quick immediate mode - Register mode - · Indirect mode - Autoincrement mode (with Immediate mode as a special case) More complex addressing modes can be achieved by combining the basic instruction word with an addressing mode prefix word. The complex addressing modes are: - Indexed - Indexed with assign - Offset - Offset with assign - Double indirect - Absolute The addressing modes of the CRIS CPU are described in the table below: | Assembler Syntax | Addressing Mode | |------------------|-------------------------------------| | i, j | Quick immediate | | Rn | Register | | Pn | Special register | | [Rn] | Indirect | | [Rn+] | Post increment | | x, u | Byte immediate | | xx, uu | Word immediate | | xxxx, uuuu | Dword immediate | | [Rn+Rm.m] | Indexed | | [Rp=Rn+Rm.m] | Indexed with assign | | [Rn+[Rm].m] | Indirect offset | | [Rn+[Rm+].m] | Autoincrement offset | | [Rn+x] | Immediate byte offset | | [Rn+xx] | Immediate word offset | | [Rn+xxxx] | Immediate dword offset | | [Rp=Rn+[Rm].m] | Indirect offset with assign | | [Rp=Rn+[Rm+].m] | Autoincrement offset with assign | | [Rp=Rn+x] | Immediate byte offset with assign | | [Rp=Rn+xx] | Immediate word offset with assign | | [Rp=Rn+xxxx] | Immediate dword offset with assign | | [[Rn]] | Double indirect | | [[Rn+]] | Double indirect with auto increment | | [uuuu] | Absolute | Table 2-5 The CRIS CPU Addressing Modes ## 2.4.2 Data Transfers The data transfer instructions for the CRIS CPU, the two predefined assembler macros POP and PUSH, and the word/byte/bit SWAP instruction set are specified in table 2-6 below. | Instruction | | Fla | ag C | per | atio | n | | | | | | | Description | |------------------------------|-------|-----|------|-----|------|---|---|---|---|---|---|---|-------------------------------------------| | mstruction | | F | P | U | M | В | I | X | N | Z | ٧ | С | Description | | CLEAR.m | d | - | - | - | - | - | - | 0 | - | - | - | - | Clear destination operand | | MOVE.m | s,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Move from source to general register | | MOVE.m | Rs,di | - | - | - | - | - | - | 0 | - | - | - | - | Move from general register to memory | | MOVE<br>(Pd == CCR/<br>DCCR) | s,Pd | * | * | * | - | * | * | 0 | * | * | * | * | Move from source to special register | | MOVE<br>(Pd!= CCR/<br>DCCR) | s,Pd | - | - | - | - | - | - | 0 | - | - | - | - | Move from source to special register | | MOVE | Ps,d | - | - | - | - | - | - | 0 | - | - | - | - | Move from special register to destination | | MOVEM | Rs,di | - | - | - | - | - | - | 0 | - | - | - | - | Move multiple registers to memory | | MOVEM | si,Rd | - | - | - | - | - | - | 0 | - | - | - | - | Move from memory to multiple registers | | MOVEQ | i,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Move 6-bit signed immediate | | MOVS.z | s,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Move with sign extend | | MOVU.z | s,Rd | - | - | - | - | - | - | 0 | 0 | * | 0 | 0 | Move with zero extend | | POP | Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Pop register from stack | | POP<br>(Pd == CCR/<br>DCCR) | Pd | * | * | * | - | * | * | 0 | * | * | * | * | Pop special register from stack | | POP<br>(Pd!= CCR/<br>DCCR) | Pd | - | - | - | - | - | - | 0 | - | - | - | - | Pop special register from stack | | PUSH | Rs | - | - | - | - | - | - | 0 | - | - | - | - | Push register onto stack | | PUSH | Ps | - | - | - | - | - | - | 0 | - | - | - | - | Push special register onto stack | | SBFS | di | - | - | - | - | - | - | 0 | - | - | - | - | Save bus fault status | | SWAP <opt.></opt.> | Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Swap operand bits | Table 2-6 Data Transfer Instructions | Option | Description | |--------|-------------------------------------------------------| | N | Invert each bit | | W | Swap the words of the operand | | В | Swap the two bytes within each word of the operand | | R | Reverse the bit order within each byte of the operand | Table 2-7 Options for the Word/Byte/Bit Swap Instruction ## 2.4.3 Arithmetic Instructions The arithmetic instructions for the CRIS CPU are described in the table below: | Instruction | | | ag C | )per | atio | n | | | | | | | Description | |-------------|---------|---|------|------|------|---|---|---|---|---|---|---|--------------------------------------| | instruction | | F | P | U | M | В | ı | X | N | Z | ٧ | С | Description | | ABS | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Absolute value | | ADD.m | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Add source to destination register | | ADDI | Rs.m,Rd | - | - | - | - | - | - | 0 | - | - | - | - | Add scaled index to base | | ADDQ | j,Rs | - | - | - | - | - | - | 0 | * | * | * | * | Add 6-bit unsigned immediate | | ADDS.z | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Add sign extended source to register | | ADDU.z | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Add zero extended source to register | | BOUND.m | s,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Adjust table index (unsigned min) | | CMP.m | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Compare source to register | | CMPQ | i,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Compare with 6-bit signed immediate | | CMPS.z | si,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Compare with sign extended source | | CMPU.z | si,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Compare with zero extended source | | DSTEP | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Divide step | | MSTEP | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Multiply step | | MULS.m | Rs,Rd | - | - | - | - | - | - | 0 | * | * | * | 0 | Signed multiply | | MULU.m | Rs,Rd | - | - | - | - | - | - | 0 | * | * | * | 0 | Unsigned multiply | | NEG.m | Rs,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Negate (2's complement) | | SUB.m | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Subtract source from register | | SUBQ | j,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Subtract 6-bit unsigned immediate | | SUBS.z | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Subtract with sign extended source | | SUBU.z | s,Rd | - | - | - | - | - | - | 0 | * | * | * | * | Subtract with zero extended source | | TEST.m | S | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Compare operand with 0 | Table 2-8 Arithmetic Instructions # 2.4.4 Logical Instructions The logical instructions for the CRIS CPU are described in the table below: | Instruction | | | ag C | per | atio | n | | | | | Decariation | | | |-------------|-------|---|------|-----|------|---|---|---|---|---|-------------|---|---------------------------------| | instruction | | F | Р | U | M | В | I | X | N | Z | ٧ | С | Description | | AND.m | s,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Bitwise logical AND | | ANDQ | i,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | AND with 6-bit signed immediate | | NOT | Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Logical NOT (1's complement) | | OR.m | s,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Bitwise logical OR | | ORQ | i,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | OR with 6-bit signed immediate | | XOR | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Bitwise Exclusive OR | Table 2-9 Logical Instructions #### 2.4.5 Shift Instructions The shift instructions of the CRIS CPU are shown in the table below. When the shift count is contained in a register, the 6 least significant bits of the register are used as an unsigned shift count. | Instruction | | Fla | ag C | per | atio | n | | | | | | | Description | | | |-------------|-------|-----|------|-----|------|---|---|---|---|---|---|---|-------------------------------|--|--| | Instruction | | F | P | U | M | В | I | X | N | Z | ٧ | С | Description | | | | ASR.m | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Right shift Rd with sign fill | | | | ASRQ | c,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Right shift Rd with sign fill | | | | LSL.m | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Left shift Rd with zero fill | | | | LSLQ | c,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Left shift Rd with zero fill | | | | LSR.m | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Right shift Rd with zero fill | | | | LSRQ | c,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Right shift Rd with zero fill | | | Table 2-10 Shift Instructions #### 2.4.6 Bit Test Instructions The bit test instructions of the CRIS CPU are shown in the table below. The BTST and BTSTQ instructions set the Z flag if the selected bit and all bits to the right of it are zero, and the N flag according to the selected bit in the destination register. | Instruction | | ag C | • | | | | | | | Description | | | | |-------------|-------|------|---|---|---|---|---|---|---|-------------|---|---|----------------------------| | instruction | | F | P | U | M | В | I | X | N | Z | ٧ | С | Description | | BTST | Rs,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Test bit Rs in register Rd | | BTSTQ | c,Rd | - | - | - | - | - | - | 0 | * | * | 0 | 0 | Test bit c in register Rd | | LZ | Rs,Rd | - | - | - | - | - | - | 0 | 0 | * | 0 | 0 | Number of leading zeroes | Table 2-11 Bit Test Instructions ## 2.4.7 Condition Code Manipulation Instructions The condition code manipulation instructions of the CRIS CPU are shown in the table below. The predefined assembler macros EI, DI and AX are also shown. | Instruction | | Fla | ag C | )per | atio | n | | | | | | Description | | |-------------|----------------|-----|------|------|------|---|---|---|---|---|---|-------------|-------------------------------| | | | F | P | U | M | В | I | X | N | Z | ٧ | С | Description | | AX | | - | - | - | - | - | - | 1 | - | - | - | - | Arithmetic extend (SETF X) | | CLEARF | <li>t&gt;</li> | 0 | 0 | - | - | * | * | 0 | * | * | * | * | Clear flags in list | | DI | | 0 | 0 | - | - | - | 0 | 0 | - | - | - | - | Disable interrupts (CLEARF I) | | EI | | - | - | - | - | - | 1 | 0 | - | - | - | - | Enable interrupts (SETF I) | | Scc | Rd | - | - | - | - | - | - | 0 | - | - | - | - | Set register according to cc | | SETF | <li>t&gt;</li> | - | - | - | * | * | * | * | * | * | * | * | Set flags in list | Table 2-12 Condition Code Manipulation Instructions ## 2.4.8 Jump and Branch Instructions The jump and branch instructions of the CRIS CPU and the predefined assembler macros RET, RETB and RETI are shown in the table below: | Instruction | | | ag C | per | atio | n | | | | | | | Description | | |-------------|----------------|---|------|-----|------|---|---|---|---|---|---|---|-----------------------------------|--| | instruction | iiisti uctioii | | P | U | M | В | I | X | N | Z | ٧ | С | Description | | | Bcc | 0 | - | - | - | - | - | - | 0 | - | - | - | - | Conditional relative branch | | | Bcc | XX | - | - | - | - | - | - | 0 | - | - | - | - | Branch with 16-bit offset | | | BREAK | n | 1 | - | * | - | - | - | 0 | - | - | - | - | Breakpoint | | | JBRC | S | - | - | - | - | - | - | 0 | - | - | - | - | Jump to breakpoint routine (note) | | | JIR | S | - | - | - | - | - | - | 0 | - | - | - | - | Jump to interrupt routine | | | JIRC | S | - | - | - | - | - | - | 0 | - | - | - | - | Jump to interrupt routine (note) | | | JMPU | si | - | - | - | - | - | - | 0 | - | - | - | - | Jump and set operation mode | | | JSR | S | - | - | - | - | - | - | 0 | - | - | - | - | Jump to subroutine | | | JSRC | S | - | - | - | - | - | - | 0 | - | - | - | - | Jump to subroutine (note) | | | JUMP | S | - | - | - | - | - | - | 0 | - | - | - | - | Jump | | | RBF | si | - | - | * | - | - | - | * | - | - | - | - | Return from bus fault | | | RET | | - | - | - | - | - | - | 0 | - | - | - | - | Return from subroutine | | | RETB | | - | - | - | - | - | - | 0 | - | - | - | - | Return from breakpoint routine | | | RETI | | - | - | - | - | - | - | 0 | - | - | - | - | Return from interrupt routine | | Table 2-13 Jump and Branch Instructions Note: The JBRC, JIRC and JSRC instructions will add four bytes to the return address stored to either SRP, IRP or BRP. This leaves four bytes unused between the JSRC/JIRC/JBRC instruction and the return point. This can be used to enhance C++ exception support. ## 2.4.9 No Operation Instruction Finally, the CRIS CPU also has a no operation instruction, NOP. | Flag Operation | | | | | | | | | | | | Description | | |----------------|---|---|---|---|---|---|---|---|---|---|---|--------------|--| | instruction | F | P | U | M | В | 1 | X | N | Z | ٧ | С | Description | | | NOP | - | - | - | - | - | - | 0 | - | - | - | - | No operation | | Table 2-14 No Operation Instruction ## 2.5 MMU Support #### 2.5.1 Overview To support the Memory Management Unit (MMU) incorporated into the ETRAX 100LX, a number of features have been included in the CRIS architecture: - The CPU can be in one of two different operation modes: *User mode* and *Supervisor mode*. The MMU uses the operation mode to select the appropriate mapping between logical and physical addresses. - The *Bus fault* is a mechanism that can interrupt the CPU in any cycle, not only at instruction boundaries. This mechanism is needed because the MMU can get a page miss in any cycle. - With the introduction of the bus fault mechanism, integral read-write operations can not be achieved by just disabling the interrupt. Instead, another method is used, see section 2.6 Integral Read-Write Operations. The user and supervisor modes have different stack pointers. In both modes, the User mode Stack Pointer can be referenced as USP, while the currently active Stack Pointer is referenced as SP (or R14). The following CRIS instructions are included specifically for MMU support: - SBFS (Save Bus Fault Status) - RBF (Return from Bus Fault) - JMPU (Jump, set user mode if U flag is set) The SBFS and RBF instructions are used at the entry and exit of the bus fault interrupt routine. They save and restore a 16 byte CPU status record containing the information necessary to resume the operation that was interrupted by the bus fault. ## 2.5.2 Protected Registers and Flags A few registers and flags need to be protected from being modified while the CPU is in user mode. The protected registers and flags are: - IBR (Interrupt Base Register) - BAR (Breakpoint Address Register) - M flag (NMI enable flag) - B flag (HW breakpoint enable flag) - I flag (Interrupt enable flag) An attempt to modify a protected register while in user mode will just be silently denied. It will not cause any exception. The protected registers are readable in both user and supervisor modes. ## 2.5.3 Transition Between Operation Modes A transition between the user and supervisor modes can take place for the following reasons: #### Transition to user mode: - JMPU with the U flag set - RBF with the U flag set - RETI with the U flag set - RETB with the U flag set #### Transition to supervisor mode: - System Reset - BREAK instruction - Interrupt (including NMI and HW break) - Bus fault The stack pointers will be automatically exchanged at a transition between the user and supervisor modes. #### 2.5.4 Bus Fault Sequence When the MMU signals a Bus Fault, the CPU will interrupt immediately at the end of the CPU clock cycle and enter a Bus Fault sequence. The Bus Fault sequence is similar to the ordinary interrupt sequence, see section 2.7 *Interrupts*. The steps in the sequence are: - 1 Bus Fault INTA cycle. This cycle will be an idle bus cycle. - 2 Interrupt vector read cycle. The vector number will be 0x2e in MMU bus faults, and 0x20 in bus faults in the single step unit. - **3** Start execution of the Bus Fault interrupt routine at the address given by the interrupt vector. When entering into the Bus Fault interrupt routine, the internal CPU status is present in hidden CPU status registers. This status has to be saved to the memory using the SBFS instruction as the first instruction in the interrupt routine. #### 2.5.5 Format of the CPU Status Record The format of the CPU status record is as follows: Figure 2-7 CPU Status Record Format - The *PC field* contains the value of PC immediately after the interrupted cycle. For example, if the bus fault occurs on an instruction fetch at address A in a linear instruction stream, the PC field will contain the value A + 2. - The *Execution state field* contains a number of flags that enables the CPU to restart in the correct execution state. For more detail regarding these flags see Chapter 1 of the ETRAX 100LX Programmer's Manual. - If the interrupted cycle was a data read or write (i.e. not an instruction fetch), the *Instruction field* contains the opcode of the interrupted instruction. If the interrupted cycle was an instruction fetch, the instruction field will contain the invalid data that was fetched during the interrupted cycle. - The *Interrupted Address field* contains the address of the data entity in transfer during the interrupted cycle. - Finally, the *Data field* contains data associated with the interrupted instruction. For more information see Chapter 1 of the ETRAX 100LX Programmer's Manual. # 2.6 Integral Read-Write Operations Since a bus fault can interrupt the CPU in any bus cycle (except INTA), it is not possible to ensure the integrity of a piece of code just by disabling the interrupts or by only using instructions that lock out interrupts between them. Instead, integral readwrite operations can be implemented by using the *Load-Locked, Store-Conditional* principle discussed in the ETRAX 100LX Programmer's Manual. Support for integral read-write operations includes the F and P flags, and a conditional write mechanism: - The F flag (Interrupt acknowledge flag) is set by interrupts, bus faults, and the BREAK instruction. - All instructions that write to memory, except for SBFS, can be made conditional. If both the F and X flags are set, no write will be performed and the P flag will be set instead. # 2.7 Interrupts The CRIS CPU uses vectorized interrupts that are generated either externally to, or internally by, the ETRAX 100LX. The interrupt acknowledge sequence is as follows: - 1 Perform an INTA cycle, where the 8-bit vector number is read from the bus. - **2** Store the contents of PC to the Interrupt Return Pointer (IRP). Note that the return address is not automatically pushed on the stack. - **3** Read the interrupt vector from the address [IBR + <vector number> \* 4]. - **4** Start the execution at the address pointed to by the interrupt vector. The Interrupt Base Register (IBR) has bits 31-16 implemented. The remaining bits are always zero. Figure 2-8 Interrupt Vector Address Calculation #### 2.7.1 NMI The Non Maskable Interrupt (NMI) is handled in the same way as the normal interrupt except for the following three differences: - The return address is stored in the Breakpoint Return Pointer (BRP) instead of the IRP. - The NMI is enabled/disabled by the M flag instead of the I flag. The M flag can be set with the SETF M instruction. Move to CCR/DCCR has no effect. Once set, the M flag can only be cleared by an NMI acknowledge cycle or system reset. - The INTA cycle will be an idle bus cycle, and the vector number 0x21 is generated internally in the CPU. # 2.8 Software Breakpoints The CRIS CPU has a breakpoint instruction (BREAK n). This instruction saves the current value of PC in the Breakpoint Return Pointer (BRP) register and performs a jump to address (IBR + 8 \* n). Figure 2-9 Breakpoint Routine Entry Address Calculation # 2.9 Hardware Breakpoint Mechanism The CPU contains a hardware breakpoint mechanism. The hardware breakpoint address is loaded in the BAR register (Breakpoint Address Register), and the hardware breakpoint mechanism is enabled by setting the Breakpoint enable flag B (see Figure 2-2 on page 6). For each CPU read or write cycle, the address is compared with the contents of the BAR register. In order to detect a read or write in the dword (and not just a single byte) of the address location, bit 1 and 0 are ignored in the comparison. Bit 31 is also ignored in the comparison since that bit handles the cache in the ETRAX 100LX (address bit 31 set will bypass the cache and directly access the main memory). An address hit is handled in the same way as an NMI with interrupt vector number 0x20, except that a breakpoint hit is not affected by the M flag. The hardware breakpoint mechanism is disabled after reset. # 3 SINGLE STEP ### 3.1 General There is a simple single step mechanism in the ETRAX 100LX. The single step is controlled by 4 mode bits (19:16) in the R TEST MODE register. | Bit nr. | Name | Description | |---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | single_step | Turns single step on and off. | | 18 | break_write | Enables the single step unit to break execution on memory write cycles. | | 17 | break_read | Enables the single step unit to break execution on memory data read cycles (as opposed to instruction fetch). | | 16 | break_fetch | Enables the single step unit to break execution on instruction fetch cycles. This will break both fetch from memory and fetch from the CPU internal prefetch register. | Table 3-1 Single Step Control Bits in the R\_TEST\_MODE Register The single step unit is started by first setting the appropriate bits in the R\_TEST\_MODE register, and then using the RBF instruction to jump to the code through which the single step should be performed. The single step unit will issue a bus fault on the first CPU cycle that matches the cycle types selected in the R\_TEST\_MODE register. The single step bus fault uses the interrupt vector number 0x20, which is the same interrupt vector that is used by the HW break mechanism. As a result, it is not recommended that the single step and the HW break mechanisms be enabled at the same time. After the bus fault has occurred, the single step unit is disabled until after the next RBF instruction has been executed and the restarted cycle has been completed. If a single step bus fault occurs at the same time as an MMU bus fault, the single step bus fault will have priority. This means that the single step routine must be able to check for this case and invoke MMU handling as well, but the MMU handler doesn't need to be aware of the single step mechanism. To check for concurrent MMU and single step bus faults, there is a **both\_faults** bit (R\_BUS\_STATUS bit 4) that is set when this happens. The **both\_faults** bit is cleared when the CPU runs an RBF instruction. # 3.2 Programming Considerations A special case occurs with interrupts when the **break\_read** bit is set. The single step unit will then break also on interrupt vector read cycles. This case can be identified by a bit in the CPU status record, but the interrupt sequence cannot be automatically restarted by the RBF instruction. The single step handler routine must check for this case and compensate for it. When single stepping through code that uses the integral read-write mechanism, the 'old F flag' in the CPU status record must be checked, and the F flag in CCR must be restored if there wasn't a concurrent MMU bus fault. Otherwise, the conditional write will always fail in single step mode, and the program will hang. Another problem that has to be taken care of occurs when single stepping through code that pops data from the supervisor stack. After a bus fault in the data read cycle of a pop, the stack pointer will already be incremented. If the single step handler uses the stack this will clobber the stack data that was going to be read when the bus fault occurred. There are two possible solutions for this problem: 1 Reserve extra space on the stack. #### **Example:** This will reserve stack space corresponding to the maximum SP increment that could occur with Autoincrement addressing mode. The maximum of 64 bytes occurs with the MOVEM [SP+], PC instruction. This method will only work as long as the program you are single stepping through doesn't itself use the same method as described above to access values on the stack after the stack pointer has been incremented. 1 Store status at absolute address and have a separate stack for the single step handler. #### Example: ``` SBFS [STATUS_RECORD] ; Save CPU status to ; absolute address. MOVE DCCR, [SAVED_DCCR] ; Save DCCR to absolute address. DI MOVEM SP, [SAVED_REGS] ; Save all registers to ; absolute address. MOVE.D SINGLE_STEP_SP, SP ; Load new sp value for ; single step handler. : : : MOVEM [SAVED_REGS], SP MOVEM [SAVED_DCCR], DCCR RBF [STATUS_RECORD] ``` # 4 Memory Management Unit The ETRAX 100LX includes a Memory Management Unit (MMU) that manages the physical memory resources of the device. The MMU has a number of purposes: - Protecting the code and data of one user-level application from other user-level applications. - Permitting user-level applications to share portions of the address space. - Protecting the kernel-level code and data from user-level applications. - Running applications that are partially resident in main memory. Only the most recent part of such an application is normally stored in main memory: the rest of the program is stored on disk until needed. This is more commonly known as swapping. - Reference counting in support of a garbage collection mechanism. The MMU implements a virtual memory system where it creates the illusion of a very large amount of memory exclusively available for each application. In ETRAX 100LX, 4 GBytes of virtual memory are made available to each application. Each application is also given a separate address space identifier that is used by the MMU to separate its memory from other applications. The virtual memory is divided into 8 KByte pages which can be individually protected and mapped to physical memory. The upper 19-bit part of the 32-bit CPU address is known as the virtual page number (vpn), while the lower 13-bit part is used as an offset within each page. The vpn is translated into a 19-bit physical page number (pfn) while the page offset remains unchanged through the MMU. The MMU uses the CPU's *User* and *Supervisor Modes* to restrict access and select the appropriate mapping from logical to physical addresses in the virtual memory space. Mapping from virtual address to physical address is handled by a *Translation Lookaside Buffer* (TLB). The TLB is an on-chip cache that provides translations in the form of page table entries (pte). The ptes are stored in page tables in main memory. If a virtual-to-physical address translation is not found in the TLB, the MMU will interrupt the CPU and use a software table walker to look for the translation in the main memory page table. In some cases the MMU is not used, so it can be disabled in register R\_MMU\_ENABLE. By default the MMU is disabled after reset. When the MMU is disabled, the ETRAX 100LX is considered to be in *non-protected* mode and memory is accessed in the conventional manner. Please see chapter 18.17 *MMU Registers* for detailed information on the MMU registers. ## 4.1 MMU Memory Areas The MMU operates with two types of memory area: - **Kernel/user area** accessed in the CPU User and Supervisor Modes, and mainly contains user code and data structures. - **Kernel area** accessed in the CPU Supervisor Mode only and may include kernel code and data structures, I/O-buffers, DMA-buffers, mode registers, etc. ## 4.1.1 Kernel/User Address Space The *kernel/user* address space is a uniform, virtual address area of 4 GBytes in size. It is divided into 8 KByte pages that can be individually protected and mapped to physical memory. Mapping is executed through the TLB, which translates a virtual address into a corresponding physical address. Each user process has a unique translation of virtual addresses placed in page tables in main memory. The page tables are maintained by the kernel. Figure 4-1 Kernel/User Virtual Address Space ## 4.1.2 Kernel Address Space The kernel address space is divided into sixteen 256 MByte segments designated seg\_0 to seg\_f. Each segment can be individually configured to use page mapping or linear segment mapping. The mapping method is determined in kernel segment register R\_MMU\_KSEG. When a bit in this register is set to 0, the corresponding segment is page-mapped via the TLB. When a segment bit is set to 1, the corresponding segment is linear mapped by means of a 4-bit offset. Linear-mapped segments do not use the TLB. #### **Page-Mapped Kernel Segments** Kernel address segments that use page mapping are divided into 8 KByte pages controlled by the TLB. The four-bit base fields in registers R\_MMU\_KBASE\_LO and R\_MMU\_KBASE\_HI are ignored for page mapping purposes. Figure 4-2 Kernel Page-mapped Virtual Address Space ### **Linear Segment-Mapped Kernel Areas** The virtual addresses of kernel segments that use linear mapping are converted to physical addresses by translating the four m.s.b. of the 32-bit virtual address from the CPU. The linear translation is handled in two registers, R\_MMU\_KBASE\_HI and R\_MMU\_KBASE\_LO. The 4-bit base field in these registers becomes address bits 31 to 28 when translating to physical addresses. Bits 27 to 0 of the virtual address are unchanged when translated to a physical address. Figure 4-3 Linear Segment Address Translation ## 4.2 Translation Lookaside Buffer The Translation Lookaside Buffer is a 64-entry cache that maps a virtual address to a physical address. If a translation cannot be found in the TLB (a *TLB miss*), the CPU is interrupted (chapter 2, refers) and the software is required to load a new translation into the TLB. ## 4.2.1 TLB Memory Sets The TLB comprises four 16-entry memory sets designated 0 to 3. The TLB is thus four-set associative. This means that a vpn from the CPU can be stored at only one location in each of the four TLB memory sets, and in each set the chosen location is the same (see Figure 4.4). An example of possible locations for different addresses in the TLB is given in the table below. | VPN | Positions in TLB | | | | |-----|------------------|----|----|----| | 0 | 0 | 16 | 32 | 48 | | 1 | 1 | 17 | 33 | 49 | | 2 | 2 | 18 | 34 | 50 | | | | | | | | • | | | | | | • | • | • | • | | | • | • | • | • | • | | 14 | 14 | 30 | 46 | 62 | | 15 | 15 | 31 | 47 | 63 | | 16 | 0 | 16 | 32 | 48 | | 17 | 1 | 17 | 33 | 49 | Table 4-1 Example of Virtual Address Positions in the TLB The selection of the TLB set in which a particular vpn will be stored must be configured in software. The location at which the vpn will be placed within the TLB set is determined by a 4-bit index comprising bits 13 to 16 of the incoming virtual address from the CPU. In the event of a TLB miss, a 2-bit set number is provided by a random number generator. The random set number is combined with the 4-bit index from the CPU address to form a 6-bit index. This index is stored in register R\_TLB\_SELECT, and can be used to choose which of the 64 TLB entries to replace. It is also possible for the software to use another algorithm to select the entry to replace. As shown below, bits 4 and 5 of the index provide the TLB set number and bits 3 to 0 denote the location within the set. | I | set | | location | | | | |---|-----|---|----------|---|---|---| | | 5 | 4 | 3 | 2 | 1 | 0 | Figure 4-4 Format of TLB Miss Exception Index To accommodate the 8 KByte page size, the lower 13 bits of the 32-bit virtual address from the CPU are not changed by the translation. The 19-bit virtual page number is translated into a 19-bit physical frame number. The principle of the TLB memory sets is illustrated below. Figure 4-5 TLB Memory Sets #### 4.2.2 TLB Entries Entries stored in the TLB are 44 bits in width. They consist of a virtual to physical address translation, a page identification, and control bits. The format of a TLB entry is shown below. Figure 4-6 Format of a TLB Entry - **pfn** the translated address expressed as a 19-bit physical frame number; - **vpn** the virtual address expressed as a 15-bit virtual page number: the remaining 4 bits are composed from the 4-bit TLB set index. - **page\_id** the 6-bit page identification; - we write enable bit 19 is used to write-protect the page; - **kernel** bit 20 is used to prevent access to the page during CPU User Mode; - valid bit 21 indicates that the TLB entry contains a valid address translation; - **global** bit 22 indicates whether or not the TLB ignores the page identification matching conditions for a TLB hit. If the **global** bit is not asserted (0), the **page\_id** in the TLB entry is compared to the value of the 6-bit **page\_id** in register R\_MMU\_CONTEXT. To achieve a valid translation, the values of the **page\_id** fields in the TLB entry and the register must match. If the **global** bit is asserted (1), the **page\_id** of the TLB entry is not compared to the **page\_id** field in register R\_MMU\_CONTEXT. The condition for a hit in one of the TLB sets is: ``` hit = (valid | inv_excp) & (cpu_vpn == tlb_vpn) & ((context_pid == tlb_pid) | global)) ``` #### where: | valid | valid bit (21) in the TLB entry. | | |-------------|------------------------------------------------------|--| | inv_excp | invalid page exception enabling bit from R_MMU_CTRL. | | | cpu_vpn | virtual page number from the CPU. | | | tlb_vpn | virtual page number in the TLB entry. | | | context_pid | page_id field in R_MMU_CONTEXT. | | | tlb_pid | page_id field in the TLB entry. | | | global | global bit (22) in the TLB entry. | | Table 4-2 Definitions of TLB Hit ## 4.2.3 TLB Register Interface The TLB is controlled by registers R\_TLB\_SELECT, R\_TLB\_LO and R\_TLB\_HI, all entries to which can be read and written by the CPU. Register R\_TLB\_SELECT is used to choose which entry is to be read or written in the TLB. TLB entries are 44 bits in width and therefore an entry cannot be written by the CPU in one cycle. The CPU must first write the high order part of the TLB entry to register R\_TLB\_HI. This contains the same fields as register R\_MMU\_CAUSE and, when writing to R\_TLB\_HI, the data are also stored at the corresponding fields of R\_MMU\_CAUSE. The high order part is not stored in the TLB until the low order part is written in register R\_TLB\_LO. Registers R\_MMU\_CAUSE and R\_TLB\_SELECT are normally updated automatically by the MMU and do not require updating by the software. To write a new translation in the TLB, for example a TLB miss, the software only has to write into register R\_TLB\_LO. #### 4.2.4 Virtual Address from the CPU An incoming address from the CPU is constructed as shown below. Figure 4-7 Incoming Address from the CPU The page offset is 13 bits wide to accommodate the offset within the 8 KByte pages. The upper 15 bits of the vpn are stored in the TLB and the lower four bits are the address index for the selected TLB set. When the CPU generates a new address, the four TLB sets are searched for a matching vpn. If an entry is found, the **page\_id** is compared to the corresponding field in register R\_MMU\_CONTEXT. The **valid**, **kernel** and **we** bits are controlled and, if all conditions match, a valid physical address is output to the cache. The TLB is not permitted to store more than one valid, virtual page translation with the same **page\_id** or with the **global** bit set. This would cause multiple hits in the TLB and result in an MMU exception. ## 4.2.5 MMU Exceptions An exception is generated if there is a mismatch in the output from one or more fields of the TLB. In the event of an exception, the MMU interrupts the CPU by means of bus fault logic (See chapter 2 *RISC CPU*). Information about the exception is stored in register R MMU CAUSE, which holds information about: - The vpn that generated the exception - The **page\_id** of the application that generated the exception - Whether the exception was caused by a write or read access The type of exception that occurred Five different types of MMU exception can occur (Refer to section *4.2.1 TLB Memory Sets* for those exceptions that generate a random or actual index): - Miss The referenced address does not match any TLB entry, or the current page\_id does not match the TLB index. A valid entry must be loaded by software. - Write error During a write operation, reference is made to a page that does not have the we bit asserted in the TLB entry. This exception can be used for write protection and dirty checks. - Access violation In User Mode, reference is made to a page with the kernel bit asserted in the TLB entry. When asserted, the kernel bit prevents CPU User Mode access to the page. - Invalid page Reference is made to a page with matching vpn and page\_id fields in the TLB, but the valid bit is deasserted. This can be used for reference counting. - Multiple hits The occurrence of more than one hit in the TLB indicates a serious error. This is indicated by a bus fault signal with all exception bits deasserted. The write error, access violation and invalid page exceptions can all be disabled in control register R\_MMU\_CTRL. Normally the invalid page exception is disabled unless a reference count is in progress. When disabled, an invalid entry in the TLB will not match any address and will, thus, cause a miss. The nature of a miss exception is such that it does not allow any other exceptions to occur simultaneously. However, a single memory reference may cause any combination of write error, access violation and invalid page exceptions at the same time. The conditions for the MMU exceptions are: - Miss = $\sim$ hit - Write error = hit & cpu\_wr & ~we & we\_excp - Access violation = hit & user\_mode & kernel & acc\_excp - Invalid page = hit & ~valid & inv\_excp #### where: | hit | Hit in one of the TLB sets. | |-----------|----------------------------------------------------------| | cpu_wr | CPU write access. | | we | Write enable bit in TLB entry. | | we_excp | Write error exception enabling bit from R_MMU_CTRL. | | user_mode | CPU User Mode access. | | kernel | Kernel bit in TLB entry. | | acc_excp | Access violation exception enabling bit from R_MMU_CTRL. | | valid | Valid bit in TLB entry. | | inv_excp | Invalid page exception enabling bit from R_MMU_CTRL. | Table 4-3 Definition of MMU Exceptions # 4.3 MMU Registers The MMU is served by a set of dedicated registers. The table below summarizes the purpose of each register. | Register | Function | |--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_MMU_CONFIG comprising: | | | R_MMU_KSEG | Sets individual page or segment mapping method for each kernel segment 0 to $\mathbf{f}$ . | | R_MMU_CTRL | Enables or disables the invalid page $(valid)$ , access $(kernel)$ and write-enable $(we)$ MMU exceptions. | | R_MMU_ENABLE | Enables or disables the MMU. | | R_MMU_KBASE_LO | Provides the 4-bit offset for linear translations in the eight lower kernel segments 0 to 7. | | R_MMU_KBASE_HI | Provides the 4-bit offset for linear translations in the eight upper kernel segments 8 to f. $$ | | R_MMU_CONTEXT | Contains the 6-bit page_id of the current address map. | | R_MMU_CAUSE | Multi-purpose, containing: the 19-bit vpn of the referenced address that generated an exception when an MMU exception occurs; the 6-bit page_id from R_MMU_CONTEXT when an MMU exception occurs; 4 discrete bits signifying whether a miss, invalid, access or write-enable exception has occurred; 1 bit signifying whether the exception was caused by a write or read access. | | R_TLB_SELECT | Contains the 6-bit TLB index. | | R_TLB_LO | Contains the lower 23 bits of the TLB entry, namely: 19-bit pfn; global bit; valid bit; kernel bit; we bit. | | R_TLB_HI | Contains the upper 25 bits of the TLB entry, namely: 19-bit vpn; 6-bit page_id. | Table 4-4 MMU Registers For detailed information on the MMU registers, please refer to chapter 18.17 *MMU Registers*. ## 4.4 MMU Test Mode The MMU can be set to a test mode that can be used to manually check the TLB and the bus fault logic. The MMU test mode is set by bit **mmu\_test** in register R\_TEST\_MODE. When the MMU test mode is active, the bus fault logic is operative but the bus fault signal to the CPU is gated and cannot, therefore, generate an interrupt to the CPU. Register R\_MMU\_CAUSE is updated as normal. The address translation logic is not affected by the MMU test mode. If the MMU is enabled, mapping through the TLB and offset registers operates in the normal way. If the MMU is disabled, the output physical address is not translated. | mmu_en | mmu_test | Interrupt CPU | Update R_MMU_CAUSE | Translate Address | |--------|----------|---------------|--------------------|-------------------| | 0 | 0 | no | no | no | | 0 | 1 | no | yes | no | | 1 | 0 | yes | yes | yes | | 1 | 1 | no | yes | yes | Table 4-5 MMU Test Mode Truth Table # 4.5 Example of Virtual Memory Configuration Virtual memory configuration is essentially a matter of setting up the ratio of page-mapped kernel space to linear-mapped kernel space. For example, to set up the following virtual memory system, the MMU register configurations would resemble those described in the tables below. - 0.5 GBytes of linear-mapped kernel area; - 3.5 GBytes of page-mapped kernel area; - 4 GBytes of kernel/user area. ### Register R\_MMU\_KBASE\_HI | Bit(s) | Name | Setting | Value | |---------|--------|---------------------------------|-------| | 31 - 28 | base_f | Don't care. | 0 x 0 | | 27 - 24 | base_e | Don't care. | 0 x 0 | | 23 - 20 | base_d | Don't care. | 0 x 0 | | 19 - 16 | base_c | Kernel cached area. | 0 x 7 | | 15 - 12 | base_b | Kernel uncached mode registers. | 0 x b | | 11 - 8 | base_a | Don't care. | 0 x 0 | | 7 - 4 | base_9 | Don't care. | 0 x 0 | | 3 - 0 | base_8 | Don't care. | 0 x 0 | Table 4-6 Example of Kernel Base High Register Configuration ### Register R\_MMU\_KBASE\_LO | Bit(s) | Name | Setting | Value | |---------|--------|-------------|-------| | 31 - 28 | base_7 | Don't care. | 0 x 0 | | 27 - 24 | base_6 | Don't care. | 0 x 0 | | 23 - 20 | base_5 | Don't care. | 0 x 0 | | 19 - 16 | base_4 | Don't care. | 0 x 0 | | 15 - 12 | base_3 | Don't care. | 0 x 0 | | 11 - 8 | base_2 | Don't care. | 0 x 0 | | 7 - 4 | base_1 | Don't care. | 0 x 0 | | 3 - 0 | base_0 | Don't care. | 0 x 0 | Table 4-7 Example of Kernel Base Low Register Configuration ### Register R\_MMU\_KSEG | Bit(s) | Name | Setting | Value | | |--------|-------|--------------------------------|-------|--| | 15 | seg_f | Page mapping. | 0 | | | 14 | seg_e | Page mapping. | 0 | | | 13 | seg_d | Page mapping. | 0 | | | 12 | seg_c | Kernel linear segment mapping. | 1 | | | 11 | seg_b | Kernel linear segment mapping. | 1 | | | 9 | seg_a | Page mapping. | 0 | | | 8 | seg_9 | Page mapping. | 0 | | | 7 | seg_7 | Page mapping. | 0 | | | 6 | seg_6 | Page mapping. | 0 | | | 5 | seg_5 | Page mapping. | 0 | | | 4 | seg_4 | Page mapping. | 0 | | | 3 | seg_3 | Page mapping. 0 | | | | 2 | seg_2 | Page mapping. 0 | | | | 1 | seg_1 | Page mapping. 0 | | | | 0 | seg_0 | Page mapping. | 0 | | Table 4-8 Example of Kernel Segment Register Configuration Memory maps of the virtual address spaces realized by the example configuration are illustrated below. Figure 4-8 Example of Kernel Virtual Memory Map Figure 4-9 Example of Kernel/User Virtual Memory Map # 5 BUS INTERFACE The ETRAX 100LX bus interface has a 32/16-bit data bus, a 25-bit address bus, and six internally decoded chip select outputs. Six additional chip select outputs are multiplexed with other I/O functions, and are available in some configurations. The bus interface also supports either asynchronous or synchronous DRAM banks without external logic. #### 5.1 Data Bus The 32-bit data bus provides support for 16-bit wide memories. The data bus is organized with the least significant byte at the lowest address ("little endian"). The 32-bit data bus mode is shown in figure 5-1, and the 16-bit data bus mode is shown in figure 5-2 below: Figure 5-1 32-bit Mode Data Bus Figure 5-2 32-bit Wide Data on a 16-bit Mode Data Bus # 5.2 Bus Interface Registers | Register | Function | | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | R_WAITSTATES | A 32-bit write only register containing wait<br>state settings for peripheral, SRAM, and flash-PROM chip selects. | | | R_BUS_CONFIG | A 32-bit write only register for selecting bus width, common write enable (cwe) or <i>bytewise</i> write enable (bwe) selection, and DMA burst length,. It is also used for setting write delay mode for chip selects. | | | R_BUS_STATUS | A 32-bit read only register that shows the initial values of the bus status pins ${f bs0}$ - ${f bs3}$ after reset. | | | R_DRAM_TIMING | A 32-bit write only register for asynchronous DRAM wait<br>state configuration. | | | R_SDRAM_TIMING | A 32-bit write only register for SDRAM enabling and configuration. | | | R_DRAM_CONFIG | A 32-bit write only register for asynchronous DRAM bus width, and DRAM type and bank selection. | | | R_SDRAM_CONFIG | A 32-bit write only register for SDRAM bus width, and SDRAM type and bank selection. | | Table 5-1 Bus Interface Registers For more detailed information see chapter 18.2 Bus Interface Configuration Registers. # 5.3 Address and Chip Selects The ETRAX 100LX chip operates with a 32-bit wide address space internally, but only address bits 25-1 are available on the external pins. Address bits 30-26 are decoded internally to generate the different memory chip select outputs, and the select of DRAM banks and internal I/O. Address bit 31 is used to select whether the cache is used or bypassed by CPU accesses. Additional chip selects are configured in the register R\_PORT\_PB\_SET (See chapter 18.2 *Bus Interface Configuration Registers*). The addresses are decoded to generate chip selects as follow: | Address Range (hex) | Size (Mbyte) | Name | Description | |---------------------|--------------|------|-----------------------------------------------| | 00000000-03FFFFFF | 64 | cse0 | EPROM/flash PROM bank 0 chip select (Note: 1) | | 04000000-07FFFFFF | 64 | cse1 | EPROM/flash PROM bank 1 chip select (Note: 1) | | 08000000-0BFFFFFF | 64 | csr0 | SRAM bank 0 chip select. (Note: 1) | | 0C000000-0FFFFFF | 64 | csr1 | SRAM bank 1 chip select (Note: 1) | | 10000000-13FFFFFF | 64 | csp0 | Peripheral chip select 0 (Note: 1) | | 14000000-17FFFFFF | 64 | csp1 | Peripheral chip select 1 (Note: 1) Note: 2) | | 18000000-1BFFFFFF | 64 | csp2 | Peripheral chip select 2 (Note: 1) (Note: 2) | | 1C000000-1FFFFFFF | 64 | csp3 | Peripheral chip select 3 (Note: 1) (Note: 2) | | 20000000-23FFFFFF | 64 | csp4 | Peripheral chip select 4 (Note: 2) | | 24000000-27FFFFFF | 64 | csp5 | Peripheral chip select 5 (Note: 1) (Note: 2) | | 28000000-2BFFFFFF | 64 | csp6 | Peripheral chip select 6 (Note: 1) (Note: 2) | | 2C000000-2FFFFFF | 64 | csp7 | Peripheral chip select 7 (Note: 1) (Note: 2) | | 30000000-3FFFFFFF | 256 | - | Do not use (Note: 3) | | 40000000-7FFFFFFF | 1024 | - | DRAM interface (Note: 1) | | 80000000-AFFFFFF | 768 | | Same as 00000000-2FFFFFFF but uncached | | B0000000-B7FFFFF | 128 | - | Internal registers | | B8000000-BFFFFFF | 128 | - | Internal start up code | | C0000000-FFFFFFF | 1024 | - | Same as 40000000-7FFFFFFF but uncached | Table 5-2 Chip Selects - **Note 1:** Add 80000000 (hex) to bypass the cache. - **Note 2:** Peripheral select 1 3 and 5 7 are multiplexed with bits 2 7 in general port PB in the I/O block, and are not available if these pins are configured as general port pins. - **Note 3:** This region is internal registers and start-up code, but it is cached. Never use this area for accessing internal registers. ### 5.4 Internal Bus Arbitration The bus interface performs the bus arbitration between the possible internal bus masters. The bus priority order is: - 1 Shared RAM interface (highest priority) - 2 External DMA channels - 3 DRAM refresh - 4 Internal DMA channels - **5** CPU and cache (lowest priority) # 5.5 Bus Width, Cycle Timing and Wait States The bus interface supports 4 asynchronous DRAM banks, 8 synchronous DRAM banks (i.e. 2 groups of SDRAM banks with 2 to 4 banks per group), and between 6 to 12 other memory banks depending on its configuration. Each memory bank is connected to one of the chip select outputs. The banks are separated into five groups: | Group 1 | cse0, cse1 | |---------|-------------------------------------------------------------------------------| | Group 2 | csr0, csr1 | | Group 3 | $\overline{csp0}$ , $\overline{csp1}$ , $\overline{csp2}$ , $\overline{csp3}$ | | Group 4 | $\overline{csp4}$ , $\overline{csp5}$ , $\overline{csp6}$ , $\overline{csp7}$ | | Group 5 | DRAM banks | Table 5-3 The ETRAX 100LX bus width and number of wait states can be configured individually for each group. The bus width can be configured to either 16 or 32 bits using the internal register R\_BUS\_CONFIG. All banks in the same group have the same width. For group 1, the EPROM/flash PROM group, the initial bus width is decided by bus status pin 0 (bs0) at system reset. If bs0 is low, the bus width is configured to 16 bits. If bs0 is high, then the bus width is configured to 32 bits. All bus cycles are run in consecutive bursts, with a maximum length of 32 bytes, and a minimum length of 1 byte. A burst will never cross a 32-byte boundary. A burst is either read or write, and the data direction is never changed within a burst. For each group of memory banks except Synchronous DRAM banks, the following wait state parameters can be configured: | Parameter | Name | Size (bits) | Description | |----------------------|------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | Early wait states | ew | 2 | Number of wait states before the falling edge of $\overline{rd}$ , $\overline{wr0}$ - $\overline{wr3}$ , or $\overline{cas}$ . | | Late wait states | lw | 2 or 4 (Note: 44) | Number of wait states after the falling edge of $\overline{rd}$ , $\overline{wr0}$ - $\overline{wr3}$ , or $\overline{cas}$ . | | Turn-off wait states | ZW | 2 | Number of wait states after the end of a burst. The turn-off wait states of the ending burst and the early wait states of the next burst may overlap. | Table 5-4 Memory Bank Wait State Parameters That Can Be Configured **Note 4:** There are 2 bits for DRAM, and 4 bits for all other memory banks. | Group or Cycle | Wait State Ranges | | | |---------------------------------------|-------------------|--------|----------| | Group or Cycle | Early | Late | Turn Off | | Group 1: cse0, cse1 | 0 – 3 | 0 – 15 | 0 – 3 | | Group 2: csr0, csr1 | 0 – 3 | 0 – 15 | 0 – 3 | | Group 3: csp0, csp1, csp2, csp3 | 0 – 3 | 0 – 15 | 0 – 3 | | Group 4: csp4, csp5, csp6, csp7 | 0 – 3 | 0 – 15 | 0 – 3 | | Asynchronous DRAM cas cycle | 0 – 3 | 0 – 3 | 0 – 3 | | Asynchronous DRAM ras cycle | 0 – 3 | 0 – 3 | - | | Asynchronous DRAM ras precharge cycle | - | 0 – 3 | - | Table 5-5 Possible Wait State Settings Wait states for groups 1 to 4 are configured in R\_WAITSTATES, and asynchronous DRAM wait states are configured in R\_DRAM\_TIMING. A zero wait state bus cycle lasts 20 ns. Between bursts there are 10 ns. Each wait state adds 10 ns to the bus cycle time. Default after reset is maximum number of wait states. For Synchronous DRAM banks, the following wait state parameters can be configured: | Parameter | Name | Size (bits) | Description | |----------------------------|--------|-------------|----------------------------------------------------------------------------------------------| | Master clock select | clk100 | 1 | Synchronous DRAM master clock select.<br>Possible configuration is either 50 MHz or 100 MHz. | | cas latency cycles | cl | 2 | Number of delay cycles from read bank command to valid read data. | | ras to cas delay cycles | rcd | 2 | Number of delay cycles after activate bank command. | | ras precharge delay cycles | rp | 2 | Number of delay cycles after precharge bank command. | | Row cycle time | rc | 2 | Auto refresh cycle time. | | Power down exit delay | pde | 1 | Number of delay cycles from power down exit to new command. | Table 5-6 SDRAM Bank Wait State Parameters That Can Be Configured Table 5-7 below gives possible Synchronous DRAM wait state settings and corresponding delay cycles for both a 50 and 100 MHz master clock: | Cycle | Wait State R | anges | Delay Cycle Ranges | | |-----------------------|--------------|---------|--------------------|---------| | Cycle | 50 MHz | 100 MHz | 50 MHz | 100 MHz | | cas latency | 1 - 2 | 0 - 1 | 2 – 3 | 2 – 3 | | ras to cas delay | 0 - 3 | 0 - 3 | 1 - 4 | 2 - 5 | | ras precharge delay | 0 - 3 | 0 - 3 | 1 - 4 | 2 - 5 | | Row cycle time | 0 - 3 | 0 - 3 | 6 - 9 | 6 - 9 | | Power down exit delay | 0 - 1 | 0 - 1 | 1 - 2 | 1 - 2 | Table 5-7 Possible Wait State Settings and Delay Cycles for Synchronous DRAM A delay cycle lasts 20 ns when a 50 MHz SDRAM system clock is selected, and 10 ns when a 100 MHz system clock is selected. ## 5.6 Memory Timing The timing for the read cycles, both with and without early wait states, is shown in the figure below. This timing diagram is valid for SRAM, flash and peripheral devices. Figure 5-3 Read Cycles for SRAM, Flash Memory and Peripheral Devices. ## 5.7 Write Modes #### 5.7.1 Normal and Extended Write Mode During a normal ETRAX 100LX write cycle, the wr0 - wr3 strobes will go high 5 ns before the end of the bus cycle. The write pulses can be extended to the end of the bus cycle. Normal and extended write mode can be configured individually for each of the groups, 1 to 4, of the memory banks in R\_BUS\_CONFIG. Asynchronous DRAM is configured in R\_DRAM\_TIMING. ### 5.7.2 Bytewise and Common Write Enable Mode The memory banks in group 2, the SRAM group, can be configured with R\_BUS\_CONFIG to use either four bytewise write enable strobes or one common write enable strobe. In bytewise write enable mode, bwe, four write strobes are available, one for each byte in the data bus. In common write enable mode, cwe, one common write enable strobe and four byte enable strobes are available. The byte enable strobes are active during both read and write cycles. In 32-bit cwe mode, one of the byte enable strobes is output on the unused address bit 1. | 16/32-bit bwe | 32-bit cwe | 16-bit cwe | |---------------|----------------|----------------| | wr0 | <del>be0</del> | <del>be0</del> | | wr1 | <del>be1</del> | be1 | | wr2 | <del>be2</del> | - | | wr3 | we | we | | a1 | <del>be3</del> | a1 | Table 5-8 Pin Assignment for Bytewise and Common Write Enable Modes Note 5: For information regarding actual pin assignments see chapter 19 Electrical Information. The byte enable strobes, be0 - be3, have the same timing as the address bus. The write enable strobe, we, has the same timing as the write strobes, wr0 - wr3. ## 5.8 External Interrupt Acknowledge If the external interrupt is configured for an external vector number, an interrupt acknowledge cycle will occur when the interrupt is granted. During the interrupt acknowledge cycle, an 8-bit vector number is read on the low byte of the data bus. The cycle is indicated by the inta signal going low, and $\overline{rd}$ and $\overline{wr}$ are high during the cycle. The address and chip selects are undefined. Maximum timing is used for the inta cycle, regardless of setting: ew = 3, ew = 15, and ew = 3. Figure 5-4 External inta Cycle **Note 6:** For more information see chapter 19 Electrical Information. ## 5.9 Access to Internal I/O Data read from or written to an internal I/O unit is present on the data bus for 2 clock cycles (i.e. 20 ns). The $\overline{rd}$ pulse is active for 20 ns and the $\overline{wr}$ pulses are active for 10 ns. All chip selects are inactive. # 5.10 Wait Input and Bus Cycle Rerun An external wait pin $(\overline{wait})$ is provided, and can be used by external devices to insert extra wait states. The wait input is fully synchronized, and wait is sampled 3 clock cycles (30 ns) before the end of the bus cycle. As a result, the use of the wait input requires that the number of internal wait states (ew + lw) for the memory area in question to be set to 3 or more. If the $\overline{\text{wait}}$ input is active for too long, it can cause overrun/underrun errors (e.g. in the network interface). The maximum allowed active time is, therefore, limited depending on the application. For very slow external units it is possible to make a bus cycle rerun. However, this only applies for non-cacheable CPU accesses and is not allowed to be used on other types of cycles, like DMA cycles etc. The rerun input is sampled at the rising edge of the wait signal. If the rerun input is sampled low, the CPU will rerun the bus cycle. ### 5.11 DRAM Interfaces The DRAM interface can be configured to use *Asynchronous DRAMs* (EDO or Fast Page Mode), *Synchronous DRAMs* (SDRAM), or *Double Data Rate Synchronous DRAMs* (DDR SDRAM). Selection between asynchronous and synchronous modes is made by the **sdram** mode bit in the R\_DRAM\_TIMING register. When this mode bit is not set (sdram = 0), the asynchronous DRAM mode is enabled and the registers: R\_DRAM\_TIMING and R\_DRAM\_CONFIG are used for configuration. When the **sdram** mode bit is set (sdram = 1) in R\_DRAM\_TIMING, the SDRAM mode is enabled and R\_SDRAM\_TIMING and R\_SDRAM\_CONFIG are used for configuration. | ASYNC DRAM | SDRAM | DDR SDRAM | |------------|-----------|-----------| | a25 | sdram_ras | sdram_ras | | a24 | sdram_cas | sdram_cas | | a23 | sdram_we | sdram_we | | ras0 | csd0 | csd0 | | ras1 | csd1 | csd1 | | ras2 | clk | clk | | ras3 | cke | cke | | cas<7.0> | dqm<7.0> | dqm<7.0> | | dramwe | - | dqs | Table 5-9 Pin Assignment for Asynchronous and Synchronous DRAM modes #### **Note 7:** For information regarding actual pin assignments see *19 Electrical Information*. The DRAM interface supports up to four banks of asynchronous DRAM chips and eight banks of Synchronous DRAM chips without external logic. 32-bit and 64-bit wide DRAM modules are supported as well as separate DRAM chips. DRAM bus width can be configured to 16 or 32 bits. All DRAM accesses are performed in bursts. When the first access in a series of bursts is performed, the internal address is shifted down so that the row address appears on the lower pins of the address bus. The row address is stored in an internal register in ETRAX 100LX for later reference. When the row address portion of the cycle is finished, the column address is put on the address bus. For every new burst, the row address is compared with the previously used row address that is stored in an internal register. If the row addresses are identical, the row address portion of the cycle can be left out which saves that time that would have been needed for the row access. # 5.12 Asynchronous DRAM Interface The ETRAX 100LX supports both Fast Page Mode and Hyper Page Mode (EDO) asynchronous DRAM chips. The timing diagram for a Fast Page Mode read cycle is shown in figure 5-5 below: Figure 5-5 Timing Diagram for Fast Page Mode Read Cycles If EDO DRAM chips are used, ETRAX 100LX uses the ras signal or the dramwe signal to tell the DRAM to release the data bus. The DRAM will release the data bus either when the ras signal goes high, or when the dramwe signal goes low. Figure 5-6 Timing Diagram for EDO Mode Read Cycles ### 5.12.1 Connecting the Asynchronous DRAM Banks Four asynchronous DRAM banks are combined into two groups with two banks in each group. Both banks in one group must have the same number of column address bits. When accessing these DRAM banks, the cas signals can be used either as bank strobes (bankwise cas mode), or as byte strobes (bytewise cas mode). One mode is used throughout a single application. Bytewise cas mode is illustrated in figure 5-7 below. Only one ras signal at a time will be active in each group. The cas signals are used to select the different bytes within the word or dword. Figure 5-7 Bytewise cas Mode. In a design using bankwise cas mode, as in figure 5-8, all the ras signals can be active simultaneously. casa decides which bank to access. If bytewise access is required, the byte cas signals are generated by gating casb, used as byte enables, and casa as shown in figure 5-9. Figure 5-8 Bankwise Accessing of Asynchronous DRAM Modules. Bankwise $\overline{\text{cas}}$ mode can be used without the $\overline{\text{cas}}$ gating if the software fulfills the following requirements: - CPU accesses to DRAM area are always cached. - All DMA descriptors are 32-bit aligned. - A DMA data buffer and program code/data, or two different DMA data buffers, are not merged within the same 32-bit aligned dword. Figure 5-9 Generating Byte cas. When using 64-bit wide asynchronous DRAM modules, one ras signal is assigned to each bank and this signal controls all 64 bits. Only one ras is active at a time. The cas signals are used to select the different bytes within the word, see figure 5-10. Upper and lower 32 bits are also tied together. In other words, bit 0 and bit 32 (bit 1 and bit 33, bit 2 and bit 34, etc.) are tied together, and one at a time they drive the databus. Figure 5-10 64-bit Wide Asynchronous DRAM Modules, All cas Signals Used For Selecting Bytes. In bankwise mode with 64-bit wide modules, the cas signals are used to activate 32 bits at a time as shown in figure 5-11. In this case, all ras signals can be active at the same time, but it is not possible to select the separate bytes in the DRAM. Figure 5-11 Bankwise Accessing, 64-bit Wide Asynchronous DRAM Modules. ## 5.12.2 Asynchronous DRAM Bank Configuration Four asynchronous DRAM banks are combined into two groups with banks 0 and 1 in group 0, and banks 2 and 3 in group 1. The two banks in each group always share the same configuration from R\_DRAM\_CONFIG. Common to all banks, the following configurations are available: #### Width (1 bit) Selects 16- or 32-bit DRAM bus width. | 0 | 16-bit DRAM bus width. | |---|------------------------| | 1 | 32-bit DRAM bus width. | #### EDO or Fast page mode (1 bit) | 0 | Fast page mode. | |---|-----------------| | 1 | EDO mode. | #### cas organization (1 bit) | 0 | The $\overline{\text{cas}}$ outputs are used for selecting bytes as in figure 5-7 or, if wide module mode is selected, as in figure 5-10. | |---|----------------------------------------------------------------------------------------------------------------------------------------------| | 1 | One cas output for each bank, see figure 5-8 and figure 5-9, or if wide module mode is selected, two cas outputs per bank as in figure 5-11. | ### Group select mode (5 bits) The group select mode determines how to select a group of DRAM banks: | Value | Select | |-------|-------------------------------------------------------------------------------------------------| | 0 | Always select group 0. | | 1 | Always select group 1. | | 2-8 | Reserved. | | 9-29 | The internal address bit number corresponding to the select mode value is used to select group. | | 30-31 | Reserved. | The following configurations are available for each group individually: #### Row Address Shift (3 bits) During the ras portion of the cycle, the row portion of the internal address is shifted down to the lower address outputs to which the asynchronous DRAM address pins are connected. The value given decides how many steps the address bits are shifted: | Value | Shift | |-------|-------------------------------------------------------------------------------------------------------------| | 0 | Internal address bits 29 - 9 shifted down to pins A21 - A1. | | : | | | : | | | 7 | Internal address bits $29$ - $16$ are shifted down to pins A14 -A1, and pins A21 - A15 are set to 0 (zero). | (The internal address bits 25 - 22 are output on pins A25 - A22 during ras cycles.) To accomplish the multiplexing of the row address and the column address on the address bus pins, the row address is shifted down to the lower pins of the bus during the ras portion of the bus cycle. Figure 5-12 Row Address Shifting During the ras Portion of the Bus Cycle #### Column Address Range (3 bits) The column address range determines how many address bits that are used in the column address. The ranges selected for the column address and the row address may overlap by one bit. When the row address has been shifted down, this bit corresponds to bit 1 on the address bus, which is not used in the 32-bit address. Consequently, the overlapping bit is part of the column address. There may also be a gap between the row address and column address parts, which are not used by the asynchronous DRAM bank. The bits in the gap can be used to select the bank and/or group. In wide module mode, the selection between casa and casb is done by the highest address bit given by the column address range. The column address range should, in this case, be set to one higher than the actual highest column address bit to the DRAM. | Value | Column Address Bits | |-------|-------------------------------------| | 0 | Up to and including address bit 8. | | : | | | : | | | 7 | Up to and including address bit 15. | #### **Bank Decode Mode (5 bits)** The bank decode mode determines how to select between the two banks in a group: | Value | Select | |-------|------------------------------------------------------------------------------------------------| | 0 | Always select bank 0 (group 0) or bank 2 (group 1). | | 1 | Always select bank 1 (group 0) or bank 3 (group 1). | | 2-8 | Reserved. | | 9-29 | The internal address bit number corresponding to the decode mode value is used to select bank. | | 30-31 | Reserved. | ### Wide Module Mode (1 bit) This mode supports 64-bit wide asynchronous <u>DRAM</u> modules where all 64 bits are controlled by the same ras signal. Both <u>casa</u> and <u>casb</u> are used within both groups of DRAM banks. If bankwise cas mode is combined with the wide module mode in any of the two groups, none of the groups can use casb as byte enables, see figure 5-11. | Value: | Select Mode: | |--------|-------------------| | 0 | Normal mode. | | 1 | Wide module mode. | # 5.13 Synchronous DRAM Interface The SDRAM interface can be configured to use a master clock of either 50 or 100 MHz. In 100MHz mode, the interface can also work as a DDR SDRAM interface. The maximum internal bus speed is always 50MHz regardless of the SDRAM master clock selection. There is support for two groups of SDRAM banks. A group is the set of SDRAM banks that are collectively either 16, 32, or 64 data bits wide. The groups are controlled by the chip selects, csd0 and csd1. Each group can be configured to use either two-bank or four-bank chips. The timing for a 50 MHz SDRAM read cycle is shown in figure 5-13: Figure 5-13 Timing Diagram for 50 MHz Read Cycles with cas Latency and ras Precharge Delay of 2 Delay Cycles In 100MHz mode commands are only issued once every two clock cycles in order to maintain the internal bus speed of 50MHz. Figure 5-14 Timing Diagram for 100 MHz Read Cycles with cas Latency and ras Precharge Delay of 2 Delay Cycles In DDR mode, a bi-directional data strobe, *dqs*, is used to qualify the data bus. The minimal burst length supported by DDR devices are two words and the second word is, therefore, masked during writes by the data mask, *dqm*, signals. Write latency for DDR devices is always set to one cycle. Figure 5-15 Timing Diagram for 100 MHz DDR Write Cycles ## 5.13.1 Power up and initialization SDRAMs have an internal configuration register that must be written during initialization with the *mode register set* (mrs) command. The SDRAM must be in idle mode and the mrs command should, therefore, be preceded by an auto refresh cycle to make sure that the banks are pre charged. The mrs command is issued by writing to the cmd field in R\_SDRAM\_TIMING. During the mrs cycle, the mrs data field in R\_SDRAM\_TIMING is output on address bits 15 - 0. All bits in the mrs field should normally be set to zero except for the cas latency select bits. It is possible to issue commands manually to the SDRAM by writing to the command field in R\_SDRAM\_TIMING. The possible commands are: - precharge all banks - auto refresh - mode register set - nop All commands have to be followed by a nop command before a new command can be issued. Note that at least five CPU nop instructions should be inserted between each write to R\_SDRAM\_TIMING. The manual commands should only be used during power up and initialization of the SDRAM banks. A typical initialization sequence is shown below: - 1 Configure the banks by writing to R\_SDRAM\_CONFIG. - **2** Configure the waitstate parameters and enable the master clock by writing to R\_SDRAM\_TIMING. - 3 Wait for 200us. - **4** Issue precharge all banks command by writing to the cmd field in R SDRAM TIMING. - **5** Wait five CPU nop cycles. - **6** Issue nop command by writing to the cmd field in R\_SDRAM\_TIMING. - **7** Wait five CPU nop cycles. Next, perform the following sequence eight times: - 1 Issue auto refresh command by writing to the cmd field in R\_SDRAM\_TIMING. - **2** Wait five CPU nop cycles. - **3** Issue nop command by writing to the cmd field in R\_SDRAM\_TIMING. - 4 Wait five CPU nop cycles. #### Finally, - 1 Issue mode register set command by writing to the cmd and mrs\_data fields in R\_SDRAM\_TIMING. - **2** Wait five CPU nop cycles. - **3** Issue nop command by writing to the cmd field in R\_SDRAM\_TIMING. - **4** Wait five CPU nop cycles. #### 5.13.2 Power save mode It is possible to run the SDRAM interface in the Power save mode. In this mode, the SDRAM banks will enter Power save mode immediately after each auto refresh cycle. This is done by deasserting the cke signal. The SDRAM banks will remain in Power save mode until the next SDRAM bus request, or until they have to be refreshed again. There is a penalty of one or two delay cycles for each Power save mode exit. The Power save mode exit delay can be configured in R\_SDRAM\_TIMING. #### 5.13.3 100 MHz mode It is possible to select a 100 MHz system clock together with both SDRAMs and DDR SDRAMs, but this will not give double the performance compared to the 50 MHz clock. Commands will only be issued every two cycles due to the internal 50 MHz bus speed. There will, however, be a speed-up since ras and cas latency will be shorter. #### 5.13.4 DDR mode The DDR mode must be used with a 100 MHz system clock due to an internal DLL in the DDR SDRAM chips. Since the DDR SDRAMs only use the dqm signals as a data mask during write operations, 64-bit modules with one common chip select for all eight bytes can not be used. ## 5.13.5 Connecting the Synchronous DRAM banks The Synchronous DRAM banks are combined into two groups where each group is controlled by a separate chip select signal. Figure 5-16 32-bit SDRAM Connection Comprising Four 16-bit SDRAM Devices. When using 64-bit wide DRAM modules, one chip select is assigned to each group and controls all 64-bits. The eight dqm signals are used to select the different bytes within the word. Upper and lower 32 bits are tied together. In other words, bit 0 and bit 32 (bit 1 and bit 33, bit 2 and bit 34, etc.) are tied together, and one at a time they drive the databus: Figure 5-17 64-bit Wide SDRAM Module Comprising Eight 16-bit SDRAM Devices. ## 5.13.6 Synchronous DRAM Bank Configuration SDRAM banks are combined into two groups where each group can use either twobank or four-bank chips. The following configurations are common for all banks: #### Width (1 bit) Width selects either a 16- or 32-bit DRAM bus width. | Value | Select | |-------|------------------------| | 0 | 16-bit DRAM bus width. | | 1 | 32-bit DRAM bus width. | #### Group Select Mode (5 bits) The group select mode determines how to select a group of DRAM banks. When using only one group, the group select mode value must be set to either 0 or 1. | Value | Select | |-------|-------------------------------------------------------------------------------------------------| | 0 | Always select group 0. | | 1 | Always select group 1. | | 2-8 | Reserved. | | 9-29 | The internal address bit number corresponding to the select mode value is used to select group. | | 30-31 | Reserved. | ## **Row Address Shift (3 bits)** During activate bank commands, the row portion and the bank select bits are shifted down to the lower address outputs to which the DRAM address pins are connected. During precharge bank, read bank, and write bank commands, only the bank select bits are shifted down to the lower address outputs. When using two groups, both groups must have the same row address shift value. The value given decides how many steps the address bus is shifted | Value | Shift | |-------|----------------------------------------------------------------------------------------------------------------| | 0 | Internal address bits 29 - 9 are shifted down to pins A21 - A1. | | : | E . | | : | 1 | | 7 | Internal address bits $29$ - $16$ are shifted down to pins A14 - A1, and pins A21 - A15 are set to $0(zero)$ . | Figure 5-18 SDRAM Address Bus Shift During Activate Bank Commands ### Column Address Range (3 bits) The column address range determines how many address bits that are used in the column address. The ranges selected for the column address and the row address may overlap by one bit. When the row address has been shifted down, this bit corresponds to bit 1 on the address bus, which is not used in the 32-bit address. Consequently, the overlapping bit is part of the column address. There may also be a gap between the row address and column address parts, which are not used by the asynchronous DRAM chip. One bit in the gap can be used to select the group. In wide module mode, the selection between casa and casb is done by the highest address bit given by the column address range. The column address range should, in this case, be set to one higher than the actual highest column address bit to the DRAM. Address bit a10 on SDRAM chips is used to select auto precharging during read and write commands and is not used as a column address. In 32-bit mode, a10 will correspond to a12 on the ETRAX 100LX, and in 16-bit mode, a10 will correspond to a11. a10 is never used as an address bit during read and write commands. In configurations with more than 10 column addresses, the address continues on the next higher address bit after a10. When using two groups, both groups must have the same column address range value. | Value | Column Address Bits | |-------|-------------------------------------| | 0 | Up to and including address bit 8. | | : | : | | : | : | | 7 | Up to and including address bit 15. | The following configurations are available for each group individually: #### Bank Type Mode (1 bit) Bank type mode selects either the two-bank or four-bank mode: | Value | Select | |-------|-----------------------------| | 0 | Two-bank mode is selected. | | 1 | Four-bank mode is selected. | #### **Bank Decode Mode (5 bits)** The bank decode mode determines how to select between bank 0 and 1 in a group. In the four-bank mode, bank 2 and 3 will selected by the next higher order address bit. The bank select bit or bits are shifted down to the lower address outputs according to the row address shift value. | Value | Column Address Bits | |---------|------------------------------------------------------------------------------------------------------------------| | 0 - 8 | Reserved. | | 9 - 29 | Internal address bit number corresponding to the decode mode value is used to select between bank 0 and 1. $ \\$ | | 30 - 31 | Reserved. | ### Wide Module Mode (1 bit) This mode supports 64-bit wide DRAM modules where all 64-bits are controlled by the same chip select signal. dqm0 to dqm7 are used to control the individual bytes within both groups of DRAM banks. | Value: | Select Mode: | |--------|------------------| | 0 | Normal mode | | 1 | Wide module mode | # 6 BOOTSTRAP METHODS # 6.1 Bootstrap Methods There are four different methods to bootstrap the ETRAX 100LX. They are presented in table 6-1 below. The cache is always initialized, regardless of the bootstrap method. The bus status pins bs3, bs2, bs1, and bs0 are sampled upon reset going high, and their values are stored to the internal register R\_BUS\_STATUS. The values of the bus status pins bs2 and bs1 determine which bootstrap method to use. | Values on pins<br>bs2 and bs1 at<br>reset | Bootstrap method | Description | |-------------------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------| | 00 | Normal bootstrap | Execution starts at address 0x80000002. | | 01 | Serial bootstrap | Serial port 0 is used, configured at 9600bps, 8 bits without parity, one start and one stop bit). | | 10 | Network bootstrap | The network bootstrap code is received in an Ethernet packet through the SNI or MII interface. $ \label{eq:main_sol} $ | | 11 | Parallel bootstrap | Parallel port 0 is used. | Table 6-1 Overview of the ETRAX 100LX Bootstrap Methods # 6.1.1 Normal Bootstrap Execution starts at address 0x80000002. # 6.1.2 Serial Bootstrap Serial port 0 is used, and is configured at 9600bps, 8 bits without parity, one start and one stop bit. A total of 784 bytes will be received. This data is stored in the cache, mapped to the address 0x380000F0, where execution then starts. # 6.1.3 Network Bootstrap The network bootstrap code is received in an Ethernet packet, as shown in table 6-2, through the SNI or MII interface. When the network bootstrap is used, the packet received must be an Ethernet packet (formatted to the IEEE 802.3 standard). | Packet byte nr. | Content (hex) | Description | |-----------------|----------------------|-----------------------------------------------------------------------------------------------------------------| | 0 - 5 | 01 40 8c 00 01 00 | Destination address. This is a multicast address within the Axis Ethernet address block. This address is fixed. | | 6 - 11 | XX XX XX XX XX XX | Source address. The address of the host transmitting the bootstrap packet. This address is not checked. | | 12 - 13 | type-length (2bytes) | This is currently not checked but it is recommended that the contents follow the 802.3 standard. | Table 6-2 Network Bootstrap Packet Header | Packet byte nr. | Content (hex) | Description | |-----------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 - 21 | AA AA 03 00 40 8C 88 56 | A SNAP header featuring the Axis vendor code (same as the Ethernet address block). This is the Axis ether-type specifically assigned for this purpose. This is currently not checked but is strongly recommended for network interoperability. | | 22 - 25 | FF FF FF FF | A tag signalling this packet as a bootstrap datagram. This is currently not checked, but is recommended for re-use of the Axis SNAP header. | | 26 - 29 | 00 00 00 00 | The bootstrap packet sequence number. The number must consist of only zeros in the first packet in the bootstrap sequence. This field is fixed. | Table 6-2 Network Bootstrap Packet Header After this header, the network bootstrap code starts. The downloaded program can be up to 1484 bytes in this package, and will be stored in the cache. The first byte of the destination address is mapped to address 0x380000E6, and execution will start at address 0x380000F4. The SNI and MII interfaces are selected by the value of the MDIO pin at start-up: | MDIO pin value | Interface | |----------------|-----------| | 0 | SNI | | 1 | MII | Table 6-3 Value of the MDIO Pin at Start-up # 6.1.4 Parallel Bootstrap Parallel port 0 is used. A total of 784 bytes will be received. The parallel port will immediately start in ECP reverse mode for the transfer of this data to the cache where it is stored. The data is mapped to address 0x380000F0, where execution then starts. IEEE 1284 negotiation phase is not performed. # 7 DMA DMA in the ETRAX 100LX provides a high data transfer rate to and from the internal peripheral interfaces, or from one location to another location in the external memory. It consists of ten DMA channels with five in each direction. The ten DMA channels are served by a DMA controller, which takes care of the data flow between the channels and the external memory. In addition, there are two external DMA channels (See *7.8 External DMA Channels*). # 7.1 DMA Operation ## 7.1.1 Overview of the ETRAX 100LX DMA Architecture A simplified architecture overview of DMA in the ETRAX 100LX, as well as a schematic flow of data is shown in figure 7-1 below. Figure 7-1 DMA Internal Overview There are five input channels (1, 3, 5, 7 and 9), and five corresponding output channels (0, 2, 4, 6 and 8). All input and output channels have a FIFO buffer. ### 7.1.2 Data Transfer There are three cases of data transference from: - 1 A peripheral interface to external memory - **2** External memory to a peripheral interface - **3** One memory location to another memory location Apart from these three cases of data transference, ETRAX 100LX DMA has two external DMA channels. See *7.8 External DMA Channels*. # Data Transfer from a Peripheral Interface to External Memory When data is to be transferred from one peripheral interface, it is first stored in a 64 byte FIFO buffer. When this buffer fills up to half its size (i.e. 32 bytes), the DMA controller is notified, and the data in the FIFO is transferred to external memory. If one of these memory addresses is present in the internal cache memory, the data is also stored in the internal cache memory. The transfer of data from a FIFO to the memory is done in bursts, and the length of these bursts is either 16 or 32 bytes as chosen by the software programmer in the register R BUS CONFIG. ## Data Transfer from External Memory to a Peripheral Interface When the DMA controller receives notice that a FIFO buffer is becoming half empty (i.e. less than or equal to 32 bytes), it begins a transfer of data from the external memory. When data is transferred from the external memory, it is read in bursts of 16 or 32 bytes as chosen by the software programmer in R\_BUS\_CONFIG. If the data in one of these memory addresses is present in the internal cache memory, the data is read from the internal cache memory. # Data Transfer from One Memory Location to Another Memory Location In order to increase the performance of DMA for this type of data transfer, there are two channels specifically designed for this task: channels 6 and 7. The FIFO buffers for channels 6 and 7 can be set to connect directly to each other in the register R\_GEN\_CONFIG. As with previous transfers, the data is read from and written to external memory when the FIFOs are either half empty or half full. If one of the memory addresses, where the data is located, is present in the internal cache memory, the data is read from or written to the internal cache memory. The data transfer to and from the FIFOs is done in bursts of 16 or 32 bytes as chosen by the software programmer in R BUS CONFIG. # 7.2 The DMA Channels There are only a limited number of combinations for the ten DMA channels which can be used for interconnection between the internal peripheral interfaces. The reason for this limitation is that some of the internal peripheral interfaces are multiplexed on the same package pins. Figures 7-2 and 7-3 below show how each peripheral interface is multiplexed on the DMA channels. Figure 7-2 DMA Input Channels Figure 7-3 DMA Output Channels The choice of which interface to be used is defined in the register R\_GEN\_CONFIG. The channels can be configured as shown in table 7-1 below: | DMA<br>channel | I/O system(s) available | | | Direction | FIFO<br>buffer<br>(bytes) | Priority | | |----------------|------------------------------|--------------------------------------------|------------------------------|-------------------|---------------------------|----------|---------| | 0 | Network | | | | out | 64 | Highest | | 1 | Network | | | | in | 64 | | | 2 | Parallel Port p0 | SCSI-8<br>Port p0 | Async serial<br>Port p2 | ATA | out | 64 | | | 3 | Parallel Port p0 | SCSI-8<br>Port p0 | Async serial<br>Port p2 | ATA | in | 64 | | | 4 | Parallel Port p1 | SCSI-8<br>Port p1 | | | out | 64 | | | 5 | Parallel Port p1 | SCSI-8<br>Port p1 | Async/Sync<br>serial Port p3 | ext_dma0 (note 1) | in | 64 | | | 6 | Async Serial<br>Port p0 | ext_dma1<br>(note 1) | = 3 | | out | 64 | | | 7 | Async Serial<br>Port p0 | ext_dma1 Memory transfer (note 1) (note 2) | | in | 64 | | | | 8 | Async/Sync<br>Serial Port p1 | USB Port p1 & p2 (note 3) | | out | 64 | | | | 9 | Async/Sync<br>serial Port p1 | USB Port p1 & p2 (note 3) | | in | 64 | Lowest | | Table 7-1 DMA Output channels - **Note 1:** ext\_dma0 and ext\_dma1 are external DMA channels to be used between the external memory and an external I/O device, see *7.8 External DMA Channels*. - **Note 2:** Memory-to-memory transfer. Channels 6 to channel 7 can be set for immediate connection, which provides an efficient way of transferring data from one memory location to another memory location. - Note 3: When Channels 8 and 9 are configured for USB, their priority becomes higher than the priority for channel 2 but lower than channel 1 (e.g. Highest: channel 0, 1, 8, 9, 2, 3...Lowest). See 7.4.2 DMA Linked Lists for USB All 10 DMA channels (0 - 9) have a 64 byte FIFO buffer to allow efficient handling of burst mode DRAM access, and software can read the number of bytes in each FIFO buffer. For input channels, software can also flush the FIFO contents to the memory data buffer by forcing an **eop** (see table 7-2) in the data stream flowing into the FIFO by using the register R\_SET\_EOP. # 7.3 DMA Registers, Linked Lists, and Descriptor Format # 7.3.1 DMA Registers There are a set of DMA registers, one set for each channel, which the DMA controller uses to handle the buffers and to store information about the buffers in the external memory. These registers and a little about of their functions are shown in figure 7-4 below: Figure 7-4 DMA Registers and the Structure of the Linked List The figure above shows the DMA registers and a simplified linked list in the external memory. During normal operation, the only registers accessed by software are: - R\_DMA\_CHx\_FIRST - R\_DMA\_CHx\_CLR\_INTR - R\_DMA\_CHx\_CMD The R\_DMA\_CHx\_FIRST register is used to locate the DMA list. R\_DMA\_CHx\_FIRST points to the first descriptor in the linked list as shown in figure 7-4 above. The R\_DMA\_CHx\_DESCR register contains the current descriptor's address, and the R\_DMA\_CHx\_NEXT contains the address to the next descriptor. R\_DMA\_CHx\_CLR\_INTR is used to clear interrupts. For more details see 7.6 DMA Transfer/Setup Examples. R\_DMA\_CHx\_CMD is the command register to control DMA operation, and is used to reset and start DMA transfers. When a command is completed, the DMA channel sets R\_DMA\_CHx\_CMD to **hold** (0) and stops. The R\_DMA\_CHx\_CMD register has five commands: - Hold - Start - Restart - Continue - Reset The **hold** command, which is completed immediately, holds the DMA channel in its current state. The **hold** command will fail, however, if the DMA channel has completed the previous command before the **hold** command is given. An unsuccessful **hold** command is indicated by the fact that the DMA channel reaches end-of-list so that R\_DMA\_CHx\_FIRST is zero. A failed **hold** command is also indicated if the DMA channel receives stop-from-io, and the **stop** bit is set in the descriptor at R\_DMA\_CHx\_DESCR. When the **start** command is given, the DMA channel starts processing the list at R\_DMA\_CHx\_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a **reset** command (3). If the DMA channel is already running this command is ignored. The **restart** command restarts the DMA channel after end-of-list has been reached. The DMA channel re-reads the descriptor at R\_DMA\_CHx\_DESCR, and if the eolbit is no longer set, it immediately follows the next link in the re- read descriptor ignoring the **wait**, **intr**, and **eop** bits. This command is completed at end-of-list (1), stop-from-io (2), or a **reset** command (3). If the DMA channel is already running this command is ignored (See note 4). A **continue** command tells the DMA channel to continue after a successful **hold** command. If the **hold** command was unsuccessful, the continue command will be interpreted as a **restart** command. The **continue** command completes when the command held by the **hold** command has completed. (See note 4) The **reset** command resets the DMA channel and its FIFOs. When the channel has won arbitration, the **reset** command takes 100 ns to complete. **Note 4:** The **restart** and **continue** commands have the same value (3). Three registers manage the actual storage of data in the buffers: - The R\_DMA\_CHx\_BUF register: pointer to the next (byte) position in the data buffer - The R\_DMA\_CHx\_HWSW register (sw field): gives the total length (in bytes) of the data buffer - The R\_DMA\_CHx\_HWSW register (**hw** field): gives the number of bytes left in the data buffer. ### 7.3.2 DMA Linked Lists ETRAX 100LX DMA stores data in the external memory, in buffers linked together with the use of a list descriptor. Each list descriptor contains a number of data fields, which tell the DMA controller where to find the next descriptor in the list. Figure 7-5 ETRAX 100LX Buffer Structure The list descriptors also contain information about the location and size of the data buffer as well as other status information. This organization of data storage in memory has the advantage of having efficient memory management, and a very flexible structure. DMA descriptors and data buffers do not have any alignment restrictions, except for the USB EP descriptor which must be 32-bit aligned (See section 7.4.3). However, performance improves if data and DMA descriptors are 32-bit and cacheline aligned. For a more detailed overview of the list descriptor see 7.3.3 DMA Descriptor Format. # 7.3.3 DMA Descriptor Format The construction of linked lists is done by defining DMA descriptors. The DMA descriptor consists of four 32-bit fields. The contents of a DMA descriptor is shown in figure 7-6 below: Figure 7-6 The DMA Descriptor Format The first 32-bit field of the descriptor gives the length of the data buffer **sw\_len** and a number of commands. The second 32-bit field gives the address to the next descriptor in the linked list, and the third 32-bit field gives the address to the data buffer **buf**. The last 32-bit field contains status information written by the DMA controller. Table 7-2 describes the contents of the DMA descriptor in more detail: | Bit | Name | Explanation | | | |--------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | (addr + 0): | | | | | | 31-21 | reserved | (note 6). | | | | 20 | ecp_cmd | ECP command used by channel 2 and 4 when connected to a parallel port in ECP mode. | | | | | tx_err | Force transmission error used by channel 0. | | | | 19 | intr | Generate a descriptor interrupt when advancing to next descriptor. | | | | 18 | wait | Wait until FIFO is empty before advancing to next descriptor, and also delay descriptor and end-of-packet interrupts until FIFO is empty (output channels only). | | | | 17 | eop | Last descriptor in a packet (output channels only). | | | | 16 | eol | Last descriptor in the list. | | | | 15-0 | sw_len | Length in bytes of data buffer. (If all bits are 0, the length is $2^{16}$ ) | | | | (addr + 4): | | | | | | 31-0 | next | Pointer to next descriptor in list (no alignment restrictions). If eol $== 1$ next is not used. | | | | (addr + 8): | | | | | | 31-0 | buf | Pointer to first byte in data buffer (no alignment restrictions). | | | | (addr + 12): | (note 5) | | | | | 31 | reserved | (note 6) | | | | 30-24 | fifo_len | If stop == 1; Number of bytes in FIFO (output channels only). | | | | 23 | crc_err | If eop == 1; Received packet has CRC error, used by channel 1. | | | | 22 | align_err | If $eop == 1$ ; Received packet has alignment error, used by channel 1. | | | | 21 | reserved | (note 6). | | | | 20 | stop | Output channel was stopped by I/O interface. Bit 20 and bit 17 are mutually exclusive. $$ | | | | 19-18 | reserved | (note 6) | | | | 17 | eop | Last descriptor in a received packet. Bit 20 and bit 17 are mutually exclusive. | | | | 16 | reserved | (note 6). | | | | 15-0 | hw_len | If eop == 1; Number of bytes written to the data buffer. (If all bits are 0, the length is $2^{16}$ ) | | | | | | If stop == 1; Number of bytes read from the data buffer. (If all bits are 0, the length is $2^{16}$ ) | | | | | | If eop == 0 && stop == 0; hw_len is not valid. (i.e you have to use sw_len to get the number of transferred bytes) | | | Table 7-2 DMA Descriptor contents - Note 5: The 32-bit status field is only written if **eop** or **stop** is set to one. For software to be able to know that the status field has been written or not, the status field of the descriptor must be cleared to all zeros before the DMA channel is started. The **eop** bit is written in the last descriptor of a packet. - **Note 6:** For compatibility with future versions of ETRAX processors, reserved fields must be set to 0 before starting DMA. When read, no assumption can be made about their value. # 7.4 DMA Registers, Linked Lists, and Descriptor Format for USB # 7.4.1 DMA Registers for USB Figure 7-7 below shows the DMA registers for USB support in the ETRAX 100LX: Figure 7-7 DMA Registers for USB During normal operation, the only registers accessed by software are: - R\_DMA\_CH8\_SUBx\_EP - R\_DMA\_CH8\_SUBx\_CMD - R\_DMA\_CH8\_SUBx\_CLR\_INTR R\_DMA\_CH8\_SUBx\_EP is used to locate the circular list of EP descriptors, R\_DMA\_CH8\_SUBx\_CMD is used to start the sub channel, and R\_DMA\_CH8\_SUBx\_CLR\_INTR is used to clear interrupts. For more details see chapter 8 Universal Serial Bus. R\_DMA\_CH8\_SUBx\_EP points to the current *Endpoint* (EP) descriptor in the EP list. R\_DMA\_CH8\_NEP points to the next EP descriptor in the EP list. R\_DMA\_CH8\_SUB points to the current *Sublist* (SB) descriptor in the current sublist. The subchannel is either enabled or disabled with R\_DMA\_CH8\_SUBx\_CMD, and the operation of the sub channels are then controlled by the USB hardware. Interrupts are cleared by writing to R\_DMA\_CH8\_SUBx\_CLR\_INTR. ### 7.4.2 DMA Linked Lists for USB To handle USB in a practical way, DMA channel 8 has extended functionality to handle four sets of two dimensional lists. One set of lists is for each transfer type: control-, interrupt-, isochronous-, and bulk-transfers. When the two dimensional lists are used, the priorities of channels 8 and 9 are higher than channel 2, but lower than channel 1. The construction of a linked list is done by defining DMA descriptors. There are three descriptor formats in the ETRAX 100LX. The first is the standard format and is used for all non USB communication and incoming USB communication. The other two formats are used only by out going USB communication. One forms a list of endpoints, and the other forms lists of data to the individual endpoints. See 7.4.3 DMA Descriptor Format for USB. You can view the DMA list structure as a two dimensional list where the endpoint descriptors form one dimension, and by connecting a list of USB Sub-list descriptors to each endpoint descriptor, the USB Sublist forms the second dimension. The same DMA list structure is used both when the USB controller is in Host mode, and when it is in Device mode. In Device mode, however, the endpoint list only contains one endpoint descriptor. Figure 7-8 DMA List Structure for USB There is no information in the descriptors telling which descriptor format a specific descriptor has. DMA interprets the descriptors based on how it is started, and on what internal state it is currently in. # 7.4.3 DMA Descriptor Format for USB # The Standard Descriptor Format The standard descriptor format in figure 7-9 below is similar to figure 7-6 with the following extensions of the 32-bit status field for channel 9 when connected to the USB interface. Figure 7-9 The DMA Descriptor Format for USB This 32-bit field contains status information written by the DMA controller. Table 7-3 describes the contents of the standard DMA descriptor in more detail: | Bit | Name | Explanation | |--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (addr + 12): | | | | 31 - 29 | reserved | (note 8) | | 28 - 24 | ep_id | If eop == 1; ID of end point that is generating this data. | | 23 | nodata | If eop == 1; There is no data in the buffer, and <b>hw_len</b> is not valid. Used when End Of USB Transfer was indicated by an empty USB packet. | | 22 | error | If eop == 1; Received USB transaction has an error. Error status can be read in USB controller using $ep\_id$ as index. The corresponding endpoint is disabled to prevent status from being lost. (note 9) | | 21 | eot | If eop == 1; End Of USB Transfer. | | 20 - 18 | reserved | (note 8) | | 17 | eop | Last descriptor in a received packet. | | 16 | reserved | (note 8) | | 15-0 | hw_len | If (eop == 1 && !nodata); Number of received bytes in buffer. (If all bits are 0, the length is $2^{16}$ ) | Table 7-3 DMA Descriptor contents for USB - Note 7: The 32-bit status field is only written if **eop** is set to one. For software to be able to know that the status field has been written or not, the status field of the descriptor must be cleared to all zeros before the DMA channel is started. The **eop** bit is written in the last descriptor of a packet. - **Note 8:** For compatibility with future versions of ETRAX processors, reserved fields must be set to 0 before starting DMA. When read, no assumption can be made about their value. - **Note 9:** For ISO IN endpoints, **error** can be the result of all USB: packet errors, no replies, or wrong packet sizes. No error is reported in the USB controller and the EP is not disabled. # **USB EndPoint List Descriptor Format, EP** The DMA controller will only assume this format for sub channels of channel 8. Note that EndPoint descriptors must be 32-bit aligned. Figure 7-10 USB EndPoint List Descriptor Format, EP The first 32-bit field of the descriptor gives a number of commands and an area **hw\_len** for the DMA controller to save internal information. The second 32-bit field gives the address to the associate sub list. The last 32-bit field gives the address to the next EP descriptor in the EP list. Table 7-4 describes the contents of the USB EndPoint list descriptor format, EP in more detail: | Bit | Name | Explanation | | | | |----------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (addr + 0): (1 | (addr + 0): (note 10) | | | | | | 31 - 29 | reserved | (note 11) | | | | | 28 - 24 | ep_id | Endpoint ID. Used by USB controller to associate a sublist with an endpoint. (note $12$ ) | | | | | 23 - 21 | reserved | (note 11) | | | | | 20 | enable | Enable. 0: There is no sublist, advance to next endpoint. 1: There is a sublist, start processing the sublist. Note that software can only enable an endpoint, and that it has to be done according to the procedure in section 8.8.5 Managing SB Descriptor Lists in Host Mode in Chapter 8 Universal Serial Bus. To disable an endpoint, the EP descriptor must be removed from the endpoint list according to section 8.8.4 Managing EP Descriptor Lists in Host Mode. | | | | | 19 | intr | Generate a $dma8\_subx\_descr$ interrupt when advancing to next descriptor. (note 12) | | | | | 18 | reserved | (note 11). | | | | | 17 | eof | This is the last endpoint descriptor in a frame. Note that this bit will not generate any DMA interrupt. This field is not used in Device mode. (note 12) | | | | | 16 | eol | This is the last descriptor in the list. The list is assumed to be circular, and the ${\bf nep}$ field is used even if eol is true. (note 12) | | | | | 15-0 | hw_len | Counter used by the DMA controller to remember bytes left in current sublist data buffer. It should be cleared by software before the endpoint is enabled, and then ignored by software. | | | | | (addr + 4): | | | | | | | 31-0 | sub | Pointer to first sublist descriptor in sublist. If enable $== 0$ sub is not used, there are no alignment restrictions on sublist descriptors. | | | | | (addr + 8): | | | | | | | 31-0 | nep | Pointer to next endpoint descriptor in endpoint list. The two least significant bits in the nep field must be zero since it is a requirement that endpoint descriptors are 32-bit aligned. (note 10) | | | | Table 7-4 USB EndPoint list descriptor contents - **Note 10:** EndPoint descriptors must be 32-bit aligned, i.e. addr<1:0> == 00. - **Note 11:** For compatibility with future versions of ETRAX processors, reserved fields must be set to 0 before starting DMA. When read, no assumption can be made about their value. - Note 12: The ep\_id, intr, eof, and eol fields must not be changed when the enable field is equal to 1. Also, note that there is a special procedure to clear the enable field according to Table 7-4, and chapter 8.8.4 Managing EP Descriptor Lists in Host Mode. # **USB Sublist Descriptor Format, SB** The DMA controller will only assume this format for sub channels of channel 8. Figure 7-11 USB Sublist Descriptor Format, SB The first 32-bit field of the descriptor gives a number of commands, and the length of the data buffer for outgoing transfers is given in **sw\_len**. For Host mode IN transfers, **sw\_len** gives the number of packets to be received by DMA channel 9. The second 32-bit field gives the address to the next descriptor in the linked list. The third 32-bit field gives the address to the data buffer **buf** for outgoing transfers. For Host mode IN transfers there is no data buffer appended, so **buf** should be set to NULL. Table 7-5 describes the contents of the USB Sublist descriptor format, SB in more detail: | Bit | Name | Explanation | | | | |-------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (addr + 0): | | | | | | | 31 - 30 | reserved | (note 14) | | | | | 29 - 24 | rem | Expected number of bytes in the last packet of a Host mode IN transfer. Used to tell the USB controller the expected length of the last packet in a Host mode IN transfer. The expected number of packets in a Host mode IN transfer is the number of bytes in the data buffer at buf. This field is not used in Device mode. | | | | | 23 | reserved | (note 14). | | | | | 22 | full | If eot==1, full==1 tells the USB that an out transfer is a full length transfer. In the special case where the transfer-length is evenly divisible by the packetsize, this field prevents the USB sending an empty packet. In all other cases this field is don't care. | | | | | 21 - 20 | tt | USB Transfer Type: 00: zout (Zero length output transfer) 01: in (Input transfer) (not used in Device mode) 10: out (Output transfer) 11: setup (Setup transfer) (not used in Device mode) | | | | | 19 | intr | Generate a <b>dma8_subx_descr</b> interrupt when advancing to the next descriptor. | | | | | 18 | reserved | (note 14). | | | | | 17 | eot | This is the last descriptor in a USB transfer.<br>Note that this bit will not generate any DMA interrupt. | | | | | 16 | eol | This is the last descriptor in the sublist. When eol is true $(1)$ , the $\mbox{\bf next}$ field is not used. | | | | | 15-0 | sw_len | Length in bytes of data buffer for outgoing transfers, and number of packets for Host mode IN transfers (If all bits are 0, the length is $2^{16}$ ). | | | | | (addr + 4): | (addr + 4): | | | | | | 31-0 | next | Pointer to next descriptor in list (no alignment restrictions). If eol == 1 next is not used. | | | | | (addr + 8): | | | | | | | 31-0 | buf | Pointer to first byte in the data buffer (no alignment restrictions). (note $13$ ) | | | | Table 7-5 USB Sublist descriptor contents - **Note 13:** For a Host mode IN transfer, DMA will not use the data referenced by **buf**. - **Note 14:** For compatibility with future versions of ETRAX processors, reserved fields must be set to 0 before starting DMA. When read, no assumption can be made about their value. # 7.5 DMA Interrupt There are two interrupts per channel: a descriptor interrupt, and an end-of-packet interrupt. Each channel has its own interrupt vector, and can be individually enabled or disabled. For a list of all interrupt vector numbers see chapter 17 *Interrupts*. For output channels, the interrupts are generated if the **intr** bit (descriptor interrupt) or **eop** bit (end-of-packet interrupt) in the descriptor are set. The interrupts are generated after DMA has read all data from the associated data buffer. If the **wait** bit is set in the descriptor, the interrupt is delayed until the DMA FIFO is emptied by the connected I/O interface. For input channels the descriptor interrupt is generated if the **intr** bit is set in the descriptor, and the end-of-packet interrupt is generated when the peripheral interface signals end-of-packet to the DMA controller. The interrupts are generated after DMA has written all the data to the associated data buffer. Interrupts are cleared with a write to the R\_DMA\_CHx\_CLR\_INTR internal register. For a more detailed information regarding enable, disable, and read interrupts, refer to chapter 17 *Interrupts*, or chapter 18.14 *DMA Registers*. # 7.6 DMA Transfer/Setup Examples In the following examples, a pseudo code notation is used to access bit fields in internal registers: *REG.field*. Here *REG* is the name of the register and *field* is the bit field in the register. Also, symbolic constants for values are used. See chapter 18.14 *DMA Registers* for a list of valid register, field, and constant names. In addition, the following C structure is assumed for descriptors where a byte is an 8-bit unsigned integer, a word a 16-bit unsigned integer, and a dword a 32-bit unsigned integer: ``` struct descriptor { word sw_len; word ctrl; dword next; dword buf; word hw_len; byte status; byte fifo_len; } ``` For a information regarding USB to DMA transfer/setup examples, please refer to chapter 8.8 *Procedures*. # 7.6.1 Initiate and Setup a DMA Transfer To initiate and setup a DMA transfer you typically: - 1 Connect the I/O interface to the desired DMA channel in R\_GEN\_CONFIG. - 2 Initiate the I/O interface. - **3** Reset the DMA channel by writing the reset-cmd to R\_DMA\_CHx\_CMD. - 4 Initiate the linked list. - **5** Set R\_DMA\_CHx\_FIRST to the first descriptor. - **6** Start DMA by writing start-cmd to R\_DMA\_CHx\_CMD. - **7** Start the I/O interface. - 8 Wait for the DMA transfer to end. This is the typical sequence of steps to initiate and set up a DMA transfer. However, for some I/O interfaces the sequence has to be altered. See each interface's respective chapter for a description of possible alterations to the procedure above. ## 7.6.2 Reset DMA Channel To reset a DMA channel and its FIFO, the reset-cmd is written to R\_DMA\_CHx\_CMD. The reset takes a while (>100ns), and when it is done DMA clears R\_DMA\_CHx\_CMD. Pseudo C-macros, and code for a DMA reset: ``` #define reset_dma( n ) \ R_DMA_CHn_CMD.cmd = reset #define wait_reset_dma( n ) \ while( R_DMA_CHn_CMD.cmd != hold ) ``` #### Example: ``` /* Reset channel 0, 3, and 7. */ reset_dma( 0 ); reset_dma( 3 ); reset_dma( 7 ); /* Wait for reset do complete. */ wait_reset_dma( 0 ); wait_reset_dma( 3 ); wait_reset_dma( 7 ); ``` # 7.6.3 Initiating Linked List The following is a C-macro to initiate a descriptor, and how to use it to form a linked list. The **next** field is Don't-Care at end of list. ``` #define descr( buf, len, next, flags ) \ { len, flags, next, buf, 0, 0, 0 } ``` ### Example: ``` dma_descr olist[] = { descr( pattern0, sizeof pattern0, &olist[1], d_int | d_eop ), descr( pattern1, sizeof pattern1, &olist[2], 0 ), descr( pattern2, sizeof pattern2, 0xDC, d_eol ) }; ``` ### 7.6.4 Start a DMA Transfer To start a DMA transfer R\_DMA\_CHx\_FIRST and R\_DMA\_CHx\_CMD have to be programmed. A sample C-macro for this is: ``` #define start_dma( n, desc ) \ R_DMA_CHn_FIRST.first = (unsigned) desc; \ R_DMA_CHn_CMD.cmd = start ``` # Example: ``` start dma(0, olist); /* Start channel 0 with olist. */ ``` # 7.6.5 Restart a DMA Transfer To append new data to a linked list the following steps should be taken. Note that the sequence of these steps is important: - 1 Initiate the new list that shall be appended to the old list. - **2** Set End-Of-List in the last descriptor of the new list. - **3** Update the **next** field in the last descriptor of the old list. - **4** Clear End-Of-List in the last descriptor of the old list. - **5** Write the restart command to R\_DMA\_CHx\_CMD. The following code will work regardless of whether you give the restart command before or after DMA has finished the old list. ``` #define append_descr( n, old_last, new_first ) \ old_last->next = new_first; \ old_last->cmds =& ~d_eol; \ R_DMA_CHn_CMD.cmd = restart ``` # Example: ``` /* Initiate new list. */ dma_descr nlist[] = { descr( pattern3, sizeof pattern3, &nlist[1], d_int | d_eop ), descr( pattern4, sizeof pattern4, &nlist[2], 0 ), descr( pattern5, sizeof pattern5, 0xDC, d_eol ) }; append( 0, &olist[2], nlist ); ``` # 7.6.6 Hold DMA Temporarily and Continue Later To temporarily hold DMA the following two C *macros* could be used. ``` #define hold_dma( n ) \ R_DMA_CHn_CMD.cmd = hold #define continue_dma( n ) \ R_DMA_CHn_CMD.cmd = continue ``` # 7.7 Memory to Memory DMA DMA channels 6 and 7 can be set up for memory to memory DMA, where the FIFO buffers of channels 6 and 7 connect directly to each other. This is configured in R\_GEN\_CONFIG. To make sure the last part of the memory to memory transfer is written out from the destination FIFO to external memory in the destination list, either the **eop** bit has to be set in the last descriptor of the source list, or the software has to manually flush the destination FIFO by writing to the R\_DMA\_SET\_EOP register when DMA channel 7 has read all data from the source list and stopped. # 7.8 External DMA Channels The external DMA channels ext\_dma0 and ext\_dma1 offer a DMA-like interface between external memory and external I/O devices. The external DMA channels operate in a "pseudo DMA" fashion, which differs from an ordinary DMA operation in that the data from the memory or the I/O device pass through the FIFO buffer of an internal DMA channel (see figure 7-12). This construction has the advantage of the bus width and timing for the I/O device, being different from the bus width and timing for memory since the accesses are performed in separate bus cycles. Figure 7-12 ETRAX 100LX External DMA Channels' Pseudo DMA Principle Note 15: External DMA has the highest priority and might starve the other I/O interfaces such as Ethernet. ext\_dma0 and ext\_dma1, which are available for external I/O, are bidirectional: - ext dma0 uses the internal DMA channels 4 and 5. - ext dma1 uses the internal DMA channels 6 and 7. The data bus width of the DMA transfers can be configured to either 8, 16, or 32 bits. Each external DMA channel uses two control signals to enable a handshake procedure: - DMA request (dreq0, dreq1) - DMA acknowledge (dack0, dack1) # 7.8.1 External DMA Configuration The operational mode for external DMA channels ext\_dma0 and ext\_dma1 are configured in registers R\_EXT\_DMA\_0\_CMD and R\_EXT\_DMA\_1\_CMD. The following modes can be individually configured for each external channel: - Width of the transfers (8, 16 or 32 bits) - Direction of the transfers (in or out) - Start and stop of the transfers - Polarity of the request signal - Polarity of the acknowledge signal - Request/acknowledge mode (burst or handshake) - Use of the transfer counter (on or off) Before an external DMA channel is started, it needs to be connected to the corresponding internal DMA channels. This configuration is made in register R\_GEN\_CONFIG. ### 7.8.2 External DMA Address External DMA bus cycles are identical to standard bus cycles, and will be directed to a constant, configurable address. This address may be used instead of, or in combination with the DMA acknowledge signal to decode the DMA cycles. The addresses for the two channels are configured in R\_EXT\_DMA\_0\_ADDR and R\_EXT\_DMA\_1\_ADDR. The two most significant bits of the address are always set to 10 (binary) so as to not access the internal cache memory or the DRAM (see figure 7-14). | 31 | 30 | 29 2 | 1 | 0 | |----|----|----------------------------|---|---| | 1 | 0 | External interface address | 0 | 0 | Figure 7-13 The Address Bus When Addressing an External Interface ### 7.8.3 Initialization It is recommended that the external DMA channel is set up in the following sequence: - 1 Connect the external DMA to its associated internal DMA channels. This is configured in R\_GEN\_CONFIG. - **2** Configure the external DMA channel, but do not start it (configuration is made in: R\_EXT\_DMA\_x\_CMD and R\_EXT\_DMA\_x\_ADDR). - 3 Reset and start the associated internal DMA channels. - **4** Start the external DMA channel (**run** bit in R\_EXT\_DMA\_x\_CMD). # 7.8.4 Request/Acknowledge Signaling Each external DMA channel has a pair of handshaking signals, **dreq** and **dack**. Both can be configured to be active high or active low. There are two modes for the request/acknowledge signalling: *handshake mode* and *burst mode*. #### **Handshake Mode** In handshake mode, a 4-phase handshaking scheme is used: - 1 The I/O device sets **dreq** active. - 2 The ETRAX 100LX sets dack active and performs a read or write operation to the I/O device (i.e. an external DMA bus cycle). - **3** The I/O device negates **dreq**. This can be done immediately after **dack** gets active, and does not have to wait for the bus cycle to complete. - **4** The ETRAX 100LX negates **dack**. The ETRAX 100LX will never negate **dack** before the external DMA bus cycle is completed. Figure 7-14 Timing Diagram for Handshaking Mode ### **Burst Mode** In burst mode, the ETRAX 100LX will always release the **dack** signal immediately after the completion of the external DMA bus cycle, and will continue to issue new external DMA bus cycles as long as the I/O device keeps the **dreq** active. Each cycle will be accompanied by a **dack** pulse. If the I/O device wants to stop or pause the transfers, it has to negate the **dreq** immediately after receiving the **dack** for the last cycle. Figure 7-15 Timing Diagram for Burst Mode # 7.8.5 Start and Stop of the Transfers After initializing the external DMA (see section 7.8.3 Initialization), the external DMA interface is started by setting the **run** bit in the R\_EXT\_DMA\_x\_CMD register. When the external DMA channel is running, the external I/O device can start and stop the transfers by activating and deactivating the **dreq** signal. Except for **dreq** going inactive, the transfers could stop for one of the following reasons: - The external DMA channel is stopped by the software, by setting the **run** bit in R\_EXT\_DMA\_x\_CMD to **stop**. - The transfer counter (see below) is in use and has expired. - The descriptor list of the associated internal DMA channel contained an **eop** flag (only in the case of transfers from ETRAX 100LX to the I/O device). - The data buffers of the associated internal DMA channel are exhausted. If one of the first two cases occurs during input from the external I/O to the ETRAX 100LX, an **eop** status bit will be set in the corresponding DMA descriptor in the descriptor list for the associated internal DMA channel, and the internal DMA channel will advance to the next descriptor. ### 7.8.6 Transfer Counter The number of transfers performed by the external DMA channel can be controlled by a transfer counter ( $tfr\_count$ field in register R\_EXT\_DMA\_x\_CMD). The transfer counter is configured with the desired number of transfers (where a transfer is either 8, 16, or 32 bits), and will be decremented by one for each transfer. When the counter reaches zero, it will stop the transfers and clear the run bit in R\_EXT\_DMA\_x\_CMD. The current values of the run bit and the transfer counter can be read from the register R\_EXT\_DMA\_x\_STAT. # 7.8.7 External DMA Interrupts Each external DMA channel will generate an interrupt, **ext\_dma0** and **ext\_dma1** respectively, whenever the run bit in R\_EXT\_DMA\_x\_CMD is cleared. When not waiting for an external DMA transfer to complete, the interrupt should be masked off in R\_IRQ\_MASK0\_SET. For further information about interrupts refer to chapter 17 *Interrupts*. # 8 UNIVERSAL SERIAL BUS ETRAX 100LX includes an on-chip Universal Serial Bus (USB) interface that complies with the Universal Serial Bus Revision 1.1 specification. The interface is equipped with two USB ports designated p1 and p2 respectively, the inputs and outputs of which are multiplexed on to the same pins as other interface applications (see chapter 19 *Electrical Information*). The characteristics and operational principles of both ports are similar. The electrical interface is compatible with a Philips model PDIUSBP11A transceiver (or equivalent), as illustrated below. Figure 8-1 USB Transceiver Interface # 8.1 Principle of Operation ### 8.1.1 Basic Architecture of the USB Interface Figure 8-2 Basic USB Architecture The USB is comprised of a root hub with ports p1 and p2 and the USB controller. The ports are duplex, and each port is connected to a dedicated transceiver (via I/O multiplexing not shown on the diagram). The root hub in the data stream controls the two USB ports and is itself managed by the USB controller, which handles frame control and timing, transaction protocol, port management and error recovery. In device mode, the root hub is only used as a port controller. The USB interface operates in cooperation with the Direct Memory Access (DMA) controller, which manages all traffic schedules and communicates with the USB via two DMA channels. DMA channel 8 handles the traffic schedules and data buffers for downstream (OUT) traffic: DMA channel 9 handles the data buffers for upstream (IN) traffic. Please refer to chapter 7 *DMA* for detailed information on DMA. # 8.1.2 Modes of Operation of the USB Interface The USB interface can be configured to operate in one of two modes: **Host mode** - in which ETRAX 100LX acts as the host for devices connected to the USB. In this mode, the USB interface can use either or both ports. **Device mode** - in which ETRAX 100LX acts as a device communicating with a host elsewhere. Either of the two USB ports can be used in this mode, but not both simultaneously. # 8.2 Operational States of the USB Controller The USB controller has six operational states which are illustrated below. Figure 8-3 Operational States of the USB Controller The UNCONFIGURED state prevails immediately after the execution of a **deconfig** command or system reset. The USB controller is stopped, the ports are disabled, frame timing is not generated and no traffic is processed. HOST\_MODE prevails in response to a **host\_config** command while in the UNCONFIGURED state, or a **reset** command while in the HOST\_STARTED or HOST\_RUNNING state. In HOST\_MODE the USB controller is prepared to act as a host. Commands can be issued to the ports and frame timing is generated, but no traffic is processed. The HOST\_STARTED state prevails when one or both ports have been enabled in HOST\_MODE, or in response to a host\_stop command in the HOST\_RUNNING state. In the HOST\_STARTED state, frame timing is generated and transmitted but traffic is not processed. The HOST\_RUNNING state prevails in response to a **host\_run** command in the HOST\_STARTED state. This is the fully operational state of the USB controller in Host mode, with the configured port(s) handling processed traffic. DEVICE\_MODE prevails in response to a **dev\_config** command while in the UNCONFIGURED state. The USB controller is prepared to act as a device and commands can be issued to the selected port. The DEVICE\_ACTIVE state prevails in response to an active command in the DEVICE\_MODE. This is the fully operational state of the USB controller in Device mode, with frame timing generated and the configured port handling traffic. Please refer to section 8.4.1 *USB Controller Commands in Host Mode* for information on the USB controller commands. # 8.3 USB Registers # 8.3.1 Register Access Timing There is a short delay between writing to a mode register and its effect on the hardware. Consequently, a **NOP** (no operation) instruction must be inserted between a write operation and a succeeding read operation to the same or affected register in order to read the updated value. This needs to be considered, for example, when accessing the EP Table. # 8.3.2 USB Mode Registers The USB interface is served by a set of dedicated mode registers. Table 8-1 below introduces these registers and summarizes their functions. For more detailed information on the USB registers, please refer to chapter 18.16 *Universal Serial Bus Interface Control Registers*. | Register | Function | |------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_USB_COMMAND | A byte-wide, read/write register that controls the USB commands in Host mode. Its functions include port selection, host and device configuration/deconfiguration, reset, run and stop commands. | | R_USB_COMMAND_DEV | A byte-wide, read/write register that controls the USB commands in Device mode. The commands are similar to those used in Host mode. | | R_USB_STATUS | A byte-wide, read-only register containing controller status information. The fields show whether the controller is busy, a Host or Device mode indicator, and whether Host mode is started and running. | | R_USB_IRQ_MASK_SET | A 16-bit wide, write-only register in which ten control bits are used to enable or mask separate USB interrupts in Host mode. They are: isochronous end of frame (iso_eof); interrupt end of frame (intr_eof); isochronous end of transfer (iso_eot); interrupt end of transfer (intr_eot); control end of transfer (ctl_eot); bulk end of transfer (bulk_eot); endpoint attention (epid_attn); start of frame (sof); port status (port_status); controller status (ctl_status). | | R_USB_IRQ_MASK_SET_DEV | A 16-bit wide, write-only register in which nine control bits are used to enable or mask separate USB interrupts in Device mode. They are: end of transfer/transaction for OUT (out_eot); endpoint3 end of transfer (ep3_in_eot); endpoint2 end of transfer (ep2_in_eot); endpoint1 end of transfer (ep1_in_eot); endpoint0 end of transfer (ep0_in_eot); endpoint attention (epid_attn); start of frame (sof); port status (port_status); controller status (ctl_status). | Table 8-1 USB Mode registers | R_USB_IRQ_MASK_READ | A 16-bit wide, read-only register that shows the status of the USB interrupts after individual bit masking in Host mode. Its contents are controlled by R_USB_IRQ_MASK_SET and R_USB_IRQ_MASK_CLR. | |-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_USB_IRQ_MASK_READ_DEV | A 16-bit wide, read-only register that shows the status of the USB interrupts after individual bit masking in Device mode. Its contents are controlled by R_USB_IRQ_MASK_SET_DEV and R_USB_IRQ_MASK_CLR_DEV. | | R_USB_IRQ_MASK_CLR | A 16-bit wide, write-only register with ten control bits that are used to clear the USB interrupt mask bits in Host mode. | | R_USB_IRQ_MASK_CLR_DEV | A 16-bit wide, write-only register with nine control bits that are used to clear the USB interrupt mask bits in Device mode. | | R_USB_IRQ_READ | A 16-bit wide, read-only register containing ten pending USB interrupt bits. It shows the status of the USB interrupts prior to individual bit masking in Host mode. | | R_USB_IRQ_READ_DEV | A 16-bit wide, read-only register containing nine pending USB interrupt bits. It shows the status of the USB interrupts prior to individual bit masking in Device mode. | | R_USB_FM_NUMBER | A 32-bit wide, read/write register that reads the number of the current USB frame in Host mode. The register is cleared when the USB controller is reset. Reading this register clears the <b>sof</b> interrupt condition. | | R_USB_FM_NUMBER_DEV | A 32-bit wide read/write register that contains the current frame number and Host/Device frame synchronization information in USB Device mode. The lower 11 bits represent the number of the current frame. The 8 msb bits read the time difference between the Host start-of-frame and the Device frame timer. The register is cleared when the USB controller is reset. Reading this register clears the <b>sof</b> interrupt condition. | | R_USB_FM_INTERVAL | A 16-bit wide, read/write register containing a 14 bit value that defines the bit time interval in a frame (the distance between two start-of-frames). The frame timer decrements from this value to zero. The value is reloaded into register R_USB_FM_REMAINING at each start-of-frame (SOF). The value in this register is the frame length minus 1. | | R_USB_FM_REMAINING | A 16-bit wide, read-only register that holds the remaining number of bit times in the current frame. The lower 14 bits represent this value: the two msb are not used. | | R_USB_FM_PSTART | A 16-bit wide, read/write register that holds the periodic start point. The lower 14 bits represent this value: the two msb are not used. The value of the periodic start point is compared with a value counted downwards. | | R_USB_RH_STATUS | A byte-wide, read-only register that contains root hub status information about the USB ports. Two 2-bit fields hold the bus states of ports p1 and p2 as sampled at the EOF2 time in the frame. A third 2-bit field represents the general condition of the USB interface. | | R_USB_RH_PORT_STATUS_1 | A 16-bit wide, read-only register containing status information about USB port p1. It is compatible with the wPortStatus field of the get_status command to USB hubs. The parameters that are read are speed, reset, suspended, enabled and connected. Two fields are not implemented in hardware and must therefore be handled in software. They are over_current (bit 3) and port_power (bit 8). When this register and R_USB_RH_PORT_STATUS_2 are | | | read, the root hub status change interrupt condition is cleared. The register must be read as an entire word (16-bits). | | R_USB_RH_PORT_STATUS_2 | A 16-bit wide, read-only register containing the same information as R_USB_RH_PORT_STATUS_1, but for USB port p2. | Table 8-1 USB Mode registers | R_USB_EPT_INDEX | A byte wide, read/write register in which the five lsb contain the index of the endpoint lookup table to be used when reading and writing via register R_USB_EPT_DATA. The endpoint lookup table contains 32 endpoint entries, each pointing at an endpoint on a USB device. The table is indexed by the endpoint ID (ep_id) number in the USB DMA descriptors. | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_USB_EPT_DATA | A 32-bit wide, read/write register. It is the general endpoint table data register for normal (non-isochronous) transfers in Host mode. Bit 18 of the register is unused (reserved). The other fields contain: valid - validity of the table entry; hold - software exclusion bit; error_count_in - error counter for incoming transactions; t_in - toggle bit for incoming transactions; low_speed - endpoint low speed marker: port - indicates the upstream device traffic port; error_code - error type indicator; t_out - toggle bit for outgoing transactions; error_count_out - error counter for outgoing transactions; max_len - maximum length of non-isochronous data packets; ep - endpoint number; dev - configured device address. | | R_USB_EPT_DATA_ISO | A 32-bit wide, read/write register. It is the general endpoint table data register for isochronous transfers in Host mode. The register is similar to $R\_USB\_EPT\_DATA$ . | | R_USB_EPT_DATA_DEV | A 32-bit wide, read/write register. It is the general endpoint table for Device mode transfers. The register is similar to R_USB_EPT_DATA. | | R_USB_EPID_ATTN | A 32-bit wide, read-only register. It contains a value representing an EP table entry that merits software attention. Reading this register clears the <b>epid_attn</b> interrupt condition. | | R_USB_PORT1_DISABLE | A byte-wide register in which one bit is used to disable USB port p1. | | R_USB_PORT2_DISABLE | A byte-wide register in which one bit is used to disable USB port p2. | Table 8-1 USB Mode registers # 8.4 USB Host mode In Host mode the USB interface manages frame timing, transaction protocol, port management and error recovery. The four transfer types stipulated in the USB specification are supported, namely: control (CTRL), bulk (BULK), interrupt (INTR) and isochronous (ISO). Either or both of the USB ports can be used. Selection of the port(s) to be used is made by asserting fields usb1 (bit 29) and usb2 (bit 30) in general configuration register R\_GEN\_CONFIG. The act of port selection also enables the USB interface. Prior to port selection, the interface and its registers are entirely inoperative. The root hub controls the reset, disable, suspend, resume, receive and transmit activities of the USB ports, even if only one port is configured for use. It is commanded by the port\_sel (bits 7 and 6) and port\_cmd (bits 5 and 4) fields in register R\_USB\_COMMAND. The state of the ports is read in registers R\_USB\_RH\_PORT\_STATUS\_1 and R\_USB\_RH\_PORT\_STATUS\_2. The status of the root hub is read in register R\_USB\_RH\_STATUS. #### 8.4.1 USB Controller Commands in Host Mode Register R\_USB\_COMMAND is used to control the USB interface in Host mode. This register contains fields for commanding the root hub and the USB controller. All these fields must be written in one operation. Each time a write operation to register R\_USB\_COMMAND is performed, a command interpretation is triggered. This sets the **busy** field (bit 7) in register R\_USB\_STATUS. When the USB controller has executed the command, the **busy** field is cleared. The current state of the USB interface is read in register R\_USB\_STATUS. The commands to the USB controller in Host mode are: #### **nop** - (no operation) One or both ports can be commanded without issuing any commands to the USB controller. The **nop** command is issued by setting field **ctrl\_cmd** (bits 2 to 0) in register R\_USB\_COMMAND to the value 0x0. #### reset When the status of the USB controller is HOST\_STARTED or HOST\_RUNNING, this command resets the USB controller. It overrides any port commands by disabling either or both configured ports. The state of the USB controller changes to HOST\_MODE, which is functionally equivalent to executing the **deconfig** and **host\_config** commands in succession. The **reset** command is issued by setting the **ctrl\_cmd** field in R\_USB\_COMMAND to the value 0x1. #### deconfig This is an emergency stop command that immediately deconfigures the entire USB interface, returning it to the condition that immediately succeeds a reset. The state of the USB controller changes to UNCONFIGURED. The **deconfig** command is issued by setting the **ctrl\_cmd** field in register R\_USB\_COMMAND to the value 0x2. ### host\_config With the USB controller in the UNCONFIGURED state, this command configures it as a host controller. Any command to a port is overridden by a configuration request to the port to adopt Host mode. The state of the USB controller changes to HOST\_MODE and, as soon as a port is reset and enabled, the status changes to HOST\_STARTED. The host\_config command is issued by setting the ctrl\_cmd field in register R\_USB\_COMMAND to the value 0x3. # dev\_config Please refer to section 8.5 *USB Data Structures in Host Mode*, Device mode. The **dev\_config** command is issued by setting the **ctrl\_cmd** field in register R\_USB\_COMMAND to the value 0x4. #### host\_nop The host\_nop (no operation) command is issued by setting the ctrl\_cmd field in R\_USB\_COMMAND to the value 0x5. #### host\_run When the host is started, this command starts the processing of USB traffic, and the status of the controller changes to HOST\_RUNNING. It is not necessary to set up the various data structures for USB traffic before issuing the **host\_run** command, but no traffic processing will occur until this has been done. The **host\_run** command is issued by setting the **ctrl\_cmd** field in register R USB COMMAND to the value 0x6. #### host\_stop If the controller status is HOST\_RUNNING, this command stops all traffic processing and changes the status of the controller to HOST\_STARTED. The **host\_stop** command is issued by setting the **ctrl\_cmd** field in register R USB COMMAND to the value 0x7. Most commands to the USB controller are effective in certain states only. The table below summarizes the relationship between the commands and the state of the USB controller. | | ctrl_cmd | | | | | | | | | | |--------------|----------|-------|----------|-----------------|------------|--------------|--------------|-----------|--|--| | Status | nop | reset | deconfig | host_confi<br>g | dev_config | host_no<br>p | host_ru<br>n | host_stop | | | | UNCONFIGURED | nop | nop | OVR | OVR | OVR | nop | nop | nop | | | | HOST_MODE | nop | nop | OVR | nop | nop | nop | nop | nop | | | | HOST_STARTED | nop | OVR | OVR | nop | nop | nop | OK | nop | | | | HOST_RUNNING | nop | OVR | OVR | nop | nop | nop | nop | OK | | | #### In the table above: **OVR** indicates that the **ctrl\_cmd** field in register R\_USB\_COMMAND overrides the **port sel** and **port cmd** fields. **OK** and **nop** indicate that the **port** sel and **port** cmd commands are executed. **Note 1:** If the USB controller is in the UNCONFIGURED state, then the **port\_cmd** command cannot be executed. If a command is written to register R\_USB\_COMMAND while the **busy** bit (3) in register R\_USB\_COMMAND is set, the result is unpredictable. ## 8.4.2 USB Port (Root Hub) Commands in Host Mode The root hub operates in conjunction with the USB controller. Commands to the root hub are given in the **port\_cmd** field of register R\_USB\_COMMAND. Any combination of the **ctrl\_cmd** and **port\_cmd** values can be used, but some are inappropriate. For instance do not command the USB controller to assume the HOST\_RUNNING state whilst simultaneously disabling both of the USB ports. Instead, set the **ctrl\_cmd** field of register R\_USB\_COMMAND to 0 (**nop**), and then use the **port\_sel** and **port\_cmd** fields to command the root hub. The commands to the USB ports in Host mode are issued to the port(s) selected in the **port\_sel** field (bits 7 to 6) in register R\_USB\_COMMAND as follows: #### reset The selected port is reset and enabled. A full port initialization of the port is performed and a bus reset is signalled according to the USB protocol. This occupies approximately 3 ms, depending upon the point in the frame cycle at which the command is issued. The reset command is issued by setting the **port\_cmd** field in register R\_USB\_COMMAND to the value 0x0. #### disable The selected port is disabled. The **disable** command is issued by setting the **port\_cmd** field in register R\_USB\_COMMAND to the value 0x1. #### suspend The selected port is placed in a suspended state. The port will not forward outbound traffic but will detect remote wakeup signalling or disconnects on the bus. The **suspend** command is issued by setting the **port\_cmd** field in register R USB COMMAND to the value 0x2. #### resume The selected port is forced to resume operation. It starts a resume signalling sequence on the USB, after which the forwarding of USB traffic commences. The **resume** command is issued by setting the **port\_cmd** field in register R\_USB\_COMMAND to the value 0x3. The root hub handles most of the signalling on the bus. Functions such as connect/disconnect detection, reset signalling, suspend/resume and speed detection are automatic and accord with the USB specification. Some device attachment and configuration timeouts must be handled in software. # 8.5 USB Data Structures in Host Mode ### 8.5.1 Transfer Frames A USB transfer frame has the basic structure shown below: Figure 8-4 Basic Structure of USB Transfer Frame in Host Mode The significant points in the transfer frame are the start-of-frame (SOF), periodic start (PSTART) and end-of-frame (EOF) events. #### Start of Frame The SOF point signifies the start of a transfer frame. The period from the beginning of one SOF to the next is the bit time interval of the frame. This is loaded into the **value** field (bits 13:0) of register R\_USB\_FM\_REMAINING at the start of each frame. The frame timer decrements from the bit time interval to zero, at which point the next SOF occurs. The bit time interval is a 14-bit value contained in the **fixed** and **adj** (adjustable) fields of register R\_USB\_FM\_INTERVAL. The default value is 0x2EDF. The **fixed** field (bits 13:6) contains the upper 8-bits of the frame interval and, as the field name suggests, they are read-only. The adj field (bits 5:0) contains the lower 6-bits of the frame interval. These bits can be used to adjust the bit time interval if necessary. Revision 1.1 of the USB specification requires that the interval must not deviate from the nominal (12000 bit times), by more than 15 bit times. Moreover the software must not adjust the frame interval by more than one bit time over six frames, and only one bit time is permitted in each adjustment. **Note 2:** The value in register R\_USB\_FM\_INTERVAL is actually the frame length minus 1. #### **Periodic Start Point** PSTART is where the transfer of interrupt and isochronous traffic can commence. Prior to the PSTART mark, only control transfers are performed. The position of PSTART is set by the 14-bits of the **value** field (13:0) in register R\_USB\_FM\_PSTART. To determine when to start sending periodic traffic, the USB controller compares R\_USB\_FM\_PSTART with R\_USB\_FM\_REMAINING, which is counted downwards. The USB driver should set R\_USB\_FM\_PSTART to 0x2A30 (Periodic traffic starts 10% after sof). More control traffic is permitted when all interrupt and isochronous transactions in the current frame are finished. When all remaining control traffic is finished, then bulk traffic transactions are performed. #### **End of Frame** At the EOF point, all traffic for the current frame is stopped and the entire procedure is repeated in the next frame. The register R\_USB\_FM\_REMAINING shows the number of bit times remaining in the current frame. Register R\_USB\_FM\_NUMBER gives the 32-bit frame number of the current frame. **Note 3:** A 32-bit frame number is used in Host mode only. The lower 11 bits of register R\_USB\_FM\_NUMBER are sent at the SOF. #### **Transfers and Toggle Bits** The USB interface does not set or clear the toggle bits at the end of a transfer. In fact the toggle bits are initialized only during the setup transaction in a CTRL transfer. This feature can be used to concatenate multiple short transfers (as presented to the USB interface), into one long transfer (as seen by the device). It also means that the software may have to preset the toggle bits between transfers. This affects the insertion of transfers in the SB descriptor lists. ### **Maximum Transfer Length** Revision 1.1 of the USB specification does not specify a maximum transfer length. The USB interface is designed to construct longer transfers by concatenation. Please refer to Universal Serial Bus Revision 1.1 specification for more detailed information about toggle bits, transfers and transfer length. # 8.5.2 DMA Descriptors The DMA generates the traffic for the USB interface, using linked lists of descriptors to track the USB traffic data and schedules. For further information regarding DMA refer to chapter 7 *DMA*. DMA channel 8 is used for the traffic schedule and outgoing traffic data. DMA channel 9 is used for incoming traffic data. All incoming traffic terminates in the same buffer list in DMA channel 9. Each traffic type has its own data structure, and the DMA divides channel 8 into four sub-channels (8.0 to 8.3), one for each traffic type, each of which is a linked list of linked lists. Sub-channel 8.0 is used for bulk traffic, sub-channel 8.1 for control traffic, sub-channel 8.2 for interrupts and sub-channel 8.3 for isochronous traffic. Figure 8-5 DMA List Structure for USB In the upper dimension, the endpoint (EP) descriptors are aligned. From each EP descriptor, a number of sublist (SB) descriptors descend to form a transfer list for that endpoint. The EP list has exactly one descriptor with the **eol** (end-of-list) flag set. An EP descriptor can be enabled only by software, but the hardware and the software can both disable an endpoint. When the hardware disables an EP descriptor, the software is notified by means of the **epid\_attn** interrupt (See section 8.5.4 *Host Mode Interrupts*). The SB descriptors describe the transfer to be performed. There are four types of transfer: **ZOUT** - a special transfer used by the control, interrupt and isochronous traffic types, but not for bulk traffic. **SETUP** - this transfer type is used for control transfers only. **IN** and **OUT** - these transfer types are used in all four types of traffic. The SB descriptor for the OUT transfer has an associated buffer for the outgoing data, whereas the IN transfer data is received by DMA channel 9. ### **DMA Descriptors for IN Transfers** The format of a DMA descriptor for an IN transfer, used by DMA channel 9, is shown below. It is recommended that all DMA descriptors for USB are 32-bit aligned due to performance. Figure 8-6 Format of DMA Descriptor For a detailed description of the DMA descriptor refer to chapter 7.4.3 *DMA Descriptor Format for USB*. ### **Endpoint Descriptors** The format of an EP descriptor, used by DMA channel 8, is shown below. The **ep\_id** field reports the EP identifier with which this buffer is associated, and is used to demultiplex the input stream into the corresponding endpoint pipe streams. All EP descriptors must be 32-bit aligned. Figure 8-7 Format of an EP Descriptor For a detailed description of the EP descriptor refer to chapter 7.4.3 *DMA Descriptor Format for USB.* #### **Sublist Descriptors** The format of an SB descriptor, used by DMA channel 8, is shown below. Figure 8-8 Format of SB Descriptor In the special case where the transfer length is evenly divisible by the packet length, the **full** field is used to prevent the USB controller from sending an empty packet at the end of the transfer. The **rem** field is used by IN transfers to count the bytes in the last packet. If the last packet is expected to be full, then the **rem** field is set to zero. For a detailed description of the SB descriptor refer to chapter 7.4.3 *DMA Descriptor Format for USB*. ## **SB Descriptors for Bulk Traffic** The transfers in the sublists can be IN or OUT. Each transfer can be constructed from one or more SB descriptors, but the last descriptor in a transfer must have the eot flag set. All descriptors in a single transfer must be of the same transfer type with the last descriptor in a sublist having the eol flag set. In the examples that follow, the maximum packet size is set in the EP table (See section 8.5.3 *Endpoint Table in Host Mode*). Transfer size 544 Max. packet size 32 Figure 8-9 Example 1 of an OUT Transfer Transfer size 160 Max. packet size 64 Figure 8-10 Example 2 of an OUT transfer Transfer size 119 Max. packet size 8 Figure 8-11 Example of an IN transfer The calculations are: sw\_len = size ? (size - 1) / max packet size + 1 : 0; rem = size % max packet size; **Note 4:** For IN transfers, the **sw\_len** field counts in packets. ## SB Descriptors for Control (CTRL) Traffic The format of a control transfer is more complicated than that of other traffic types. The USB specification requires that a control transfer must have either two or three phases: *setup*, *data* (optional), and *status* - and each phase uses one SB descriptor. For example, to build a control write it is necessary to have three SB descriptors: one SETUP, one OUT and one IN. Figure 8-12 Example of a Control Read Transfer **Note 5:** According to the Universal Serial Bus Revision 1.1 specification, the setup transaction must be exactly 8 bytes long. The ZOUT descriptor buffer pointer should be set to NULL. Figure 8-13 Example of a Control Write Transfer **Note 6:** The sw\_len field in the last descriptor has to be exactly 1. This is due to a requirement of the USB specification that a host must be prepared to receive data (from a bogus device) in the status phase. Figure 8-14 Example of a No-data Control Transfer ### EP and SB Descriptors for Interrupt (INTR) Traffic The EP descriptors for INTR traffic represent IN or OUT interrupt pipes. The technique is to run one transfer per endpoint and then change. If the endpoint has its eof flag set, then this signifies a *dummy* endpoint. Dummy endpoints are used to control the frequency of interrupt transfers: they must have only one SB descriptor attached, and that must be a ZOUT transfer. ZOUT transfers are special. The ZOUT SB descriptor for periodic traffic (INTR and ISO) is not consumed and the DMA is instructed to move to the next endpoint. If the **eof** flag of the EP descriptor is not set, then an empty packet is sent. If the EP descriptor has its **eof** flag set, then the ZOUT transfer does nothing except force the hardware to stop processing interrupt traffic for that frame. OUT transfers of INTR traffic resemble those of BULK traffic. One transfer, or an attempt to transfer, is performed in every frame (or desired period). OUT transfers of INTR traffic with different interrupt periods are complex to support. In the first example below, the host will deliver 40 bytes in the first frame, after which it will send an empty packet in each frame. Note that if a device replies with NAK, or makes no reply, the host will attempt to re-send the packet in the next period (the next frame in this example). Figure 8-15 Example of Endpoint 1 (OUT) in Each Frame of INTR Traffic In the next example below, the host will deliver 30 bytes in the first frame, then wait five frames and deliver 20 bytes. After this an empty packet will be transmitted every fifth frame. Note that if a device replies with NAK, or makes no reply, the host will attempt to re-send the packet in the next period (after five frames in this example). Figure 8-16 Example of Endpoint 1 (OUT) Every Fifth Frame of INTR Traffic IN transfers of periodic traffic (INTR and ISO) are different from those of bulk and CTRL traffic. When the IN transfer is finished the SB descriptor is not consumed, which makes the IN transfer remain in the list. The first example below shows IN endpoint EP1 in each frame and IN endpoint EP2 in every second frame. Figure 8-17 Example of Endpoint 1 (IN) Every Frame and Endpoint 2 (IN) Every 2nd Frame of INTR Traffic The final example shows IN endpoint EP1 in every fifth frame. Figure 8-18 Example of Endpoint 1 (IN) Every Fifth Frame of INTR Traffic ### EP and SB Descriptors for Isochronous (ISO) Traffic Isochronous transfers are uni-directional, and the EP descriptors represent isochronous pipes. An EP descriptor with the eof flag set is a dummy endpoint used to mark the end of isochronous traffic. This eof endpoint must contain one SB descriptor with a ZOUT transfer. For OUT transfers, only one transaction per endpoint is transmitted in each frame. If the SB list ends, then the endpoint is disabled. No re-transmissions are used. In the event of an underrun error, the USB controller forces the DMA to skip the transaction in which the underrun occurs. To make this behavior useful, it is recommended that there should be only one transaction per transfer (e.g. the data size should not be longer than the max packet size). Figure 8-19 Example of ISO OUT traffic For IN transfers, one request per endpoint is transmitted in each frame. As with interrupt traffic, the IN transfers never end. The **iso\_eot** interrupt is given for all ISO IN requests. ### 8.5.3 Endpoint Table in Host Mode The USB interface can handle 31 active endpoints in devices on the bus. The interface therefore includes a lookup (EP) table for translating endpoint identifiers into device/endpoint pairs. The EP table also contains status information for each valid **ep\_id**. Most of this information is used by the hardware only, but some fields are used to exchange information between the hardware and the software. The EP table contains 32 endpoint entries, each pointing at an endpoint on a device on the USB. The EP table for isochronous traffic differs slightly from that of all other traffic types: it requires fewer fields. The EP table is accessed via three mode registers: R USB EPT INDEX is used to point to the desired entry in the EP table. R\_USB\_EPT\_DATA is used to read and write to the indexed entry in the EP table for all traffic types except isochronous. R\_USB\_EPT\_DATA\_ISO is used to read and write to the indexed entry in the EP table for isochronous traffic. After reset, all entries in the EP table are invalidated, which means that the **valid** field (bit 31), of each entry in register R\_USB\_EPT\_DATA is cleared. If no periodic transfer is ever scheduled, then all 32 entries in the EP table can be used. However, if interrupt or isochronous traffic are to be used, then one entry must be invalid, leaving 31 entries available. **Note 7:** In software, the best way to create an invalid entry is to allocate one entry in the table; do not adjust it thereafter. The software must never modify an entry in the EP table as long as the corresponding EP descriptor is enabled. If an entry is modified while the EP descriptor is enabled, the behavior is undefined and unpredictable. To avoid such errors a synchronization method must be used. Please refer to section 8.7 *Physical Interface* for details. For a full definition of the fields in the EP table for all traffic types except isochronous, please refer to chapter 18.16.7 *R\_USB\_IRQ\_MASK\_CLR*. For a full definition of the fields in the EP table for isochronous traffic, please refer to chapter 18.16.18 *R\_USB\_RH\_STATUS*. # 8.5.4 Host Mode Interrupts A number of interrupts are generated by the USB interface: most of them indicate events in specific devices on the USB. All of the USB interrupts have the same internally-generated vector number (0x3F). As noted in table 8-1 above, the USB interrupts are handled in four registers: R\_USB\_IRQ\_MASK\_SET; R\_USB\_IRQ\_MASK\_READ; R\_USB\_IRQ\_MASK\_CLR; R\_USB\_IRQ\_READ. It is also necessary for the USB interface to identify any endpoint that triggers an interrupt. Register R\_EPID\_ATTN is used for this purpose. Each bit in the register corresponds to an entry in the endpoint lookup table. In summary the USB interrupts are: #### iso eof This interrupt is triggered in response to an isochronous traffic end-of-frame flag. In Host mode the <code>iso\_eof</code> interrupt occurs when the DMA reports a set <code>eof</code> flag in an isochronous EP descriptor to the USB interface. The interrupt is cleared when the <code>value</code> field in register R\_USB\_EPID\_ATTN is read. #### intr\_eof This interrupt is triggered in response to an interrupt traffic end-of-frame flag. In Host mode the **intr\_eof** interrupt occurs when the DMA reports a set **eof** flag in an interrupt EP descriptor to the USB interface. The interrupt is cleared when the **value** field in register R\_USB\_EPID\_ATTN is read. #### iso\_eot In Host mode, this interrupt is triggered when an isochronous transaction is completed. The interrupt is cleared when the **value** field in register R USB EPID ATTN is read. #### intr\_eot In Host mode, this interrupt is triggered in response to an end-of-transfer flag when an interrupt transfer is completed. The interrupt is cleared when the **value** field in register R\_USB\_EPID\_ATTN is read. #### ctl eot In Host mode, this interrupt is triggered in response to an end-of-transfer flag when a control transfer is completed. The interrupt is cleared when the **value** field in register R\_USB\_EPID\_ATTN is read. #### bulk eot In Host mode, this interrupt is triggered in response to an end-of-transfer flag when a bulk transfer is completed. The interrupt is cleared when the **value** field in register R\_USB\_EPID\_ATTN is read. #### epid\_attn In Host mode, this interrupt is triggered whenever a significant event occurs at an endpoint. The interrupt condition is cleared when the R\_USB\_EPID\_ATTN register is read. The events that trigger an **epid\_attn** interrupt are: **invalid ep\_id** - occurs when the USB interface receives a transfer with an invalid endpoint identifier in the EP descriptor. It is probably caused by a programming error and is a good reason to stop the affected endpoint at least. The EP descriptor will be disabled by the hardware. stall - not strictly an error condition but the EP descriptor is disabled nevertheless. For CTRL transfers there are special precautions to be taken by the software. The hardware does not perform any special routine for CTRL stalls. They are handled in the same way as BULK or INTR stalls. **3rd error** - occurs in response to three successive transaction error in a transfer, which disables the EP descriptor. Another severe error in a transaction may also trigger this event. Inspect the EP table. **buffer ourun** - a buffer overrun or underrun occurs if the memory or DMA cannot handle the traffic load. The EP descriptor is disabled. past eof1- this event is triggered if an INTR or ISO transaction proceeds beyond the EOF1 mark in the frame. **near eof** - this relatively rare event is triggered if an attempt is made to start an INTR or ISO transaction that would not fit inside the frame. It is handled in the same way as the **past eof1** event. **zout transfer** - this error event is triggered if a ZOUT transfer is ever presented to any BULK endpoint. The EP descriptor is disabled. **setup transfer** - this error event is triggered if a SETUP transfer is ever presented to any INTR, ISO or BULK endpoint. The EP descriptor is disabled. #### sof In Host mode, this interrupt is triggered whenever a start-of-frame flag leaves the USB interface. The interrupt is cleared when the **value** field in register R\_USB\_FM\_NUMBER is read. #### port\_status In Host mode, this interrupt signals any change in the status registers of the configured USB ports. The interrupt is cleared when these registers (R\_USB\_RH\_PORT\_STATUS\_1 and R\_USB\_RH\_PORT\_STATUS\_2) are read. #### ctl status In Host mode, this interrupt indicates a change in the status of the USB interface controller. The interrupt is cleared when register R\_USB\_STATUS is read. ### 8.6 Device Mode In Device mode, only one port can be configured for use, either port p1 or port p2. Selection of the port to be used is made by asserting fields usb1 (bit 29) or usb2 (bit 30) in general configuration register R\_GEN\_CONFIG. The act of port selection enables the USB interface, which is entirely inoperative prior to this. All operations at the enabled port are handled by the root hub under the control of the **port\_sel** (bits 7 and 6) and **port\_cmd** (bits 5 and 4) fields in register R\_USB\_COMMAND\_DEV. The status of the enabled port is read in register R\_USB\_RH\_PORT\_STATUS\_1 if port p1 is in use, or R\_USB\_RH\_PORT\_STATUS\_2 for port p2. Root hub status register R\_USB\_RH\_STATUS is not used in Device mode. #### 8.6.1 USB Controller Commands in Device Mode Register R\_USB\_COMMAND\_DEV contains fields for commanding the root hub and the USB controller. All these fields must be written in one operation. Each time a write operation is performed to register R\_USB\_COMMAND\_DEV, a command interpretation is triggered. This sets the busy field (bit 7) in register R\_USB\_STATUS. When the USB controller has executed the command, the busy field is cleared. The current state of the USB interface is read in main status register R\_USB\_STATUS. The only commands that can be issued to the USB controller in Device mode are: #### **nop** - (no operation) The enabled port can be commanded without issuing any commands to the USB controller. The **nop** command is issued by setting field **ctrl\_cmd** (bits 2 to 0) in register R\_USB\_COMMAND\_DEV to the value 0x0. #### deconfig This is an emergency stop command that immediately deconfigures the entire USB interface, returning it to the condition that immediately succeeds a reset. The state of the USB controller changes to UNCONFIGURED. The **deconfig** command is issued by setting the **ctrl\_cmd** field in R\_USB\_COMMAND\_DEV to the value 0x2. #### host\_config If the USB controller is in the UNCONFIGURED state, this command configures it as a host controller. The **host\_config** command is issued by setting the **ctrl\_cmd** field in register R\_USB\_COMMAND\_DEV to the value 0x3. #### dev config If the USB controller is in the UNCONFIGURED state, this command configures it as a device controller. The **dev\_config** command is issued by setting the **ctrl cmd** field in register R USB COMMAND DEV to the value 0x4. # 8.6.2 USB Port (Root Hub) Commands in Device Mode In Device mode, commands to the root hub are given in the **port\_cmd** field of register R\_USB\_COMMAND\_DEV. They are issued to the port selected in the **port\_sel** field (bits 7 to 6) of the command register as follows: #### active Enable the selected port. This must be done after the **dev\_config** command has been issued to the USB controller. The **active** command is issued by setting the **port\_cmd** field in register R\_USB\_COMMAND\_DEV to the value 0x0. #### passive Disable the selected port. Traffic on the bus is ignored and none is sent from the device. The **passive** command is issued by setting the **port\_cmd** field in register R\_USB\_COMMAND\_DEV to the value 0x1. #### wakeup Drive a K-state of 3 ms in length on the bus to request remote wakeup. This command is valid only if the device is in a suspended mode. The **wakeup** command is issued by setting the **port\_cmd** field in R\_USB\_COMMAND\_DEV to the value 0x3. ### 8.6.3 USB Data Structures in Device Mode In Device mode, the USB controller can handle four IN endpoints and 12 OUT endpoints. Note that the terms IN and OUT refer to the direction at the USB host; in other words, an IN Transfer is outgoing from the device, and an OUT transfer is incoming to the device. DMA channel 8 is used for outgoing traffic from the USB device to the host and is divided into four sub-channels, one for each IN endpoint. The data structures for the sub-channels of DMA channel 8 are organized as four linked lists of linked lists, where the first list (the EP list), always points to itself. DMA sub-channel 8.0 is used as a control endpoint, while sub-channels 8.1 to 8.3 can be used for any traffic type. Figure 8-20 DMA List Structure for USB Device (IN Endpoint) ETRAX 100LX supports 12 endpoints for incoming traffic from the USB host (OUT traffic). DMA channel 9 handles this traffic, all of which is placed in the FIFO buffer of DMA channel 9. This channel behaves in the same way as any other DMA channel in ETRAX 100LX, but with additional status flags. ### **DMA Descriptors for OUT Transfers in Device Mode** The format of a DMA descriptor for an OUT transfer (incoming traffic to the device) is shown below. This format is used by DMA channel 9, and it is recommended that all DMA descriptors for USB are 32-bit aligned. Figure 8-21 Format of DMA Descriptor For a detailed description of the DMA descriptor refer to chapter 7.4.3 *DMA Descriptor Format for USB*. #### **EP Descriptors in Device Mode** Endpoint descriptors are mainly used to store the **ep\_id** number but, in USB Device mode, the **ep\_id** number is fixed as follows: | Sub-Channel | ep_id | |-------------|-------| | 8.0 | 0 | | 8.1 | 1 | | 8.2 | 2 | | 8.3 | 3 | The format of an EP descriptor, used by DMA channel 8, is shown below. There is only one EP descriptor per sub-channel. All EP descriptors must be 32-bit aligned. Figure 8-22 Format of an EP Descriptor Note that the **eof** bit is not used in Device mode, and should be set to 0. For a detailed description of the EP descriptor refer to chapter 7.4.3 *DMA Descriptor Format for USB*. ### **SB Descriptors in Device Mode** In Device mode, the SB descriptors for the sub-channels in DMA channel 8 contain status and pointer fields to the data that will be transmitted from the device to the USB host. The format of an SP descriptor in a sub-channel is illustrated below. Figure 8-23 Format of SB Descriptor in Device Mode Note that the **rem** field is not used in Device mode, and should be set to 0. In Device mode, the only transfer types allowed in the **tt** field are ZOUT and OUT. For a detailed description of the SB descriptor refer to chapter 7.4.3 *DMA Descriptor Format for USB*. #### 8.6.4 EP Table in Device Mode The EP table is used in Device mode as well as Host mode, and is accessed through mode registers: - R\_USB\_EPT\_INDEX which is used to point to the desired entry in the EP table. - R\_USB\_EPT\_DATA\_DEV which is used to read and write to the indexed entry in the EP table. The EP table also contains status information for each valid **ep\_id**. 8-2 below shows how the rows in the EP table are used: To fill rows 0 - 11 and 16 - 19, the register macros for R\_USB\_EPT\_DATA\_DEV could be used. The data toggle bit for an endpoint is only initialized during a setup transaction. | ep_id | Description | |---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 - 11 | Configuration for USB out traffic - incoming traffic to the device. All data received will end up in DMA channel 9, and there are 12 endpoints available. ep_ids 20 - 31 are used to know the transfer size of USB out traffic: ep_id 20 is used by ep_id 0 ep_id 21 is used by ep_id 1 ep_id 22 is used by ep_id 2 ep_id 23 is used by ep_id 3 ep_id 24 is used by ep_id 4 ep_id 25 is used by ep_id 5 ep_id 26 is used by ep_id 6 ep_id 27 is used by ep_id 7 ep_id 28 is used by ep_id 8 ep_id 29 is used by ep_id 9 ep_id 30 is used by ep_id 10 ep_id 31 is used by ep_id 11 | | 12 - 15 | Reserved | | 16 - 19 | Configuration for USB in traffic - outgoing traffic from the device. There are four endpoints are available, one for each DMA channel 8 subchannel. | | 20 - 31 | Counters for ep_ids 0 - 11. Bit [31:16] is the transfer size Bit [15:0] is the number of bytes remaining in the ongoing transfer. Note that for a control endpoint, the counter is loaded by hardware with the transfer size received within the setup packet. | Table 8-2 EP table usage For a full definition of the fields of the EP table in Device mode, please refer to chapter 18.16.19 *R\_USB\_RH\_PORT\_STATUS\_1*. # 8.6.5 Device Mode Interrupts The USB interrupts in Device mode are: #### out\_eot This interrupt is triggered by an end-of-transfer flag on any of the twelve OUT endpoints. #### ep3\_in\_eot, ep2\_in\_eot, ep1\_in\_eot These interrupts are triggered by an end-of-transfer flag on IN endpoints numbered 1 to 3 respectively. #### ep0\_in\_eot This interrupt is triggered by an end-of-transfer flag on IN endpoint number 0 (control). #### epid\_attn In Device mode, this interrupt is triggered in response to an endpoint overrun or underrun condition. The interrupting endpoint is identified in register R\_USB\_EPID\_ATTN and the error condition can be read in register R\_USB\_STATUS. #### sof In Device mode, this interrupt is triggered each time the frame timer reaches 0. The frame timer interval is set in R\_USB\_FM\_INTERVAL, and can be synchronized with the frame interval of the host by using the information in R\_USB\_FM\_NUMBER\_DEV. #### port\_status In Device mode, this interrupt signals any change in the status of the USB port. #### ctl\_status In Device mode, this interrupt indicates a change in configuration. # 8.7 Physical Interface The physical interface of the USB is divided into two main parts: data transmission and power management. These differ slightly in Host mode and Device mode. #### 8.7.1 Data Transmission The data transmission interface is compatible with Philips USB transceiver type PDIUSBP11A. It is almost identical for Host and Device mode, with minor differences in the protocol handling. There is also a difference on the outside of the transceiver, concerning the pull-up and pull-down for device speed indication. In host mode, D+ and D- are individually pulled down with 15K Ohm. In Device mode, a 1.5K Ohm resistor is used for device speed selection. If a full-speed device is built, the resistor should be a pull-up on the D+ line. For a low-speed device, the resistor should be a pull-up on the D- line. # 8.7.2 Power Management USB power management is not implemented in the ETRAX 100LX USB interface. Since power management is slow and rare, it can be implemented in software using general port PA for overcurrent sensing, and any generic I/O pin for power on/off control. The fact that general port PA can be configured to generate interrupts is a useful feature in this regard. ### 8.7.3 Hardware Reset Whenever the USB interface is not configured in register R\_GEN\_CONFIG, then the USB interface reset is active and the interface is entirely frozen. Writing to the USB registers has no effect, and reading from the registers may produce unpredictable results. Immediately after reset the USB interface is in a passive state. The USB ports are off, in the sense that their output enable signals are inactive. # **Note 8:** One way to perform a hardware reset of the USB interface is to deconfigure the interface in register R\_GEN\_CONFIG and then reconfigure the interface. It is the responsibility of the software to manage USB power during startup of the USB interface. This is done outside the USB interface as noted in 8.7.2. above. # 8.8 Procedures # 8.8.1 Configuring the USB Interface for Host Mode ### **Setting the General Configuration** Set the usb1 (bit 29) and/or usb2 (bit 30) fields in register R\_GEN\_CONFIG to configure either or both of the two available USB ports. This initializes the USB interface and causes a hardware reset of the USB interface to be performed. ### Configuring the Interface Set the **ctrl\_cmd** field (bits 2 to 0) in register R\_USB\_COMMAND to the value **host\_config** (0x3). This issues the **host\_config** command to the USB interface. # 8.8.2 Starting and Stopping the Host Mode When configured, the USB interface eventually reaches the HOST\_MODE state, where it remains until at least one port is enabled. When a port is enabled, the HOST\_STARTED state is attained and traffic processing can be started by issuing the **host\_run** command to the USB controller. This sets the USB interface to the HOST\_RUNNING state. ### Starting USB Traffic Processing Set the **ctrl\_cmd** field in register R\_USB\_COMMAND to the value **host\_run** (0x6). This issues the **host\_run** command to the USB controller. ### **Stopping USB Traffic Processing** Set the **ctrl\_cmd** field in register R\_USB\_COMMAND to the value **host\_stop** (0x7). This issues the **host\_stop** command to the USB controller. All traffic processing is suspended but frame generation continues. The traffic for the current frame is finished before the state changes to HOST\_STARTED. The traffic can be started again without any special actions as long as the data structures are intact. However it should be noted that the devices may have become unstable during the stoppage time. # 8.8.3 Starting and Stopping Traffic in Host Mode This is related to the start/stop of traffic processing. In principle, traffic can be forcibly stopped by commanding the USB controller from the HOST\_RUNNING state to the HOST\_STARTED state. However a clean shutdown may leave devices in a safer condition than a forced shutdown. #### **Stopping Each Traffic Type with a Clean Procedure** - 1 Withdraw any pending transfers. This may require the temporary disabling of the endpoint in order to inspect and manipulate the SB descriptor lists. - **2** Wait for the DMA sublist to stop. When the endpoints exhaust one by one, they are automatically disabled by the USB interface. When all endpoints are disabled, the DMA sub-channel will stop. **3** When all sub lists have stopped, issue the **host\_stop** command to the USB controller by setting the **ctrl\_cmd** field in register R\_USB\_COMMAND to the value **host\_stop** (0x7). ### **Restarting Traffic After a Stop** - 1 Set the **ctrl\_cmd** field in register R\_USB\_COMMAND to the value **host\_run** (0x6). This issues the **host\_run** command to the USB controller. - **2** Set up the new transfers to be processed. All traffic was withdrawn before the traffic was stopped and therefore all SB lists are empty. # 8.8.4 Managing EP Descriptor Lists in Host Mode All EP descriptor lists must have a disabled dummy EP descriptor with the **eol** flag set. To create a new EP descriptor list it is necessary to create the first descriptor, link the first descriptor to the dummy EP descriptor, and set the **eol** flag. This must be done before the DMA sub-channel is started. The list will resemble the following diagram: Figure 8-24 New EP Descriptor List in Host Mode #### Inserting an EP Descriptor into an Existing List 1 Create a new EP descriptor, here named new\_ep. It is recommended that all values in the new descriptor should be set to zero. Locate the point in the list where the new\_ep is to be inserted. The descriptor that precedes the insertion point is here named before\_ep and the descriptor that succeeds the insertion point is named after\_ep. Figure 8-25 Existing Descriptor List **2** Point the new endpoint at the **after\_ep** descriptor. This must be done before the next step. Figure 8-26 Pointing the New Endpoint at the Succeeding Descriptor **3** Point the **before\_ep** at the **new\_ep** descriptor. To ensure that the hardware does not detect a partially-updated new endpoint, this must be done in one single 32-bit write operation. Figure 8-27 Pointing the Preceding Descriptor at the New Endpoint ### Removing an EP Descriptor from the List - 1 Bypass the descriptor by changing **before\_ep**.next to **old\_ep**.next. This must be done in one single 32-bit write operation. - **2** Check that the value in R\_DMA\_CH8\_SUBx\_EP is not equal to **old\_ep**. - **3** If the values are not the same it is safe to remove the **old\_ep**. - **4** If these two values are equal, set the interrupt bit **intr** in the *dummy* descriptor and wait for the **dma8\_subx\_descr** interrupt. - **5** At the **dma8\_subx\_descr** interrupt, remove **old\_ep**, and clear the interrupt bit in the dummy descriptor. - **6** Acknowledge the interrupt by writing to R\_DMA\_CH8\_SUBx\_CLR\_INTR. Figure 8-28 Removing the EP Descriptor # 8.8.5 Managing SB Descriptor Lists in Host Mode It is possible to insert descriptors in the middle of an SB descriptor list, but advanced disable/enable EP descriptor manipulation with list traversal is necessary to find the intersections between transfers. New traffic must not be inserted in the middle of a transfer because it would confuse the USB hardware and produce unpredictable results. The preferred method of inserting descriptors is to append new traffic at the end of the list, as described below. It is recommended an entire transfer should be inserted in one operation because this simplifies other aspects of the operation. - **1** Find the last SB descriptor in the list. - **2** Append the new descriptor to the list. - **3** Clear the **eol** flag in the last descriptor. - **4** Check whether the EP descriptor at the head of the list is enabled or disabled. If it is enabled, then the procedure is concluded. Otherwise go to step 5. - **5** Check whether an error disabled the EP descriptor, taking care not to lose any information from the interrupt system. If there was an error condition, proceed with step 6. Otherwise go to step 7. - **6** Correct the error condition, which may necessitate a permanent stop of the endpoint. This must be handled in software, which must correctly withdraw all transfers in the SB descriptor list, including the newly-inserted transfer. When this has been done, restart the endpoint if possible. - **7** Check if the **sub** field in the EP descriptor is pointing to the new SB descriptor. If so, the procedure is completed; otherwise, go to step 8. - **8** Update the EP descriptor. There was no error and the EP descriptor was disabled, therefore the SB descriptor list was exhausted. The sub field in the EP descriptor must be pointed at the new SB descriptor. - **9** Enable the EP descriptor to conclude the procedure. When removing descriptors from the SB descriptor list it is very important not to confuse DMA, which could lead to unpredictable events in the USB interface. For more information, please refer to the above section 8.8.4 *Managing EP Descriptor Lists in Host Mode.* ## **Removing SB Descriptors from the List** - 1 Disable the endpoint, see 8.8.4 *Managing EP Descriptor Lists in Host Mode*. - **2** Find the start and stop of the transfer to retire. If the endpoint was disabled due to an error, the error must also be corrected. - **3** Remove the transfer to retire. - **4** If the list is not empty, re-enable the endpoint. ### 8.8.6 Managing the EP Table in Host Mode #### Connecting an EP Descriptor to an EP Table Entry - 1 Allocate an EP table entry. The entry number is the ep\_id. - 2 Write the ep\_id into the value field of register R\_USB\_EPT\_INDEX and set the ep\_id field in the EP descriptor. - **3** Clear the EP table entry in register R\_USB\_EPT\_DATA. - **4** Set the device and endpoint parameters in register R\_USB\_EPT\_DATA. - **5** Set the **valid** field (bit 31) in the EP table entry. - **6** Insert the EP descriptor into an EP list. - **7** Enable the EP descriptor. #### Disabling an Endpoint and Accessing the EP Table Entry Follow the procedure set forth in section 8.8.4 *Managing EP Descriptor Lists in Host Mode*. When the EP is safely disabled, the entry in the EP table could also be modified. ### Re-enabling the Endpoint - **1** Set the enable bit in the EP descriptor. - **2** Check that the DMA is still running. If it has stopped for some reason (e.g. no more data to process), then write a start command to the appropriate DMA command register. # 8.8.7 Managing the DMA Channel 9 Descriptor List This is largely the same as managing any DMA list for incoming traffic. A typical USB DMA descriptor list structure resembles Figure 8-29 below. Figure 8-29 Typical USB DMA Descriptor List After reception of a transfer (one packet), the **ep\_id** and the **eop** field are written to the DMA descriptor in DMA channel 9. If the transfer is an empty packet, a dummy byte is written and the **nodata** bit is set. Observe that a packet ends in the buffer that is flagged **eop**, and the next packet begins in the immediately succeeding buffer. The software must manage the demultiplexing of packets to the correct pipe, and the cleanup after an unrecoverable transaction error. # 8.8.8 Managing the Root Hub As previously noted, the root hub manages the low level details of the USB connect/disconnect, speed detection, reset and suspend/resume signalling. The root hub also detects faulty signalling and babbling devices. Section 8.8.3 *Starting and Stopping Traffic in Host Mode*, describes the command sequences to the USB controller. The command sequences to reset and enable a USB port are discussed here. The root hub has dedicated registers to disable the USB ports. These registers are R\_USB\_PORT1\_DISABLE and R\_USB\_PORT2\_DISABLE. They must be configured before a USB port can be used. #### Writing to the Disable Registers Set the **disable** field (bit 0) in register R\_USB\_PORT1\_DISABLE to the value **no** (0x1). This ensures that USB port p1 can be enabled. Set the **disable** field (bit 0) in register R\_USB\_PORT2\_DISABLE to the value **no** (0x1). This ensures that USB port p2 can be enabled. ### **Detecting a Port Event** - 1 Wait for the USB interrupt. If register R\_USB\_IRQ\_READ indicates a **port\_status** interrupt, go to step 2. Otherwise wait until an interrupt occurs. - **2** Handle the event. Ensure that the software can remember the values in these registers in order to detect the condition that has changed. Some events also trigger a **ctl\_status** interrupt. For instance a command changing a port from **reset** to **enabled** condition may set the USB controller from the HOST\_MODE state to the HOST\_STARTED state. Also note that the last port to change from **enabled** to **disconnected** or **reset** condition will return the controller to the HOST\_MODE state. If a port event indicates that a port became connected, it is appropriate to reset the port as follows: - 1 Issue a reset command to the port by writing to the R\_USB\_COMMAND register. - **2** Wait for the reset to complete. Wait for the port enabled event. - **3** Notify the upper software that an enabled event occurred at the port. The sequence above shows a command to one port (i.e. the root hub). This is the best way to command the root hub. It is possible to issue commands to the USB controller and the root hub, but there is a potential for error. Many operations on the root hub follow the same pattern: - 1 Perform an event. - **2** Wait for its completion. - **3** Report the change in status. #### **Disabling a Port** - 1 Set the **disable** fields (bit 0) in register R\_USB\_PORT1\_DISABLE or R\_USB\_PORT2\_DISABLE to the value **yes** (0x0). This forces the respective port to recognize a disconnect event and change the port status accordingly. - **2** Wait for the port status to change to disconnected. # 8.8.9 Managing USB IN Traffic in Device Mode As previously noted, in Device mode the USB controller has 4 IN endpoints. The traffic for those endpoints are scheduled in the sub-channels of DMA channel 8. Because of the endpoint numbers (0, 1, 2 and 3), it is necessary to use endpoint 0 as the control channel. Any of the other endpoint (1, 2 and 3) can carry bulk, interrupt or isochronous traffic. #### Creating an IN Endpoint - **1** Select an endpoint (0, 1, 2 or 3). In this example, endpoint 1 is used. - **2** Create an EP list for the corresponding DMA sub-channel. The list comprises one EP descriptor pointing at itself. **3** Create SB descriptors describing the data that will be sent. In this example 321 bytes will be sent, with a buffer size of 256 bytes. Figure 8-30 Creating an IN Endpoint - **4** Fill information into the EP table. Write to the corresponding row in the EP table (row 17 since endpoint 1 has been chosen). This enables the endpoint and sets its parameters. - **5** Start the DMA sub-channel by setting the **cmd** field (bit 0) in register R\_DMA\_CH8\_SUB1\_CMD to the value **start** (0x1). If the USB host submits a request to this endpoint, the device will respond with data. When all data are sent, the sub-channel becomes disabled. If the USB device controller receives more requests to this endpoint, it responds with NAK until the software places more data into the sub-channel and restarts it. #### **Appending Traffic to an IN Endpoint** 1 Create an SB descriptor describing the data packet to be sent. In this example a USB transfer of 100 bytes in length will be appended. Set the **eot** and **eol** flags in this descriptor. Figure 8-31 Creating an SB Descriptor for Appending Traffic to an IN Endpoint **2** Move the **next** pointer in the last SB descriptor (B) to point at (C). **3** Clear the **eol** flag in descriptor B. It is important that the **next** pointer is updated before the **eol** flag is cleared. Figure 8-32 Clearing the eol Flag in Descriptor B - **4** Check whether the sub-channel is stopped. The hardware stops a sub-channel only when the **eol** flag is reached. If the sub-channel is running, then the procedure is concluded. Otherwise go to step 5. - **5** Check the sub-pointer in the EP descriptor. If this pointer is not directed at the new SB descriptor (C), then point it there and start the sub-channel. If the pointer in the EP is already pointing at the new SB, then that traffic has been sent and the sub-channel need not be started. ## Stalling Traffic on an IN Endpoint Set the stall bit in the corresponding row in the EP table. This forces the USB hardware to respond with a stall on all requests from the host to that endpoint. The software must disable stall mode to make this endpoint operate again. This should occur after a configuration event on the control channel (channel 0). It is not recommended that endpoint 0 should be stalled. ### Removing Traffic from an Endpoint - 1 Stop the DMA sub-channel by setting the **cmd** field (bit 0) in the appropriate register R\_DMA\_CH8\_SUBn\_CMD to the value **stop** (0x0). - The hardware will transmit the ongoing transaction. If the transmission of a packet has started, the hardware will attempt to finish the transmission. However the relatively abrupt stop of the DMA may cause an underrun that forces the hardware to abort the packet. This is signalled in the same way as an ordinary underrun condition. - **2** Wait for the transaction to end. This cannot be observed by software, but the transaction cannot be longer than one USB frame. It is, therefore, possible to wait for one frame to have passed. This could be done by using the **sof** interrupt which is given once every frame. - **3** Modify the list if necessary. Then start the sub-channel. ### **Error Conditions When Managing USB IN Traffic** All USB errors are handled by hardware, and the only error that can be reported is underrun. The underrun error is indicated in register $R\_USB\_STATUS$ , and the number of the endpoint that caused the error can be read in register $R\_EPID\_ATTN$ . If an isochronous endpoint encountered the underrun error, the hardware will abort the transaction and then disable the endpoint by clearing the valid bit at the corresponding row in the EP table. If a control, bulk or interrupt endpoint encountered the underrun error, the hardware only aborts the transaction, leading to a new request from the USB host. #### 8.8.10 USB OUT Traffic in Device Mode As previously mentioned, all incoming traffic from the 12 OUT endpoints is handled in DMA channel 9. Endpoint 0 is always a control endpoint and the other endpoints can be bulk, interrupt or isochronous. All OUT endpoints require two entries in the EP table, one describing the endpoint and one containing the number of bytes in the transfer. When constructing software for the device it is advisable to ensure that there are always free descriptors/buffers in DMA channel 9. This can be achieved by creating a list with interrupts enabled at certain points in the list - helping the software to free up descriptors. DMA channel 9 will stop if no descriptors remain, resulting in an overrun in the USB hardware. ### **USB Bulk and Interrupt OUT Traffic in Device Mode** As for all USB OUT transfers, the USB hardware must be informed of the expected transfer length. This is the maximum length for the transfer. The transfer could be shorter, but this must be signalled from the host by sending a short packet (not max\_packet\_size) or an empty packet. If the transfer length is not known, the counter must be loaded with a large number (i.e 0xffff) and then reloaded with this value before it reaches zero. For bulk and interrupt traffic, the $max\_packet\_size$ is 64 =>. The counter must be reloaded after $\sim 1000$ packets and, at the most, there can be 19 of these packets per frame (per 1 ms). Another approach to an unknown transfer length is to load the counter with a multiple of the max\_packet\_size (i.e 0xffc0). The hardware will thus report *end-of-transfer* after 1023 packets but, if the actual end-of-transfer has not occurred, the host will continue to send data and the device hardware will receive the data. After reception of a transaction (one packet), the **ep\_id** and the **eop** field are written to the DMA descriptor in DMA channel 9. If the transaction is an empty packet, a dummy byte is written and the **nodata** bit is set. Figure 8-33 Typical USB DMA descriptor List As mentioned before, the end-of-transfer can be signified by the receipt of: - Exactly the number of previously agreed bytes - A short packet - An empty packet At the end-of transfer, an interrupt is signalled (note that this interrupt is the same for all 12 OUT endpoints), and the **eot** bit is written in the DMA descriptor that contains the last data for that transfer. #### **USB Isochronous OUT Traffic in Device Mode** In Device mode, isochronous OUT traffic operates in almost the same way as bulk and interrupt traffic. The difference is that each transaction on an isochronous channel is a transfer. Consequently the transfer length required by hardware (from the EP table), must be set to the same value as **max packet size**. #### **Error Conditions for USB OUT Traffic in Device Mode** The only error not handled by the USB hardware is overrun. The overrun error is reported in register R\_USB\_STATUS, and the number of the endpoint that caused the error can be read in register R\_EPID\_ATTN. If an endpoints overruns it does not acknowledge that transaction. #### 8.8.11 USB Control Traffic in Device Mode Control traffic uses one OUT endpoint and one IN endpoint. With three exceptions, they act in the same way as other endpoints. These exceptions are: - The transfer length of the OUT endpoint (traffic to device), is handled by hardware - IN transfers are aborted if the host issues a new setup packet - IN transfers are considered done when the status packet arrives # The transfer length of the OUT endpoint (traffic to device), is handled by hardware For a setup packet, the hardware always loads the EP table with the value 8 and, after reception of the first DATA0 packet, the EP table is loaded with the expected transfer length. This is the two last bytes in that packet. #### IN transfers are aborted if the host issues a new setup packet If the host first issues a Control read command and then, before all data are read by the host, it issues another Control read command, then the hardware will skip the first transfer in the IN endpoint. #### IN transfers are considered done when the status packet arrives To support the requirements of section 8.5.2.3 of the revision 1.1 of the USB specification, the IN transfer is skipped if the status packet arrives before the IN transfer is complete. Consequently, there will be no **eot** interrupt on that endpoint. # 9 NETWORK INTERFACE The ETRAX 100LX includes an on-chip Fast Ethernet controller. The ETRAX 100LX network interface supports 10 and 100 Mbps Ethernet (IEEE 802.3 and Ethernet II) protocols. With 10 Mbps, the physical interface can be configured to be compatible with either 802.3 MII or SNI (National Semiconductor DP8391 compatible interface). 100 Mbps is only supported over 802.3 MII. The network interface has the following features: - 10 MBit/100 MBit MII Interface - 10 MBit Serial Network Interface (SNI) - Support for full duplex including pause frames - 2 simultaneous station addresses ## 9.1 The Ethernet II and IEEE 802.3 Standards There are some minor differences between the IEEE 802.3 standard and Ethernet II regarding frames. Figure 9-1 below shows the frame format for the Ethernet II standard and the frame format for the IEEE 802.3 standard. CRC = Cyclic Redunancy Check (same as FCS = Frame Check Sequence) Figure 9-1 A description of the frames in Ethernet and the IEEE 802.3 standard Table 9-1 below gives short explanations of the frames' contents: | Frame fields | Description | Length (bytes) | |-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------| | Preamble | Provides synchronization. Consists of 7 bytes of the bit pattern "10101010". | 7 | | Start-of-Frame<br>Delimiter (SOF) | Provides framing. Contains the bit pattern "10101011". | 1 | | Destination Address | The address of the destination station. The first bit indicates: $0 = individual; 1 = group \ address$ | 6 | | Source Address | The address of the sending station. | 6 | | Length or type | Specifies the length or type of the data field. | 2 | | Data | The data content. | 46 - 1500 | | Pad | If the actual data is less than 46 bytes, pad bytes consisting of zeros are added to it up to the required minimum of 46 bytes. | 0 - 46 | | CRC | Used for error checking at the destination station. (CRC = Cyclic Redundancy Check) | 4 | Table 9-1 Ethernet frame contents # 9.2 Network interface registers Table 9-2 below provides a brief description of the network interface registers. For more detailed information, see 18.9 *Network Interface Registers*. | Register | Function | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_NETWORK_SA_0 | A 32-bit wide write only register which contains the bit address $\mbox{[31:0]}$ of station address MA0. | | R_NETWORK_SA_1 | A 32-bit wide write only register which contains the bit address [15:0] of station address MA1, and the bit address [47:32] of station address MA0. | | R_NETWORK_SA_2 | A 32-bit wide write only register which contains the bit address [47:16] of station address MA1. | | R_NETWORK_GA_0 | A 32-bit wide write only register which contains the bit $\left[ 31:0\right]$ of the group address table. | | R_NETWORK_GA_1 | A 32-bit wide write only register which contains the bit $\left[63{:}32\right]$ of the group address table. | | R_NETWORK_REC_CONFIG | A 32-bit wide write only register for configuration of the Ethernet receiver. | | R_NETWORK_GEN_CONFIG | A 32-bit wide write only register for internal loop back, setting the frame format, SNI and MII mode selection, and enabling/disabling of the network controller. | | R_NETWORK_TR_CTRL | A 32-bit wide write only register for controlling the Ethernet transmitter. | | R_NETWORK_MGM_CTRL | A 32-bit wide write only register for controlling the management interface. | | R_NETWORK_STAT | A 32-bit wide read only register for receiver pin status, transmitter error status, and management data. | | R_REC_COUNTERS | A 32-bit wide read only register containing receiver error counters. | | R_TR_COUNTERS | A 32-bit wide read only register containing transmitter error counters. | | R_PHY_COUNTERS | A 32-bit wide read only register containing <b>sqe_test_error</b> and <b>carrier_loss</b> counters. | Table 9-2 Network interface registers # 9.3 Network Interface Configuration The network interface for the ETRAX 100LX is configured in the registers R\_NETWORK\_REC\_CONFIG and R\_NETWORK\_GEN\_CONFIG. In R\_NETWORK\_GEN\_CONFIG, the following configuration possibilities are available: - Enable/disable the network interface - Physical interface mode, IEEE 802.3 MII or DP 8391 compatible SNI (see 9.4) - Frame type and access protocol mode (see 9.6.2 and 9.6.3) By setting the **loopback** field of R\_NETWORK\_GEN\_CONFIG, the network interface can also be set in an internal loopback mode where the transmit data is fed directly to the receiver. The data speed in this mode is 100 Mbps. The R\_NETWORK\_REC\_CONFIG register contains receiver specific configurations (see 9.5). This register also contains the **duplex** field, which selects between half and full duplex operation. In full duplex mode, the receiver is not turned off during transmission, and the transmitter ignores the COL and CRS signals. Full duplex flow control is also turned on. This enables the network transmitter of the ETRAX 100LX to automatically react on 802.3x PAUSE frames by temporarily stopping the transmission. The full duplex mode can also be used for external loopback tests. **Note 1:** Unless the transceiver has successfully negotiated full duplex, half duplex should be selected. # 9.4 Pin Usage in MII and SNI Modes | Solder Ball | Direction | Name | MII Usage | SNI Usage | |-------------|-----------|---------|---------------------------------------------------------|------------------| | Y11 | in/out | mdio | Management data. | General I/O. | | W11 | out | mdc | Management clock. | General output. | | V11 | out | txdata0 | Data out, bit 0. | Data out. | | U11 | out | txdata1 | Data out, bit 1. | General output. | | Y12 | out | txdata2 | Data out, bit 2. | General output. | | W12 | out | txdata3 | Data out, bit 3. | General output. | | V12 | out | txen | Transmit enable. | Transmit enable. | | U12 | out | txer | Transmit error/<br>25 MHz clock/<br>Address recognized. | General output. | | Y13 | in | crs | Carrier sense. | Carrier sense. | | W13 | in | col | Collision. | Collision. | | V13 | in | txclk | Transmit clock. | Transmit clock. | | Y14 | in | rxer | Receive error. | General input. | | W14 | in | rxclk | Receive clock. | Receive clock. | | Y15 | in | rxdv | Data in valid. | Not used. | | V14 | in | rxdata0 | Data in, bit 0. | Data in. | | W15 | in | rxdata1 | Data in, bit 1. | General input. | | Y16 | in | rxdata2 | Data in, bit 2. | General input. | | U14 | in | rxdata3 | Data in, bit 3. | General input. | # 9.5 Receiver Logic Functions The receiver logic of the ETRAX 100LX network interface, configured in R\_NETWORK\_REC\_CONFIG, performs the following: - Communicates incoming data to the receiving FIFO of DMA channel 1 - Communicates status to DMA channel 1 - Checks the destination address of the incoming frame - Checks the CRC of the incoming frame - Checks the length of the incoming frame For more information regarding DMA, please refer to chapter 7 DMA. # 9.5.1 Data Transfer to the Receiving FIFO Incoming data is transferred, one byte at a time, to the receiving FIFO of DMA channel 1. If the destination address of the frame does not match the address in the network interface, or if there is an error in the frame, the frame is aborted and the remaining bytes in the frame are not sent to the FIFO. If an overrun occurs, the packet that caused the overrun is aborted, and reception continues with the next packet. The frame sent to the FIFO contains the following information: | DA | Destination address (6 bytes) | |------|----------------------------------------------------| | SA | Source address (6 bytes) | | L | Length or type (2 bytes) | | Data | Frame data (+ pad if necessary) (46 to 1500 bytes) | | CRC | Cyclic Redundancy Check (4 bytes) | The preamble and SOF fields are generated by the PHY/controller. # 9.5.2 Address Recognition The destination address (DA) field of the incoming frame is compared with the addresses set in the network interface. If the addresses do not match, the frame is aborted. Within the frame formats of the IEEE 802.3 standard, there are three types of destination addresses: - Individual address (unicast) - Group address (multicast) - Broadcast (all nodes) #### Individual address The ETRAX 100LX can hold two individual addresses, MA0 and MA1, each 48 bits long. All 48 bits are compared in each address. This means that one or both of the individual addresses can be used to match a group address instead. In R\_NETWORK\_REC\_CONFIG, there is also one mode bit, ma0 and ma1 respectively, for each individual address to enable/disable recognition. #### **Group address** A 6-bit hash address is calculated from the 48 destination address (DA) bits: Hash\_address[5:0] = DA[5:0] ^ DA[11:6] ^ DA[17:12] ^ DA[23:18] ^ DA[29:24] ^ DA[35:30] ^ DA[41:36] ^ DA[47:42] Note 2: $^{\circ} = XOR$ The hash address is used as an index for a 64-bit table ( $R_NETWORK_GA_0$ and $R_NETWORK_GA_1$ ), which indicates whether or not to copy the frame. In $R_NETWORK_REC_CONFIG$ , there is also the individual mode bit, which is used to select whether to only match group addresses (DA[47] == 1) or to also match individual addresses. The different addresses above can also be used to get promiscuous mode. Set all bits in R\_NETWORK\_GA\_0 and R\_NETWORK\_GA\_1 to 1, and set the **individual** field of R\_NETWORK\_REC\_CONFIG to **receive** (1). #### **Broadcast address** In R\_NETWORK\_REC\_CONFIG, there is a mode bit **broadcast** to enable/disable the recognition of the broadcast address 0xFFFFFFFFF. #### 9.5.3 Receiver CRC Check. The incoming data is CRC checked according to the IEEE 802.3 standard. If an incorrect CRC is detected, the frame is aborted, and the CRC error counter **crc\_error** or alignment error counter **alignment\_error** is incremented in the register R\_REC\_COUNTERS. For the difference between these two error counters, please refer to the IEEE 802.3 standard. With an MII interface, the CRC block also monitors the **rxer** input signal. If the **rxer** signal occurs during a reception, this is handled as if an incorrect CRC occurred. The mode bit **bad\_crc** in R\_NETWORK\_REC\_CONFIG, enables/disables the abortion of frames due to incorrect CRC. If disabled, frames with CRC and alignment errors will also be received. Two status bits, **crc\_err** and **align\_err**, are transferred to DMA channel 1. DMA will put this status information in the status field of the DMA descriptor for the received frame. ## 9.5.4 Received Frame Length Check The lengths of the incoming frames are checked against the specified limits of the IEEE 802.3 frame format: Minimum: 64 bytes Maximum: 1518 or 1522 bytes The max length of a standard Ethernet packet is 1518 bytes. The length can be extended to 1522 bytes when VLAN tagging, according to IEEE 802.1q, is used. The max length is configured with the max\_size field in R\_NETWORK\_REC\_CONFIG. If the frame length is outside the specified bounds, the frame is aborted. There are two mode bits **oversize** and **undersize** in R\_NETWORK\_REC\_CONFIG to enable the minimum length and maximum length check separately. # 9.6 Transmitter Logic Functions The transmitter logic block, configured in R\_NETWORK\_TR\_CTRL, performs the following functions: - Adds preamble and start of frame delimiter to the beginning of the frame. - Pads frame data with zeros if the length of the frame data falls below the required minimum of 46 bytes. - Calculates and adds CRC to the end of the frame. - Handles the access protocol including automatic retransmission (CSMA/CD or demand priority). #### 9.6.1 Transmission of Frames Transmit data is read from the FIFO of DMA channel 0, one byte at a time. The frame from the FIFO should contain the following: | DA | Destination address (6 bytes) | |------|---------------------------------------| | SA | Source address (6 bytes) | | L | Length or type (2 bytes) | | Data | Frame data (0 to 1500 bytes) (Note 3) | #### **Note 3:** Minimum length of data is 46 bytes if automatic **pad** is not selected. The transmitter adds the preamble and start-of-frame delimiter to the beginning of the frame, and the frame check sequence (CRC) to the end of the frame. There is an option to automatically add a pad before the CRC, if the data field of the frame is shorter than 46 bytes. The pad consists of all zeros. Automatic padding is selected by the **pad** bit in R NETWORK TR CTRL. With the MII interface it is possible to deliberately corrupt a frame by setting the <code>tx\_err</code> bit (force network transmission error) in the DMA descriptor. The corruption of frames by the <code>tx\_err</code> bit is only possible if the <code>txer</code> pin is configured for transmit error output and is connected to the <code>txer</code> pin of the transceiver. The automatic addition of CRC to the frame can be disabled by setting the <code>crc</code> mode bit in <code>R\_NETWORK\_TR\_CTRL</code>. This allows corrupted frames to be sent, for example, for test purposes. If the transmitter gets a FIFO empty status during transmission without also getting an **eop**, the transmission is stopped and the transmit **underrun** interrupt is activated. The transmitter remains stopped until the interrupt is cleared. If underrun occurs the transmitter stops. R\_DMA\_CH0\_FIRST points to the first descriptor in the packet that could not be sent. ### 9.6.2 CSMA/CD Access Protocol The CSMA/CD access protocol is used in the IEEE 802.3 mode. The protocol listens continuously to carrier sense to see if the line is free. When a frame is queued for transmission, it is sent as soon as the line is free. If a collision is detected during the transmission, the protocol tries to resend the frame 15 times (i.e. a total of 16 attempts are made). If the transmission is aborted due to excessive collisions, the excessive retry interrupt is issued, and the transmitter stops. The transmitter remains stopped until the interrupt is cleared. If an excessive collision occurs, the transmitter stops. R\_DMA\_CH0\_FIRST points to the first descriptor in the packet that could not be sent. When the interrupt is cleared, transmission is restarted. Two mode bits in R\_NETWORK\_TR\_CTRL, **retry** and **cancel**, modify the access protocol handling. They can be used for other standard modes, as well as for test purposes or to implement protocols that deviate from the standard. | Field | Description | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | retry | Retransmission can be disabled. The <b>excessive_col</b> interrupt will then be issued after the first collision. | | cancel | A pending frame can be cancelled. This will inhibit any attempts to start sending a frame. If there is data in the FIFO but the transmission has not started, the frame will be aborted. If the transmission is already started it will be completed. No transmit retries will be made if the cancel bit is set. After the current frame is completed or aborted, the <code>excessive_col</code> interrupt will be issued. | # 9.6.3 Demand Priority Access Protocol Demand priority access protocol is used in IEEE 802.12 mode. The ETRAX 100LX is designed to support this mode together with Texas Instruments TNETE211 (100-VG-AnyLAN2 PMD interface) or equivalents. The Ethernet controller also supports the token ring frame format through an 802.3 MII interface with extended protocol, using a handshake protocol. Configuration for this feature is done in R NETWORK REC CONFIG. For more information about the operation in these modes please contact Axis Communications. # 9.7 Management Interface The MII management interface consists of two pins, **mdio** and **mdc**. These pins are controlled by software, and are configured in R\_NETWORK\_MGM\_CTRL. As an extension of the IEEE 802.3 management protocol, the **mdio** interrupt is also implemented on the **mdio** pin. An **mdio** interrupt will be issued if the **mdio** field in $R_NETWORK\_STAT$ is sampled low while the interrupt is enabled. In SNI mode, the management interface for the ETRAX 100LX also includes the possibility to use MII\_TXD[3:1] and TX\_ERR as general outputs, and to use MII\_RXD[3:1] and RX\_ERR as general inputs. # 9.8 Ethernet Error and Statistics Counters The ETRAX 100LX contains the following Ethernet error and statistics counters which are read in R\_REC\_COUNTERS, R\_TR\_COUNTERS and R\_PHY\_COUNTERS: | Counter | Explanation | |-----------------|-----------------------------------------------------------------------------------------------------------------| | crc_error | Number of frames with crc errors | | alignment_error | Number of frames with alignment errors | | oversize | Number of oversized frames | | congestion | Number of otherwise correct frames that were not received due to a FIFO full condition | | single_col | Number of frames that were involved in exactly one collision | | multiple_col | Number of frames that were involved in more than one collision | | late_col | Number of frames that were involved in late collisions | | deferred | Number of deferred transmit frames | | carrier_loss | Number of transmit frames for which the carrier sense signal was not constantly present during the transmission | | sqe_test_error | Number of transmitted frames for which the sqe test signal was not recognized | Each counter is 8 bits wide. The counters are cleared either when they are read or at system reset. When a counter reaches 255 it stops counting. If the network interface is disabled the counter values are preserved. An interrupt (with the same name as the error counter) is generated for a counter when it reaches 128. Reading the counter will clear the associated interrupt. The interrupt status can be masked individually, but all counters share the same interrupt vector number (0x27). # 9.9 Network interrupts In addition to error and statistics counter interrupts, there are four network interrupts. Two of these interrupts are for the network receiver, one is for the network transmitter, and one is for the **mdio** pin. All have the internally generated vector number 0x26. #### overrun This interrupt is set when the network receiver experiences a FIFO overrun condition (congestion error). Two interrupts, **congestion** (See section 9.8) and **overrun**, are available, but usually only one of them should be enabled. The **overrun** interrupt should be used if software intervention is necessary when an overrun error occurs. The **congestion** error counter should be used if the only action needed is an error count. This interrupt is cleared by reading the **congestion** field of R\_REC\_COUNTERS, an action which also clears the **congestion** interrupt. #### underrun This interrupt is set when the network transmitter experiences a FIFO underrun condition. This interrupt is cleared by setting the **clr\_error** field in R\_NETWORK\_TR\_CTRL. #### excessive\_col This interrupt is set when the network transmitter experiences collisions for 16 consecutive transmission attempts. It is set after the first collision if the **retry** field in network interface register R\_NETWORK\_TR\_CTRL is set to **disable**, and when the transmitter stops after the **cancel** field of R\_NETWORK\_TR\_CTRL has been set. This interrupt is cleared by setting the **clr\_error** field in R\_NETWORK\_TR\_CTRL. #### mdio This interrupt is from the MII **mdio** pin. It is generated when the **mdio** pin is low. The interrupt should be masked off during normal data transfers over the **mdio** interface. This interrupt should be cleared in the external unit that is driving the MDIO pin. For more information see chapter 17 *Interrupts*. # 10 EIDE/ATA-2/ATA-3 INTERFACE ### 10.1 ATA Interface Pin Connection The EIDE/ATA-2/ATA-3, or ATA interface for short, supports four ATA busses without external logic, see Figure 10-1 below. Figure 10-1 How to Connect the ATA Bus. Each bus is capable of accessing two ATA devices, so up to a total of eight devices can be accessed by the ATA interface. The ATA interface is enabled in the R\_GEN\_CONFIG register (See 18.11 *ATA Interface Registers*). The reset signal of the ATA interface (RESET- (Device reset)) is not supported by the hardware of the ETRAX 100LX, but must be chosen from an available general I/O pin (e.g. General Port **pa0** - **pa7**, General Port **pb0** - **pb7**, **g27**, etc.) and handled by software. For more information regarding general I/O pins see chapter 19 *Electrical Information*. ## 10.2 EIDE/ATA-2/ATA-3 Interface Registers An ATA/ATAPI device (e.g. a hard disk or CD-ROM drive) is controlled via a set of read/write registers in each device. By writing to these registers the ATA device can be made to perform commands such as reading or writing data to or from a disk. For more information about these registers please see the ATA-3 standard. Communication between the ETRAX 100LX and ATA devices takes place via the following set of ETRAX 100LX registers: | Register | Function | |--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_ATA_CTRL_DATA | A 32-bit write only register to enable reading data from and writing data to ATA devices. | | R_ATA_STATUS_DATA | A 32-bit read only register that indicates if the ATA interface is busy. It also indicates if the transmitter is ready, and holds data read from the ATA device. | | R_ATA_CONFIG | A 32-bit write only register for enabling the ATA controller, DMA handshaking, and setup and hold time for register read/writes. | | R_ATA_TRANSFER_CNT | A 32-bit read/write register used to set the number of bytes or 16-bit words transferred during DMA transfers. | For more detailed information about these registers, see chapter 18.11 *ATA Interface Registers* ### 10.3 Data Transfer The ATA interface of ETRAX 100LX can be driven either by internal DMA or by using the register R\_ATA\_CTRL\_DATA (see sections 10.3.3 ETRAX 100LX Register Access, and 10.3.4 ETRAX 100LX DMA Access below). Programmed input/output (PIO) is used for transferring commands to the ATA device, and for transferring data if the device does not support the DMA handshaking protocol. Internal DMA of the ETRAX 100LX must not be confused with the DMA handshaking on the ATA bus that many ATA devices use. ETRAX 100LX DMA can be used both when directly accessing the ATA registers of the device Programmed Input/Output (PIO) and when using the DMA handshaking protocol of the device. ### 10.3.1 Programmed Input/Output (PIO) Commands are always transferred to ATA devices using PIO, and the commands are written directly to the R\_ATA\_CTRL\_DATA register in the ETRAX 100LX. Data can also be transferred to ATA devices in the same way. Data fetched from ATA devices is read in R\_ATA\_STATUS\_DATA. ### 10.3.2 ATA DMA Handshaking Most new ATA devices use DMA handshaking to transfer data. DMA handshaking is enabled in R ATA CONFIG. The device sets its DMARQ signal high when it is ready to receive or deliver data. If the amount to be transferred to or from the device is large, it is possible that the device can neither accept nor produce all data in one burst. It will then lower its DMARQ for periods of time during the transfer. It may take some time until the device is able to accept or produce more data after it has lowered its DMARQ, so this time can be used to talk to another ATA device. This is made possible through the **ata\_dmaend** interrupt generated when the DMARQ signal goes low. ### 10.3.3 ETRAX 100LX Register Access The R\_ATA\_CTRL\_DATA register of the ETRAX 100LX is used for writing to or reading from the registers of ATA devices. Each time R\_ATA\_CTRL\_DATA is written to, one transfer is made to or from the ATA device. The result (e.g. the data transferred from the ATA device) is read in R\_ATA\_STATUS\_DATA. #### 10.3.4 ETRAX 100LX DMA Access An alternative to register access is to let internal DMA of the ETRAX 100LX drive the ATA interface, which is then used to transfer data to and from the ATA device. Configuration to allow DMA to drive the ATA interface is done in R GEN CONFIG. ATA uses DMA channels 2 and 3. A transfer counter, R\_ATA\_TRANSFER\_CNT, is used. For each ATA transfer (8 or 16 bits) the counter is decremented. When the R\_ATA\_TRANSFER\_CNT register reaches zero, the transfer is stopped. If data was transferred to the ETRAX 100LX, an end-of-packet (EOP) is signalled to ETRAX 100LX DMA. # 10.4 Timing If PIO is used, the time for transferring individual data varies between 140 ns and 600ns depending on what mode the ATA device is in (For details please see the ATA-3 standard). Figure 10-2 PIO Timing When DMA handshaking is used, the time varies from 120 ns to 480 ns depending on the ATA mode. Figure 10-3 DMA Multiword (16-bit) Timing Timing for both PIO and DMA handshaking is configured in R\_ATA\_CONFIG. # 10.5 Interrupts The ATA interface has nine interrupts: ata\_irq0, ata\_irq1, ata\_irq2, and ata\_irq3 When ATA is in use, ata\_irq0, ata\_irq1, ata\_irq2, or ata\_irq3 is set when a unit on the ATA bus (0, 1, 2, 3 respectively) requests an interrupt. The interrupt is cleared through registers in the external unit on the ATA bus (0, 1, 2, 3 respectively). ata\_drq0, ata\_drq1, ata\_drq2, and ata\_drq3 Whe ATA is in use, ata\_drq0, ata\_drq1, ata\_drq2, or ata\_drq3 is set when a unit on the ATA bus (0, 1, 2, 3 respectively) requests a DMA transfer. The interrupt is automatically cleared at the end of the DMA transfer on ATA bus (0, 1, 2, 3 respectively). #### ata\_dmaend The **ata\_dmaend** interrupt is set when the selected ATA unit releases its DMA request (transfer completed). The interrupt should be masked in R\_IRQ\_MASK0\_SET except when an ATA DMA transfer has been started. It is automatically cleared when the next ATA DMA transfer commences. # 11 ASYNCHRONOUS SERIAL PORTS #### 11.1 General The ETRAX 100LX contains four complete asynchronous serial receivers/ transmitters with full buffering and parity control. Each asynchronous serial port has one handshake signal in each direction. The receivers/transmitters support baud rates from 48 up to 1,843,200 baud, plus a non-standard baud rate of 6,250,000 baud. # 11.2 Connection to Input/Output Pins The pins of Asynchronous Serial Port p0 are available in all configurations. The other asynchronous serial port pins are multiplexed as shown in table 11-1 below: | Asynchronous Serial Port Pins | Multiplexed Pins | |-------------------------------|------------------------------------------------------------------------------| | Asynchronous Serial Port p1 | Synchronous Serial Port p1<br>USB Port p1<br>General I/O Port | | Asynchronous Serial Port p2 | SCSI-8 Port p0<br>SCSI-W Port<br>ATA Port<br>General I/O Port | | Asynchronous Serial Port p3 | Synchronous Serial Port p3<br>SCSI-8 Port p1<br>ATA Port<br>General I/O Port | Table 11-1 Asynchronous serial port pin multiplexing Pin configuration is done in registers $R\_GEN\_CONFIG$ and $R\_GEN\_CONFIG$ II. In order to set the correct default value of Asynchronous Serial ports p2 and p3, the **hcfg** pin should be tied to 0: if (hcfg = 0), then $\{s0sel = 1, s1sel = 1\}$ For more information see section 19.11 I/O Pin Default Values. # 11.3 Asynchronous Serial Port Registers Table 11-2 below provides a summary of the asynchronous serial port registers. For more detailed information see chapter 18.8 *Serial Port Registers*. | Register | Function | |----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | R_SERIAL0_CTRL R_SERIAL1_CTRL R_SERIAL2_CTRL R_SERIAL3_CTRL | A 32-bit wide write only register for baud rate selection, serial transmitter/receiver control, and serial data out. | | R_SERIAL0_BAUD<br>R_SERIAL1_BAUD<br>R_SERIAL2_BAUD<br>R_SERIAL3_BAUD | A byte wide write only register for transmitter/receiver baud rate selection. | | R_SERIALO_REC_CTRL R_SERIAL1_REC_CTRL R_SERIAL2_REC_CTRL R_SERIAL3_REC_CTRL | A byte wide write only register for serial receiver control. | | R_SERIALO_TR_CTRL R_SERIAL1_TR_CTRL R_SERIAL2_TR_CTRL R_SERIAL3_TR_CTRL | A byte wide write only register for serial transmitter control. | | R_SERIALO_TR_DATA<br>R_SERIAL1_TR_DATA<br>R_SERIAL2_TR_DATA<br>R_SERIAL3_TR_DATA | A byte wide write only register for serial data out. | | R_SERIAL0_READ<br>R_SERIAL1_READ<br>R_SERIAL2_READ<br>R_SERIAL3_READ | A byte wide read only register for serial transmitter/receiver status, and serial data in. | | R_SERIAL0_STATUS<br>R_SERIAL1_STATUS<br>R_SERIAL2_STATUS<br>R_SERIAL3_STATUS | A byte wide read only register for serial transmitter/receiver status. | | R_SERIAL0_REC_DATA R_SERIAL1_REC_DATA R_SERIAL2_REC_DATA R_SERIAL3_REC_DATA | A byte wide read only register for data in from the serial receiver. | | R_SERIAL0_XOFF<br>R_SERIAL1_XOFF<br>R_SERIAL2_XOFF<br>R_SERIAL3_XOFF | A 32-bit wide write only register for serial transmitter control, and <b>xoff</b> handling. | | R_ALT_SER_BAUDRATE | A 32-bit wide write only register for alternative baud rate selection. | | R_SERIAL_PRESCALE | A 16-bit write only register for the divide factor for serial clock prescaling. | | R_SER_PRESC_STATUS | A 16-bit read only register for the current count value of the serial divide factor. | Table 11-2 Asynchronous serial port registers ### 11.4 Operation Modes The serial port operation modes are configured in R\_SERIAL*x*\_CTRL. The receiver and transmitter can also be configured separately by using the registers R\_SERIAL*x*\_REC\_CTRL and R\_SERIAL*x*\_TR\_CTRL respectively. The following modes can be configured: - · Receiver and transmitter baud rate - Odd, even, fixed or no parity - 7 or 8 data bits The transmitter can also be configured to send $\underline{1}$ or 2 stop bits, and to handle $\overline{\textbf{cts}}$ automatically or to ignore $\overline{\textbf{cts}}$ . When automatic $\overline{\textbf{cts}}$ handling is selected, a high on the $\overline{\textbf{cts}}$ input will halt the transmitter after the ongoing byte, and keep it halted until $\overline{\textbf{cts}}$ becomes low again. The $\overline{\text{rts}}$ output is also controlled by a bit in the R\_SERIALx\_CTRL register. In the R\_SERIAL*x*\_XOFF register, the serial port can be configured to stop transmission when the xoff character is received. The character code for xoff is also configurable. Receiver and transmitter baud rate configuration can be done in either R\_SERIAL*x*\_REC\_CTRL or R\_SERIAL*x*\_BAUD. Asynchronous Serial Port p0 can be used when bootstrapping the ETRAX 100LX. See chapter 6 *Bootstrap Methods*. **Note 1:** In order to avoid unnecessary repetition of port numbers, the X\_ in the interrupt and register names stands for either 0\_, 1\_, 2\_ or 3\_, representing Asynchronous Serial Ports p0, p1, p2 and p3. #### 11.5 Baud Rate Selection There are four different ways to set the baud rate, which is configured in R ALT SER BAUDRATE: • The default setting for R\_ALT\_SER\_BAUDRATE is to choose one of the available predefined baud rates shown below in table 11-3. The predefined baud rate is set in R\_SERIALx\_CTRL or R\_SERIALx\_BAUD. The baud rate can be set individually for each port, and separately for input and output: | Predefined Baud rates | | | | | | | | |-----------------------|---------|-----------|--|--|--|--|--| | 300 | 9,600 | 230,400 | | | | | | | 600 | 19,200 | 460,800 | | | | | | | 1,200 | 38,400 | 921,600 | | | | | | | 2,400 | 57,600 | 1,843,200 | | | | | | | 4,800 | 115,200 | 6,250,000 | | | | | | Table 11-3 Predefined baud rates - Use a scalable baud rate. The scalable baud rate can be set between 1,562,500 baud and 48 baud through a 16 bit divide factor loaded in R\_SERIAL\_PRESCALE. The resulting baud rate will be (3,125,000/ser\_presc baud), where ser\_presc is the divide factor in R\_SERIAL\_PRESCALE. - Use an external baud rate clock which is enabled in R\_GEN\_CONFIG\_II. The clock must be less than 20 MHz. The baud rate achieved from the external clock is the external clock divided by eight, so the maximum baud rate is 2,500,000 baud. The General I/O Port pb6 is assigned to receive the external baud rate clock. - Use **timer0** as the baud rate generator. The frequency generated with **timer0**, is configured in the R\_TIMER\_CTRL register. For transmission the timer output clock is used directly resulting in a maximum baud rate of 12.5 MHz. For receiving the output is divided by eight resulting in a maximum baud rate of 1,562,500 baud. For more detailed information see chapter 15 *Timers*. ## 11.6 CPU Controlled Operation When the CPU controls serial port operation, the port can be polled or interrupt driven. When the transmitter is ready to accept new data, the **tr\_ready** field in R\_SERIAL*x*\_READ and R\_SERIAL*x*\_STATUS is set to **ready**, and the **ser***x*\_**ready** interrupt is generated. The **tr\_ready** bit and the **ser***x*\_**ready** interrupt are cleared when data is written to the R\_SERIAL*x*\_TR\_DATA register or to the **data\_out** field of R\_SERIAL*x*\_CTRL. When data is available from the serial receiver, the **data\_avail** field in R\_SERIAL*x*\_READ and R\_SERIAL*x*\_STATUS is set to **yes**, and the **ser***x*\_**data** interrupt is generated. The **data\_avail** bit and the **ser***x*\_**data** interrupt are cleared when data is read from the R\_SERIAL*x*\_REC\_DATA register or from the **data\_in** field of R\_SERIAL*x*\_READ. If the serial receiver encounters a parity error, framing error or overrun error, the errors are indicated in the R\_SERIAL*x*\_READ and R\_SERIAL*x*\_STATUS registers. The error status is valid whenever the **data\_avail** bit is set, and is cleared when data is read from the R\_SERIAL*x*\_REC\_DATA register or from the **data\_in** field of R\_SERIAL*x*\_READ. # 11.7 DMA Controlled Operation In R\_GEN\_CONFIG, the asynchronous serial ports can be connected to the internal DMA channels as shown in the table below: | Async Serial Port | DMA Channel | | | | | | |----------------------|-------------|-----------|--|--|--|--| | Asylic Selial Fort | In | Out | | | | | | Async Serial Port p0 | Channel 7 | Channel 6 | | | | | | Async Serial Port p1 | Channel 9 | Channel 8 | | | | | | Async Serial Port p2 | Channel 3 | Channel 2 | | | | | | Async Serial Port p3 | Channel 5 | Channel 4 | | | | | In a DMA controlled operation, received data is entered into the FIFO of the connected internal DMA channel. The data in the FIFO will only be written out when it reaches the configured FIFO trip point (i.e. 16 or 32 bytes, which is configured in R\_BUS\_CONFIG). Therefore, after the last received byte, there may be up to 31 bytes left in the FIFO. The remaining FIFO contents can be written out to the memory by issuing an **eop** (end of packet) command to DMA. This is done by writing to the R\_SET\_EOP register. In addition, the **data\_avail** field in R\_SERIAL*x*\_READ and R\_SERIAL*x*\_STATUS is set when a data byte is received, and is cleared by a CPU read from the R\_SERIAL*x*\_REC\_DATA register or from the **data\_in** field of R\_SERIAL*x*\_READ. The same is also true for the **ser***x*\_**data** interrupt. Therefore, the **data\_avail** field and/or the **ser***x*\_**data** interrupt can be used to detect when new data has been entered into the FIFO. To handle receive errors in a DMA controlled operation, there are two different modes: - 1 If the **dma\_err** field in R\_SERIAL*x*\_CTRL is set to **stop**, a receive error generates an **eop** to DMA and stops the receiver so the erroneous byte is not entered into the FIFO. The error condition is cleared by a CPU read from the R\_SERIAL*x*\_REC\_DATA register, or from the **data\_in** field of R\_SERIAL*x*\_READ. - **2** If the **dma\_err** field is set to **ignore**, receive errors are ignored and the erroneous byte is entered in the FIFO. During a DMA controlled transmission, DMA transfers may be temporarily stopped and CPU mode entered by disconnecting DMA in R\_GEN\_CONFIG. This can be used, for example, for inserting a CPU controlled xoff transmission into a DMA controlled data stream. # 11.8 Asynchronous Serial Port Interrupts Each asynchronous serial port has two interrupts, one for the receiver and one for the transmitter: #### serx\_ready This interrupt is set when the asynchronous serial port is ready to acquire new data for transmission. This interrupt is cleared when new data is written to the R\_SERIALx\_TR\_DATA register, or to the **data\_out** field of R\_SERIAL3\_CTRL. The **serx\_ready** interrupt should be masked when DMA is used for data transfers. #### serx\_data This interrupt is set when input data is available on the port. It is cleared when data is read from the R\_SERIALx\_REC\_DATA register, or from the **data\_in** field of R\_SERIALx\_READ. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. For more detailed information see chapter 17 *Interrupts*. # 12 SYNCHRONOUS SERIAL INTERFACE #### 12.1 Overview The synchronous serial interface (sync serial) in the ETRAX 100LX sends the transmission clock along with the data. Communication takes place between two parties: a master which generates the clock, and a slave. The ETRAX 100LX can be either the master or the slave. Figure 12-1 Simple Synchronous Serial Port The sync serial interface has two synchronous serial ports. The first sync serial port is named *Synchronous Serial Port p1* and the other is *Synchronous Serial Port p3*. These two ports are multiplexed with Asynchronous Serial Ports p1 and p3 respectively, so Sync Serial Ports p0 and p2 do not exist. #### 12.2 Mode Selection There are six different operation modes into which the sync serial ports of the ETRAX 100LX can be configured. Three different types of communication channels can be used, two of which are unidirectional, and one of which is bidirectional. Because there is one master and one slave in each type of channel, one synchronous serial port may be configured into one of the following six modes: | Mode | Description | |----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Master Output | The ETRAX 100LX generates clock signals, and data is transferred to the external unit. | | Master Input | The ETRAX 100LX generates clock signals, and data is transferred from the external unit. $ \frac{1}{2} \left( \frac{1}{2} \right) = \frac{1}{2} \left( \frac{1}{2} \right) \frac$ | | Master Bidirectional | The ETRAX 100LX generates clock signals, and data is transferred in both directions. | | Slave Output | The ETRAX 100LX sends data to the external unit depending on the incoming clock signals it receives. | | Slave Input | The ETRAX 100LX receives data from the external unit depending on the incoming clock signals it receives. | | Slave Bidirectional | The ETRAX 100LX sends and receives data from the external unit depending on the incoming clock signals it receives. | To properly configure the ETRAX 100LX, select the mode that is supported by the other circuit. If two ETRAX 100's are connected to each other, any of the six modes are available. ### 12.3 Pin Usage ### 12.3.1 Pin Configuration The sync serial ports are multiplexed onto the same pins as some other interface applications, see chapter 19 Electrical Information. To select sync serial port p1, the **sermode1** bit in the R\_GEN\_CONFIG\_II register must be set to **sync** (0x1). To select sync serial p3, the **sermode3** bit in the R\_GEN\_CONFIG\_II register must be set to **sync** (0x1), and the **ser3** bit in the R\_GEN\_CONFIG register must be set to **select** (0x1). For every configuration the sync serial interface has two output pins and two input pins, and the pin function is different depending on the mode of operation. To make all configurations complete, however, one extra bidirectional pin per port will be required. In order to use some synchronous serial port modes, 5 pins are needed. Extra pins must be configured from General I/O Ports **pb4** or **pb7**, which is done with the register R\_PORT\_PB\_SET. For a detailed description of the different registers, please refer to chapter 18.18 *Synchronous Serial Port Registers*. ### 12.3.2 Pin Usage in the Different Modes The signal names at the I/O pins differ, depending upon the mode in use. The following tables show the different I/O pin assignments of the two synchronous serial ports in each mode of operation. | | Synchronous Serial Ports - Master Output Mode | | | | | | | | | | |----------------|-----------------------------------------------|------------------------|----------------------------------|---------------------|------------------------|-----------------------------|-----------------------------------------------------------------|--|--|--| | Synchro | onous Ser | rial Port p1 | rt p1 Synchronous Serial Port p3 | | | | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | | T17 | rxd1 | - | J18 | s1sel | - | ss1_in1<br>ss3_in1 | Not used by the synchronous serial ports in Master Output mode. | | | | | V19 | cts1 | ss1status | J19 | s1bsy | ss3status | ss1_in2<br>ss3_in2 | Serial busy input to respective port. | | | | | U19 | txd1 | ss1clk | H20 | s1sel | ss3clk | ss1_out1<br>ss3_out1 | Serial clock output from respective port. | | | | | W20 | rts1 | ss1data | B19 | s1en | ss3data | ss1_out2<br>ss3_out2 | Serial data output from respective port. | | | | | W17 | pb4 | ss1frame | U16 | pb7 | ss3frame | ss1_io3<br>ss3_io3 | Serial frame indicator output from respective port. | | | | | | Synchronous Serial Ports - Master Input Mode | | | | | | | | | | | |----------------|----------------------------------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|----------------------------------------------------------------|--|--|--|--| | Synchro | onous Ser | rial Port p1 | Synchro | onous Ser | ial Port p3 | | | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | | | T17 | rxd1 | ss1data | J18 | s1sel | ss3data | ss1_in1<br>ss3_in1 | Serial data input to respective port. | | | | | | V19 | cts1 | ss1status | J19 | s1bsy | ss3status | ss1_in2<br>ss3_in2 | Serial empty input to respective port. | | | | | | U19 | txd1 | ss1clk | H20 | s1sel | ss3clk | ss1_out1<br>ss3_out1 | Serial clock output from respective port. | | | | | | W20 | rts1 | ss1frame | B19 | s1en | ss3frame | ss1_out2<br>ss3_out2 | Serial frame indicator from respective port. | | | | | | W17 | pb4 | - | U16 | pb7 | - | - | Not used by the synchronous serial ports in Master Input mode. | | | | | | | Synchronous Serial Ports - Slave Output Mode | | | | | | | | | | | |----------------|----------------------------------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|----------------------------------------------------------------|--|--|--|--| | Synchro | onous Ser | ial Port p1 | Synchro | onous Ser | ial Port p3 | | | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | | | T17 | rxd1 | ss1clk | J18 | s1sel | ss3clk | ss1_in1<br>ss3_in1 | Serial clock input to respective port. | | | | | | V19 | cts1 | ss1frame | J19 | s1bsy | ss3frame | ss1_in2<br>ss3_in2 | Serial frame indicator to respective port. | | | | | | U19 | txd1 | ss1data | H20 | s1sel | ss3data | ss1_out1<br>ss3_out1 | Serial data output from respective port. | | | | | | W20 | rts1 | ss1status | B19 | s1en | ss3status | ss1_out2<br>ss3_out2 | Serial empty output from respective port. | | | | | | W17 | pb4 | - | U16 | pb7 | - | - | Not used by the synchronous serial ports in Slave Output mode. | | | | | | | Synchronous Serial Ports - Slave Input Mode | | | | | | | | | | | |----------------|-------------------------------------------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|---------------------------------------------------------------|--|--|--|--| | Synchro | Synchronous Serial Port p1 Synchronous Serial Port p3 | | | | | | | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | | | T17 | rxd1 | ss1clk | J18 | s1sel | ss3clk | ss1_in1<br>ss3_in1 | Serial clock input to respective port. | | | | | | V19 | cts1 | ss1frame | J19 | s1bsy | ss3frame | ss1_in2<br>ss3_in2 | Serial frame indicator to respective port. | | | | | | U19 | txd1 | - | H20 | s1sel | - | ss1_out1<br>ss3_out1 | Not used by the synchronous serial ports in Slave Input mode. | | | | | | W20 | rts1 | ss1status | B19 | s1en | ss3status | ss1_out2<br>ss3_out2 | Serial busy output from respective port. | | | | | | W17 | pb4 | ss1data | U16 | pb7 | ss3data | ss1_io3<br>ss3_io3 | Serial data input to respective port. | | | | | | | Synchronous Serial Ports - Master Bidirectional Mode | | | | | | | | | | | |----------------|------------------------------------------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|-----------------------------------------------------|--|--|--|--| | Synchro | onous Ser | ial Port p1 | Synchro | onous Ser | ial Port p3 | | | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | | | T17 | rxd1 | ss1status | J18 | s1sel | ss3status | ss1_in1<br>ss3_in1 | Serial busy input to respective port. | | | | | | V19 | cts1 | ss1idata | J19 | s1bsy | ss3idata | ss1_in2<br>ss3_in2 | Serial data input to respective port. | | | | | | U19 | txd1 | ss1clk | H20 | s1sel | ss3clk | ss1_out1<br>ss3_out1 | Serial clock output from respective port. | | | | | | W20 | rts1 | ss1odata | B19 | s1en | ss3odata | ss1_out2<br>ss3_out2 | Serial data output from respective port. | | | | | | W17 | pb4 | ss1frame | U16 | pb7 | ss3frame | ss1_io3<br>ss3_io3 | Serial frame indicator output from respective port. | | | | | | | Synchronous Serial Ports - Slave Bidirectional Mode | | | | | | | | | | | |-------------------------------------------------------|-----------------------------------------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|--------------------------------------------|--|--|--|--| | Synchronous Serial Port p1 Synchronous Serial Port p3 | | | | | | | | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | | | T17 | rxd1 | ss1clk | J18 | s1sel | ss3clk | ss1_in1<br>ss3_in1 | Serial clock input to respective port. | | | | | | V19 | cts1 | ss1frame | J19 | s1bsy | ss3frame | ss1_in2<br>ss3_in2 | Serial frame indicator to respective port. | | | | | | U19 | txd1 | ss1status | H20 | s1sel | ss3status | ss1_out1<br>ss3_out1 | Serial busy output from respective port. | | | | | | W20 | rts1 | ss1odata | B19 | s1en | ss3odata | ss1_out2<br>ss3_out2 | Serial data output from respective port. | | | | | | W17 | pb4 | ss1idata | U16 | pb7 | ss3idata | ss1_io3<br>ss3_io3 | Serial data input to respective port. | | | | | # 12.4 Synchronous Serial Port Registers The sync serial ports are served by two sets of dedicated registers, one set for each port. The table below summarizes the purpose of each register. | Registers | Function | |----------------------------------------------------|--------------------------------------------------------------------------------------------------| | R_SYNC_SERIAL_PRESCALE | A 32-bit write-only register that selects clock source and frame sync rate for both ports. $ \\$ | | R_SYNC_SERIAL1_REC_DATA<br>R_SYNC_SERIAL3_REC_DATA | 32-bit read-only registers containing data in from the serial receivers. | | R_SYNC_SERIAL1_REC_WORD<br>R_SYNC_SERIAL3_REC_WORD | 16-bit read-only registers containing data in from the serial receivers. | | R_SYNC_SERIAL1_REC_BYTE<br>R_SYNC_SERIAL3_REC_BYTE | 8-bit read-only registers containing data in from the serial receivers. | | R_SYNC_SERIAL1_STATUS<br>R_SYNC_SERIAL3_STATUS | $32\mbox{-bit}$ read-only registers containing status information from the ports. | | R_SYNC_SERIAL1_TR_DATA<br>R_SYNC_SERIAL3_TR_DATA | 32-bit write-only registers containing data out to the serial receivers. | | R_SYNC_SERIAL1_TR_WORD<br>R_SYNC_SERIAL3_TR_WORD | 16-bit write-only registers containing data out to the serial receivers. | | R_SYNC_SERIAL1_TR_BYTE<br>R_SYNC_SERIAL3_TR_BYTE | 8-bit write-only registers containing data out to the serial receivers. | | R_SYNC_SERIAL1_CTRL<br>R_SYNC_SERIAL3_CTRL | 32-bit write-only registers for configuration and control of each port. | For more detailed information about sync serial registers, refer to chapter 18.18 *Synchronous Serial Port Registers.* ## 12.5 Configuration Besides the different modes described in section 12.2 *Mode Selection*, a number of things can be configured in the R\_SYNC\_SERIAL*x*\_CTRL register: - Word length can be either 8, 12, 16, 24 or 32 bits. - A number of different frame synchronization modes can be configured. - The ports can be controlled by the CPU or by DMA. - Data can be sent with either the lsb or msb first. - The active clock edge may be either positive or negative. - All control signals can be individually inverted. - The receiver and transmitter can be enabled and disabled individually as well. # 12.6 Word Length The sync serial interface supports a transmitted/received word length of either 8, 12, 16, 24 or 32 bits. The word length is configured with the **wordsize** field in R\_SYNC\_SERIAL*x*\_CTRL. **Note 1:** To avoid unnecessary repetition, the x\_ in R\_SYNC\_SERIALx\_CTRL above and elsewhere in this chapter, stands for 1\_ and 3\_, representing Synchronous Serial Ports p1 and p3. When the sync serial port is controlled by the CPU, transmit data is written to R\_SYNC\_SERIAL*x*\_TR\_DATA, and receive data is read from R\_SYNC\_SERIAL*x*\_REC\_DATA. Each read or write corresponds to one received or transmitted word of the selected word length. The **wordsize** lsb bits are used by the interface. For word lengths other than 32-bits, the upper bits of R\_SYNC\_SERIAL*x*\_TR\_DATA are ignored by the transmitter, and the upper bits of R\_SYNC\_SERIAL*x*\_REC\_DATA contain invalid data. The lower 8 bits or 16 bits of the transmit data can be written in the registers R\_SYNC\_SERIALx\_TR\_BYTE and R\_SYNC\_SERIALx\_TR\_WORD respectively. Each write to one of these registers will result in the transmission of one word of the selected word length. If the word length is wider than the written register, the remaining bits will be the same as in the previously transmitted word. There are 8-bit and 16-bit registers for the data read as well, R\_SYNC\_SERIAL*x*\_REC\_BYTE and R\_SYNC\_SERIAL*x*\_REC\_WORD respectively. When the sync serial interface is DMA driven, each transmitted/received word is represented by 1, 2 or 4 bytes in memory, depending on the selected word length: | Selected Word Length (bits) | Size In Memory (bytes) | |-----------------------------|------------------------| | 8 | 1 | | 12 | 2 | | 16 | 2 | | Selected Word Length (bits) | Size In Memory (bytes) | |-----------------------------|------------------------| | 24 | 4 | | 32 | 4 | #### Frame Synchronization 12.7 #### 12.7.1 Frame Synchronization Modes The following figures show the different types of frame synchronization configurations in R\_SYNC\_SERIAL*x*\_CTRL: Figure 12-2 Synchronous Serial Type Configurations Note 1: When the f\_syncsize field in R\_SYNC\_SERIALx\_CTRL is set to extended, the field f\_synctype must be set to early. #### 12.7.2 Frame Strobe Generation When the sync serial interface operates in Master mode, the frame strobe output interval is controlled by the **word\_rate** and **frame\_rate** fields in R\_SYNC\_SERIAL\_PRESCALE. The selected values are common to both ports. The **word\_rate** field selects the interval, in number of bit clocks, between the start of consecutive words transmitted or received. The word rate interval length is the value in the **word rate** field + 1. Figure 12-3 Word Rate Interval The maximum value for the word rate interval is 1024 bits (i.e. word\_rate field = 1023). The minimum value is restricted by the word length, see table 12-1 below: | Frame | Sync Type: Bit | or Word | Frame sync type: Early Bit,<br>Early Word or Early Extended | | | |-------------|-------------------------------|----------------------------------|-------------------------------------------------------------|-------------------------------|----------------------------------| | Word Length | Minimum<br>word_rate<br>Value | Minimum<br>Word Rate<br>Interval | Word Length | Minimum<br>word_rate<br>Value | Minimum<br>Word Rate<br>Interval | | 8 | 7 | 8 | 8 | 8 | 9 | | 12 | 11 | 12 | 12 | 12 | 13 | | 16 | 15 | 16 | 16 | 16 | 17 | | 24 | 23 | 24 | 24 | 24 | 25 | | 32 | 31 | 32 | 32 | 32 | 33 | Table 12-1 Word length The **frame\_rate** field selects the number of words received or transmitted between each frame strobe output. The frame strobe interval is the value in the **frame\_rate** field + 1. If the **frame\_rate** field is set to 0, a frame strobe will be output for each word received or transmitted. This is the appropriate setting for most applications. Figure 12-4 Frame Strobe Output with frame\_rate Set to 0. #### 12.7.3 Stream Mode It is possible to turn off frame synchronization, so that no frame strobe output is generated and the incoming frame strobe is ignored. Words will be transmitted or received back-to-back regardless of the word rate setting. This mode is used if the transferred data contains embedded synchronization. ### 12.8 Clocking #### 12.8.1 Clock Generator There are three possible clock sources for the sync serial interface: - Internally generated codec clock. - Externally generated codec clock. - Baudrate clock from the async serial port. Clock selection is made in register R\_SYNC\_SERIAL\_PRESCALE. Fields clk\_sel\_u3 and clk\_sel\_u1 are used to select either the codec clock or baudrate clock. The source for the codec clock (internal or external) is defined when *operation mode* is selected. #### **Internally Generated Codec Clock** The base clock is 4.096 MHz. For selectable clock division, the base clock is then divided using a prescaler with a division factor of 1 to 128 before it is used by the sync serial port. The division factor is set in the **prescaler** field. The selected value is common to both ports. #### **Baudrate Clock from Async Serial Ports** When this mode is used, the clock is generated from the baud rate clock generator which is used in the async serial ports. This clock generator may be configured in a number of different ways, which is selected in the R\_ALT\_SER\_BAUDRATE register and in the **tr\_baud** field of R\_SYNC\_SERIAL*x\_*CTRL. For a description of the different possibilities, refer to chapter 11.5 *Baud Rate Selection*. Before this clock is used, the frequency is divided by two. Thus, the selectable frequency settings in the **tr\_baud** field of the R\_SYNC\_SERIAL*x*\_CTRL register, are half of the selected frequency for the asynchronous serial ports. For the baudrate selection modes that do not use the **tr\_baud** field, the following formula applies: sync serial bit clock = $$\frac{\text{async serial baud rate}}{2}$$ ### 12.8.2 Data Sampling Sampling of incoming signals is controlled by the **clk\_polarity** field in R\_SYNC\_SERIAL*x*\_CTRL. The outgoing clock may be inverted with the **clk\_driver** field. When clocks are not inverted, output signals are changed on the rising edge, and input signals are sampled on the falling edge of the clock, see figure 12-5 below. Figure 12-5 Master Output/Slave Input ### 12.8.3 Clock Gating When clock gating is turned on (**clk\_mode** is set to **gated** (1)), every negative clock edge is a bit strobe. When nothing is sent, the clock is held low. However, if clock gating is turned off (**clk\_mode** is set to **normal** (0)), the clock will run continuously. Figure 12-6 below shows an example of the input mode with clock gating on: Figure 12-6 Input Mode with Clock Gating On Note that clock gating does not work correctly with **flow\_ctrl** set to **enable** (1) because the transmitter will stop clocking and never sample the status signal after its initial rise. If more than one word is transferred between frames, as in figure 12-7 below, the clock must be gated for the receiver to understand the incoming data because the word strobe signal is not sent (only the frame strobe). With clock gating turned on, the clock will only be active when the information is sent. In this case, every active clock edge contains information, and as a result, many words per frame can be understood by the receiver. Figure 12-7 Output Mode with Clock Gating on, 2 Words Per Frame The number of words per frame is selected in R\_SYNC\_SERIAL*x*\_PRESCALE. ### 12.9 Flow Control In the R\_SYNC\_SERIAL*x*\_CTRL register, if the **flow\_ctrl** field is set to **off** (0), the amount of transferred data is defined by the selected word rate. Data must be available when they are to be sent, and storage must be available before more data is received. If this is not the case, the failing unit will go into an error state which may be detected by reading the status register: R\_SYNC\_SERIAL*x*\_STATUS. When **flow\_ctrl** is set to **on** (1), one or more status signals between units are used to pause the transfer until the receiver is prepared. This will delay word and frame synchronization. The master unit is paused by the slave if the slave can not deliver or receive data. If the master runs out of buffers, the start frame/word is delayed internally until the congestion is cleared. An overrun/underflow error will be reported if the transmitter or receiver over/under run their FIFO's. When the **error** field in R\_SYNC\_SERIAL*x*\_CTRL is set to **ignore** (1), the transmission is continued after next frame sync even if an error is detected. When **error** is set to **normal** (0), the transfer is halted when an error is detected. The status signal should be seen as the way the slave halts the transfer if data/storage is not available, and the frame signals the way the master controls the same variables. The frame pulse, represented by a dotted line, is skipped. Figure 12-8 Flow Control # 12.10 Interrupts There are two interrupts for each sync serial port. The same interrupt bits in the R\_IRQ\_MASK1\_RD register that are used for the asynchronous serial ports are also used for the sync serial interface: fields **ser1\_ready**, **ser1\_data**, **ser3\_ready**, and **ser3\_data**. For detailed information see chapter *18 Interrupts*. The **ser1\_ready** or **ser3\_ready** interrupt is generated when the sync serial port is ready to accept a new data word to be transmitted, i.e. whenever the **tr\_ready** field of the R\_SYNC\_SERIALx\_STATUS register is set. The interrupt is cleared when new data is written to one of the port data transmit registers R\_SYNC\_SERIALx\_TR\_DATA, R\_SYNC\_SERIALx\_TR\_WORD or R\_SYNC\_SERIALx\_TR\_BYTE. The **ser1\_data** or **ser3\_data** interrupt is generated when the sync serial port has received a new data word, i.e. whenever the **data\_avail** field of the R\_SYNC\_SERIAL*x*\_STATUS register is set. The interrupt is cleared when the data is read from one of the port data receive registers R\_SYNC\_SERIAL*x*\_REC\_DATA, R\_SYNC\_SERIAL*x*\_REC\_WORD or R\_SYNC\_SERIAL*x*\_REC\_BYTE. # 12.11 Using The Sync Serial Ports with DMA The sync serial ports can be driven by the CPU or by DMA. Sync serial port 1 uses internal DMA channel 8 for output, and DMA channel 9 for input. Port 3 uses DMA channel 6 for output and DMA channel 7 for input. When DMA is used, the **dma\_enable** field in R\_SYNC\_SERIAL1\_CTRL register must be set, and the ports must be connected to their respective DMA channels, which is done in the R\_GEN\_CONFIG register. For input transfers with DMA, the incoming data will be stored in the fifo of the DMA channel, and will not be written out to memory until the fifo is filled with 16 or 32 bytes (depending on the DMA burst length set in the R\_BUS\_CONFIG register). The DMA can be forced to write out the fifo contents to memory, by setting the appropriate bits in the R\_SET\_EOP register. The DMA will then set an **eop** in the current DMA descriptor, and advance to the next descriptor. For further information on DMA operation, see chapter 7DMA. # 13 PARALLEL PORTS ETRAX 100LX has two parallel ports for the connection of high-speed peripheral devices. These ports are designated p0 and p1 respectively and the characteristics and operating principles of both ports are similar. The parallel ports can be used through register access or internal direct memory access (DMA). The ports can be configured to communicate with compatible peripherals by using various protocols, including: - IBM XT/AT compatible Centronics; - IBM PS/2 compatible Centronics; - Hewlett Packard Fast Mode: - Fastbyte protocol; - IEEE 1284 Byte, Nibble, Extended Capability Port (ECP), and Enhanced Parallel Port (EPP) modes; - ECP wide (16-bit) mode. A port designated parallel port-W is available when ETRAX 100LX operates in the ECP wide (16-bit) mode. Parallel port-W uses the control and status signals of port p0, together with the 8-bit data lines of p0 and p1 to form a word-wide data bus. Inputs and outputs to and from the parallel ports are multiplexed on to the same pins as some other interface applications (See chapter 19.10 *Multiplexed Interfaces*). # 13.1 Parallel Port Registers The parallel ports are served by two sets of dedicated registers, one for each port. The required mode of operation and all operational parameters are established, written and read in these registers. The table below summarises the purpose of each register. | Registers | Function | |------------------------------------------|-----------------------------------------------------------------------------------------------------------------------| | R_PAR0_CTRL_DATA<br>R_PAR1_CTRL_DATA | 32-bit write-only registers containing discrete control bits and data for the respective port. | | R_PAR0_CTRL<br>R_PAR1_CTRL | $8\mbox{-bit}$ write-only registers for the selection of port control signals oe, seli, autofd, strb and init. | | R_PAR0_STATUS_DATA<br>R_PAR1_STATUS_DATA | 32-bit read-only registers containing status bits and data for the respective port. | | R_PAR0_STATUS<br>R_PAR1_STATUS | 16-bit read-only registers containing status bits for the respective port. | | R_PAR0_CONFIG<br>R_PAR1_CONFIG | 32-bit write-only registers for configuration and control of each port. | | R_PAR0_DELAY<br>R_PAR1_DELAY | 32-bit write-only registers in which data transfer timing periods are set individually for each port. | | R_PAR_ECP16_DATA | In ECP wide (16_bit) mode, this read/write register contains the last data word sent or received at parallel port p0. | For more detailed information on the parallel port registers, please refer to chapter 18.10 *Parallel Port Registers*. # 13.2 Modes of Operation The modes of operation supported by ETRAX 100LX are: - IEEE 1284 Compatibility (Centronics) mode; - IBM Fastbyte; - IEEE-1284 Nibble mode; - IEEE-1284 Byte mode; - IEEE-1284 ECP mode; - ECP wide (16-bit) mode (parallel port-W); - IEEE 1284 EPP mode; - Manual mode this is the default mode of ETRAX 100LX see the note below. Note: 1 To switch to any other mode within an IEEE 1284 transaction, a negotiation phase is necessary. The negotiation phase, as well as termination and host recovery, are not supported in ETRAX 100LX and therefore it must be set up by software in the Manual mode. ### 13.2.1 IEEE-1284 Compatibility (Centronics) Mode The IEEE-1284 Compatibility (Centronics) mode is a simplex mode for forward data transfers (ETRAX 100LX to peripheral). The significant signals used by the parallel ports in Compatibility (Centronics) mode, and the corresponding signal names at the multiplexed I/O interface, are listed in the table below. | Interface Pin Name | | | | Origin of | |--------------------|-------------|---------|------------------------------------------------------------------------------------------------------------------|-------------| | Port_0 | Port_1 | Signal | Description of Signal | Signal | | p0d7 - p0d0 | p1d7 - p1d0 | D7:D0 | Data byte from port to peripheral. | ETRAX 100LX | | p0strobe | p1strobe | nStrobe | Strobe signal. Set low to initiate a data transmission. | ETRAX 100LX | | p0ack | p1ack | nAck | $\label{thm:eq:hammer} \mbox{Handshake line. Set low to indicate that the peripheral is ready to receive data.}$ | Peripheral | | p0busy | p1busy | Busy | Handshake line. Set high to indicate that the peripheral is busy and thus unable to receive data. | Peripheral | In the Compatibility (Centronics) mode only, ETRAX 100LX can be configured for different methods of handshaking with acknowledgment signal **nAck**. Each port's response to **nAck** is established by **oe\_ack** (bit 3) or **ign\_ack** (bit 4) in the port's configuration register R\_PAR0\_CONFIG or R\_PAR1\_CONFIG respectively. **Note: 2** The **oe\_ack** bit and the **ign\_ack** bit cannot both be asserted (set to 1), otherwise a conflict will occur. #### Bit oe ack asserted When a data byte is ready, ETRAX 100LX checks that the **Busy** signal is not asserted, confirming that the peripheral can receive data. When setup time $T_{\text{SU}}$ elapses, ETRAX 100LX asserts **nStrobe** and the transfer of the data byte commences. The **nStrobe** signal remains low for the duration of $T_{\text{STRB}}$ , then the low/high transition of **nStrobe** initiates $T_{\text{HOLD}}$ . The data transfer continues until $T_{\text{HOLD}}$ elapses or until the peripheral asserts the **nAck** signal, whichever occurs last. Acknowledgment from the peripheral is thus necessary before ETRAX 100LX can place a new data byte on the bus. T<sub>SU</sub> can be set between 10 ns and 5 µs in steps of 20 ns. T<sub>STRB</sub> and T<sub>HOLD</sub> can be set between 20 ns and 5 µs in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved arrow represents a sequential dependency. E = ETRAX 100LX (host) P = peripheral Figure 13-1 Compatibility (Centronics) Mode Timing with nAck Succeeding $T_{HOLD}$ $T_{su}$ can be set between 10 ns and 5 $\mu$ s in steps of 20 ns. $T_{\text{strb}}$ and $T_{\text{hold}}$ can be set between 20 ns and 5 us in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. E = ETRAX 100LX (host) P = Peripheral Figure 13-2 Compatibility (Centronics) Mode Timing with nAck Preceding $T_{HOLD}$ #### Bit oe\_ack deasserted When a data byte is ready, ETRAX 100LX checks the **Busy** signal to confirm that the peripheral can receive data. When $T_{\text{SU}}$ elapses, signal **nStrobe** is asserted by ETRAX 100LX to start the transfer of the data byte. The **nStrobe** signal remains low for the duration of T <sub>STRB</sub>, then the rising edge of **nStrobe** initiates $T_{\text{HOLD}}$ . The data transfer continues until $T_{\text{HOLD}}$ elapses, irrespective of the state of the **nAck** signal. In this configuration, ETRAX 100LX waits for an acknowledgment from the peripheral before placing the next data byte on the bus. The low/high transition of the **nAck** signal is necessary to trigger the next assertion of **nStrobe**. T<sub>su</sub> can be set between 10 ns and 5 us in steps of 20 ns. $T_{\text{strb}}$ and $T_{\text{hold}}$ can be set between 20 ns and 5 us in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. E = ETRAX 100LX (host) P = Peripheral Figure 13-3 Compatibility (Centronics) Mode Timing with Byte Transfers Terminated by $T_{HOLD}$ For this example to work, the **ign** ack bit must be set to 0 (wait). ### Bit ign\_ack asserted If the port is configured to ignore the **nAck** signal, only the **Busy** signal is monitored by ETRAX 100LX. When a data byte is ready, ETRAX 100LX checks the **Busy** signal to confirm that the peripheral can receive data. When setup time $T_{\text{SU}}$ elapses, ETRAX 100LX asserts **nStrobe** and the data transfer commences. The **nStrobe** signal remains low for the duration of T $_{\text{STRB}}$ , then its rising edge initiates $T_{\text{HOLD}}$ . The data transfer stops when $T_{\text{HOLD}}$ elapses. $T_{su}$ can be set between 10 ns and 5 $\mu$ s in steps of 20 ns. $T_{\text{strb}}$ and $T_{\text{hold}}$ can be set between 20 ns and 5 us in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. E = ETRAX 100LX (host) P = Peripheral Figure 13-4 Compatibility (Centronics) Mode Timing - Ignore nAck #### Compatibility (Centronics) mode time periods The data setup time ( $T_{\text{SU}}$ ), the strobe time ( $T_{\text{STRB}}$ ), and the data hold time ( $T_{\text{HOLD}}$ ) are set individually for each port in register R\_PAR0\_DELAY or R\_PAR1\_DELAY respectively. ### 13.2.2 Fastbyte Mode Fastbyte is a simplex mode for forward data transfer (ETRAX 100LX to peripheral) with four-phase handshaking. The significant signals used by the parallel ports in Fastbyte mode, and the corresponding signal names at the multiplexed I/O interface, are listed in the table below. | Interface Pin Name | | | | Origin of | |--------------------|-------------|---------|---------------------------------------------------------------------------------------------------|-------------| | Port_0 | Port_1 | Signal | Description of Signal | Signal | | p0d7 - p0d0 | p1d7 - p1d0 | D7:D0 | Data byte from port to peripheral. | ETRAX 100LX | | p0strobe | p1strobe | nStrobe | Strobe signal. Set low to initiate a data transmission. | ETRAX 100LX | | p0ack | p1ack | nAck | thm:eq:handshake line. Set low to indicate that the peripheral is ready to receive data. | Peripheral | | p0busy | p1busy | Busy | Handshake line. Set high to indicate that the peripheral is busy and thus unable to receive data. | Peripheral | When data is ready ETRAX 100LX checks that the **Busy** signal is not asserted, confirming that the peripheral can receive data. After setup time $T_{\text{SU}}$ has elapsed, ETRAX 100LX asserts the **nStrobe** signal. When the peripheral asserts **nAck**, ETRAX 100LX de-asserts **nStrobe** and the data transfer ceases. $T_{su}$ can be set between 10 ns and 5 $\mu$ s in steps of 20 ns. The curved lines represent sequential dependencies. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. E = ETRAX 100LX (host) P = Peripheral Figure 13-5 Fastbyte Mode Timing #### Fastbyte mode time periods For both ports, setup time $T_{\text{SU}}$ is configurable in the respective internal register R\_PAR0\_DELAY or R\_PAR1\_DELAY (See chapter 18.10 *Parallel Port Registers*). #### 13.2.3 IEEE-1284 Nibble Mode This is a simplex mode for reverse data transfers only (peripheral to ETRAX 100LX). The significant signals used by the parallel ports in Nibble mode, and the corresponding signal names at the multiplexed I/O interface, are listed in the table below. | Interface Pin Name | | | | Origin of | |--------------------|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | Port_0 | Port_1 | Signal | Description of Signal | Signal | | p0autofd | p1autofd | HostBusy | Handshake line. Set low to indicate that the respective port is ready to receive data, and high to indicate that the port has received a nibble. | ETRAX 100LX | | p0ack | p1ack | PtrClk | Handshake line. Set low to indicate a valid nibble, and high to acknowledge that the respective port has received a nibble. | Peripheral | | p0fault | p1fault | nDataAvail | Used for data bit 0, then 4. | Peripheral | | p0select | p1select | XFlag | Used for data bit 1, then 5. | Peripheral | | p0perror | p1perror | AckDataReq | Used for data bit 2, then 6. | Peripheral | | p0busy | p1busy | PtrBusy | Used for data bit 3, then 7. | Peripheral | A peripheral requests attention from ETRAX 100LX with the initial handshaking between signals **PtrClk**, **HostBusy** and **AckDataReq**, which generates an interrupt to the respective parallel port (**par0\_peri** for port p0, **par1\_peri** for port p1). ETRAX 100LX responds to the interrupt when it is ready to receive data (See section 13.3 *Parallel Port Interrupts*). The transfer of data takes place on the status signal lines in two cycles, one nibble at a time. Bits 0 to 3 are sent first and bits 4 to 7 follow after a handshake between **PtrClk** and **HostBusy**. The data bus **D7:D0** and the **nStrobe** signal are not used in IEEE 1284 Nibble mode. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. Figure 13-6 Nibble Mode Timing ### 13.2.4 IEEE-1284 Byte Mode This is a simplex mode for reverse data transfers (peripheral to ETRAX 100LX). The procedure is similar to the IEEE-1284 Nibble mode, the difference being that an entire byte is transferred simultaneously on the data bus. The significant signals used by the parallel ports in this mode, and the corresponding signal names at the multiplexed I/O interface, are listed in the table below. | Interface Pin Name | | | | Origin of | |--------------------|-------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | Port_0 | Port_1 | Signal | Description of Signal | Signal | | p0d7 - p0d0 | p1d7 - p1d0 | D7:D0 | Data bytes from peripheral to the respective port. | Peripheral | | p0perror | p1perror | AckDataReq | Set low to acknowledge that the respective port is ready. | Peripheral | | p0autofd | p1autofd | HostBusy | Handshake line. Set low to indicate that the respective port is ready to receive a byte, and high to indicate that the port has received the byte. | ETRAX 100LX | | p0strobe | p1strobe | HostClk | Set low at the end of each byte transfer to indicate that the respective port has received a byte. | ETRAX 100LX | | p0ack | p1ack | PtrClk | Handshake line. Set low to indicate a valid byte on the data lines, and high to acknowledge that the respective port has received a byte. | Peripheral | | p0fault | p1fault | nDataAvail | Set low by peripheral to indicate that data is available. | Peripheral | Handshaking is realized by the **PtrClk** signal controlled by the peripheral, and the **HostBusy** signal controlled by ETRAX 100LX. Signal **HostClk** is pulsed low by ETRAX 100LX at the end of each byte transfer to indicate that the byte has been received. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-7 IEE-1284 Byte Mode Timing ### 13.2.5 IEEE-1284 ECP Mode (Forward and Reverse) The ECP mode supports half-duplex (forward and reverse), parallel data exchange between ETRAX 100LX and a peripheral, at transfer rates of up to 6 Mbyte/s. The protocol provides for separate data and command cycles, and two types of command cycle: data compression by Run Length Encoding (RLE) implemented in hardware; channel addressing, which must be handled in software. The significant signals used by the parallel ports in the 1284 ECP mode, and the corresponding signal names at the multiplexed I/O interface, are listed in the table below. | Interface Pin Name | | | | Origin of | |--------------------|-------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | Port_0 | Port_1 | Signal | Description of Signal | Signal | | p0d7 - p0d0 | p1d7 - p1d0 | D7:D0 | Carries data bi-directionally (half-duplex). | Both | | p0strobe | p1strobe | HostClk | Handshakes with <b>PeriphAck</b> to transfer data or addresses in the forward direction. Set low to indicate valid data, and set high to clock data/addresses to the peripheral. | ETRAX 100LX | | p0ack | p1ack | PeriphClk | Handshakes with $\boldsymbol{HostAck}$ to transfer data or addresses in the reverse direction. | Peripheral | | p0autofd | p1autofd | HostAck | HostAck Provides command/data status in the forward direction. Handshakes with PeriphClk to transfer data in the reverse direction. Set high to indicate a data cycle. | | | p0busy | p1busy | PeriphAck | Handshakes with <b>HostClk</b> to transfer data or addresses in the forward direction. Provides command/data status in the reverse direction. | Peripheral | | p0init | p1init | nReverseRequest | Set low to switch channel to reverse direction. | ETRAX 100LX | | p0perror | p1perror | nAckReverse | Set low to acknowledge <b>nReverseRequest</b> . | Peripheral | | p0fault | p1fault | nPeriphRequest | Set low to indicate that reverse data is available. | Peripheral | The **HostAck** signal is used to distinguish between data and command cycles. When **HostAck** is asserted, a data cycle is taking place: when **HostAck** is low a command cycle is taking place. During a command cycle, bit 7 of the data byte is used to indicate RLE or channel addressing. When bit 7 is set to 0, a run length count is being sent: when bit 7 is set to 1, a channel address is being sent. The timing diagram below shows the transfer of data and commands in the forward direction, followed by a transfer of data and commands in the reverse direction. $T_{SU}$ can be set between 10 ns and 5 $\mu s$ in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-8 ECP Mode Timing #### **ECP** mode time periods For both ports, setup time $T_{\text{su}}$ is configurable in the respective internal register R PAR0 DELAY or R PAR1 DELAY. #### Stall detection In ECP mode, a stall condition occurs if the peripheral is unable to accept a data byte sent by ETRAX 100LX. In this event ETRAX 100LX can abort the data transfer by asserting signal **nReverseRequest**. Regardless of whether the peripheral has already accepted the byte, it discards the byte and acknowledges ETRAX 100LX by asserting **nAckReverse**. ETRAX 100LX responds by de-asserting **nReverseRequest**. Stall detection can be implemented in software by means of the tr\_rdy bit (17), in register R\_PAR0\_STATUS\_DATA or R\_PAR1\_STATUS\_DATA. This bit is controlled exclusively by the respective parallel port. It is set to 1 when the port reads a new data byte, and to 0 when the software writes to R\_PAR0\_CTRL\_DATA (7:0) or R\_PAR1\_CTRL\_DATA (7:0). The stall condition can therefore be detected by writing to the control and data register, wait for a period to elapse (e.g. one second), and then read the status of tr\_rdy. If this bit is set to 0, then data has not been sent. An example of the code necessary to implement stall detection in ECP mode when using DMA is: ``` while (dma transfer is not ready) { WRITE to R_PARn_CTRL_DATA.data WAIT (e.g. 1s) READ R_PARn_STATUS_DATA.tr_rdy if (tr_rdy==0) { stall } } ``` A similar work-around can be devised to implement stall detection in ECP mode when using registers. ### 13.2.6 ECP Wide (16-Bit) Mode The ECP wide (16-bit) mode is not an IEEE 1284 mode. It is a feature of ETRAX 100LX that is almost identical to the IEEE 1284 ECP mode, except that data words are transferred instead of bytes. ECP wide (16-bit) mode is implemented in parallel port p0 only. Run Length Encoding (RLE) is not supported in this mode. The significant signals used by parallel port-W, and the corresponding signal names at the multiplexed I/O interface, are listed below. | Interface Pin<br>Parallel Port-W | Signal | Description of Signal | Origin of<br>Signal | |----------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------| | p0d15 - p0d0 | D15:D0 | Carries 16-bit data bi-directionally (half-duplex). | Both | | p0perror | nAckReverse | Asserted (0) to acknowledge $nReverseRequest$ ( $\overline{p0init}$ ). | Peripheral | | p0autofd | HostAck | Provides command/data status in the forward direction. Handshakes with <b>PeriphClk</b> to transfer data in the reverse direction. Set high to indicate a data cycle. | ETRAX 100LX | | p0strobe | HostClk | Handshakes with <b>PeriphAck</b> to transfer data in the forward direction. Set low to indicate valid data, and set high to clock data to the peripheral. | ETRAX 100LX | | p0ack | PeriphClk | Handshakes with <b>HostAck</b> to transfer data in the reverse direction. | Peripheral | | p0busy | PeriphAck | Handshakes with <b>HostClk</b> to transfer data in the forward direction. Provides command/data status in the reverse direction. | Peripheral | | p0fault | nPeriphRequest | Set low to indicate that reverse data is available. | Peripheral | | <del>p0init</del> | nReverseRequest | Set low to switch channel to reverse direction. | ETRAX 100LX | ### ECP wide (16-bit) register configuration Only parallel port p0 controls the ECP wide (16-bit) mode. The mode is enabled by bit 10 (wide) in port p0 configuration register R\_PAR0\_CONFIG and bit 2 (par0), bit 7 (par1) and bit 31 (par\_w) in general configuration register R\_GEN\_CONFIG. The following truth table shows the required bit settings. | R_GEN_CONFIG<2><br>par0 | R_GEN_CONFIG<7><br>par1 | R_GEN_CONFIG<31><br>par_w | R_PAR0_CONFIG<10> wide | Mode | |-------------------------|-------------------------|---------------------------|------------------------|----------| | 0 | X | 0 | X | | | 1 | X | 0 | 0 | ECP | | 1 | 0 | 1 | 1 | ECP wide | All bit combinations other than those shown above are forbidden. $T_{SU}$ can be set between 10 ns and 5 $\mu s$ in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-9 ECP Wide (16-bit) Mode Timing The data lines of both parallel ports are used for data transfers in ECP wide (16-bit) mode. A multiplexer, controlled by the wide signal, places the upper byte (**D15:D8**) of the data word on to the data lines of port p1. A dedicated read/write register R\_PAR\_ECP\_16\_DATA stores the last 16-bit data word sent or received. #### ECP wide (16-bit) mode time periods Setup time $T_{SU}$ is configurable in register R\_PAR0\_DELAY. #### 13.2.7 EPP Mode The IEEE Enhanced Parallel Port (EPP) protocol is for high-speed, half-duplex (forward and reverse), parallel data exchange between ETRAX 100LX and a peripheral. All activities are controlled by ETRAX 100LX, which first selects a register within a peripheral, then performs a series of asynchronous read/write operations with the selected register. The significant signals used by the parallel ports in the EPP mode, and the corresponding signal names at the multiplexed I/O interface, are summarised in the table below. | Interface Pin Name | | | | Origin of | | |--------------------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------|--| | Port_0 | Port_1 | Signal | Description of Signal | Signal | | | p0d7:p0d0 | p1d7:p1d0 | D7:D0 | Carries 8-bit data/addresses bi-directionally. | Both | | | p0selectin | p1selectin | nAStrb | Address strobe. Set low when address bytes are being written or read. Set high when data bytes are being written or read. | ETRAX 100LX | | | p0autofd | p1autofd | nDStrb | Data strobe. Set low when data bytes are being written or read. Set high when address bytes are being written or read. | ETRAX 100LX | | | p0strobe | p1strobe | nWrite | Selects write cycles. Set low when address/data bytes are being written. Set high when address/data bytes are being read. | ETRAX 100LX | | | p0busy | p1busy | nWait | Handshake signal. Set low to indicate that a read or write cycle can commence. Set high to indicate that a read or write cycle can terminate. | Peripheral | | #### **EPP** write modes To meet the requirements of the IEEE 1284 EPP protocol, ETRAX 100LX offers three different EPP write modes (1, 2 and 3). The required mode is established in registers R\_PAR0\_CONFIG and R\_PAR1\_CONFIG. In the EPP write modes, ETRAX 100LX asserts the **nWrite** signal, places a data or address byte on the data bus, and asserts the corresponding strobe signal (**nDStrb** for data: **nAStrb** for an address). Within a response time, the peripheral signifies that it is ready to receive the data/address byte by de-asserting the **nWait** signal. ETRAX 100LX responds by de-asserting **nDStrb/nAStrb** to latch the data/address into the peripheral device. The peripheral acknowledges the end of the cycle and signifies that it is ready for the next cycle by asserting the **nWait** signal. Timing diagrams of EPP write modes 1 to 3 are given in Figures 14-10 to 14-12 that follow. $T_{su}$ can be set between 10 ns and 5 ys in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-10 EPP Address/Data Write Mode 1 Timing $T_{su}$ can be set between 10 ns and 5 ys in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-11 EPP Address/Data Write Mode 2 Timing T<sub>su</sub> can be set between 10 ns and 5 ys in steps of 20 ns. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-12 EPP Address/Data Write Mode 3 Timing #### EPP address/data read cycles In the EPP address or data write mode, ETRAX 100LX uses the data lines to read an address or data byte from the peripheral. ETRAX 100LX signifies a read cycle by asserting the appropriate strobe signal (nAStrb for an address: nDStrobe for data), and de-asserting the nWrite signal. When the peripheral responds, the strobe (nAStrobe or nDStrobe) is used to latch the address or data byte from the peripheral. The peripheral uses nWait for handshaking at the beginning and end of the write cycle. The prefix n in a signal name represents a negative (active-low) signal in the IEEE 1284 Standard. The curved lines represent sequential dependencies. E = ETRAX 100LX (host) P = Peripheral Figure 13-13 EPP Address/Data Read Cycle Timing #### EPP configuration in the mode registers The read/write functionality of the EPP mode is implemented by a configuration of the parallel port registers. Bits 11 and 2 to 0 in register R\_PAR0\_CONFIG or R\_PAR1\_CONFIG respectively are used to choose the read-write mode, where bits 2 to 0 are the mode field and bit 11 acts as the extended mode selector. The choice of an address or data transfer cycle is realized by bit 3 in the respective configuration register. #### 13.2.8 Manual Mode In the context of ETRAX 100LX, Manual mode is the configuration of the parallel ports by means of customised software. This feature enhances the versatility of ETRAX 100LX by permitting the implementation of parallel data transfer protocols not otherwise supported within the IEEE 1284 standard. To facilitate the Manual mode, all signals to and from the parallel ports are programmable. When Manual mode is operational these discrete signals, and the data buses, are read/written by software through the mode registers. The software-programmable signals are: | Port p0 | Port p1 | Port-W | |-------------|-------------|--------------| | p0perror | p1perror | p0perror | | p0ack | p1ack | p0ack | | p0busy | p1busy | p0busy | | p0fault | p1fault | p0fault | | p0select | p1select | p0select | | p0data_oe | p0data_oe | p0data_oe | | p0selectin | p1selectin | p0selectin | | p0autofd | p1autofd | p0autofd | | p0strobe | p1strobe | p0strobe | | p0init | p1init | p0init | | p0d7 - p0d0 | p1d7 - p1d0 | p0d7 - p0d0 | | | | p0d15 - p0d8 | Table 13-1 Software-Controlled Signals in Manual Mode Please refer to chapter 19.10 *Multiplexed Interfaces* for details of the multiplexed I/O interface that includes these signals. ## 13.3 Parallel Port Interrupts Both parallel ports can generate a number of different interrupts, if configured to do so in the Interrupt Mask registers. ## 13.3.1 Peripheral Interrupt The parallel ports can be configured so that in the Nibble, Byte, ECP and ECP wide (16-bit) modes, a peripheral can attract the attention of ETRAX 100LX through signal sequences. The peripheral requests attention by means of handshaking between the **PtrClk**, **HostBusy** and **AckDataReq** signals, which generates the interrupt. ETRAX 100LX acknowledges the interrupt when it is ready to receive data. The peripheral interrupt for parallel port p0 is enabled in the **par0\_peri** field (bit 10) of the R\_IRQ\_MASK0\_SET register. It is cleared by reading the **peri\_int** field (bit 24) in register R PAR0 CTRL DATA. The peripheral interrupt for parallel port p1 is enabled in the **par1\_peri** field (bit 18) of the R\_IRQ\_MASK1\_SET register. It is cleared by reading the **peri\_int** field (bit 24) in register R\_PAR1\_CTRL\_DATA. ## 13.3.2 ECP Command Interrupt The parallel ports can be configured to generate an interupt in ECP reverse mode in response to the start of a command cycle from the peripheral. The ECP command interrupt for parallel port p0 is enabled in the **par0\_ecp\_cmd** field (bit 11) of the R\_IRQ\_MASK0\_SET register. It is cleared by reading the **ecp\_cmd** field (bit 8) in register R\_PAR0\_STATUS\_DATA. The ECP command interrupt for parallel port p1 is enabled in the **par1\_ecp\_cmd** field (bit 19) of the R\_IRQ\_MASK1\_SET register. It is cleared by reading the **ecp\_cmd** field (bit 8) in register R\_PAR1\_STATUS\_DATA. ## 13.3.3 Data Available Interrupt The parallel ports can be configured to generate an interrupt when a port has input data available. When DMA is used for the data transfer, this interrupt indicates that at least one byte has been received since the interrupt was last cleared. The data available interrupt for parallel port p0 is enabled in the **par0\_data** field (bit 9) of the R\_IRQ\_MASK0\_SET register. It is cleared by reading the **data** field (bits 7:0) in register R\_PAR0\_CTRL\_DATA. The data available interrupt for parallel port p1 is enabled in the **par1\_data** field (bit 17) of the R\_IRQ\_MASK1\_SET register. It is cleared by reading the **data** field (bits 7:0) in register R\_PAR1\_CTRL\_DATA. ## 13.3.4 Ready Interrupt The parallel ports can be configured to generate an interrupt when a port is ready to get new data for transmission. The ready interrupt for parallel port p0 is enabled in the **par0\_ready** field (bit 8) of the R\_IRQ\_MASK0\_SET register. It is cleared by writing the **data** field (bits 7:0) in register R\_PAR0\_CTRL\_DATA. The ready interrupt for parallel port p1 is enabled in the **par1\_ready** field (bit 16) of the R\_IRQ\_MASK1\_SET register. It is cleared by writing the **data** field (bits 7:0) in register R\_PAR1\_CTRL\_DATA. **Note: 3Note:** The par0\_ready/par1\_ready bits should be masked off when the DMA is used for data transfers. #### 13.3.5 EPP Interrupts A peripheral gains the attention of the parallel port by means of a single interrupt request on the port's peripheral acknowledgement line ( $\overline{\textbf{p0ack}}$ and $\overline{\textbf{p1ack}}$ ). To generate an interrupt, the acknowledgement signal is pulsed low for period $T_p$ (0.5 ms). Although an interrupt can be asserted at any time it is independent of, and does not interfere with, the EPP cycles. The status of the EPP interrupt for parallel port p0 is indicated by the **ack** field (bit 27) of register R\_PAR0\_STATUS\_DATA and the corresponding field (bit 11) of register R\_PAR0\_STATUS. The status of the EPP interrupt for parallel port p1 is indicated by the **ack** field (bit 27) of register R\_PAR1\_STATUS\_DATA and the corresponding field (bit 11) of register R\_PAR1\_STATUS. # 14 SHARED RAM INTERFACE The shared RAM interface handles 8-bit and 16-bit transfers between an external device and the system SRAM. The interface operates with standard SRAM. Data transfers are controlled by an asynchronous handshake protocol. Figure 14-1 How to Connect for Shared RAM The address from the external device is supplied to the SRAM through external multiplexers, except for address bit 0 and 1 that are multiplexed internally. Shared <u>RAM</u> interface cycles are like normal bus cycles, except that the **a\_sel** signal on the **s0atn** pin is high during the cycle. Shared RAM interface cycles are never packed together in bursts. The cycles can be 8-bit or 16-bit wide. 16-bit cycles are always 16-bit aligned. Figure 14-2 Shared RAM Timing # 14.1 Shared RAM Interface Configuration | Register | Function | |---------------------|-----------------------------------------------------------------------------------------------| | R_SHARED_RAM_CONFIG | A 32-bit write only register to configure and enable the shared RAM interface. | | R_SHARED_RAM_ADDR | A 32-bit write only register that sets bits 29-8 of the base address for the shared RAM area. | Table 14-1 Shared RAM Interface Registers To initiate the Shared RAM interface, first write to the R\_GEN\_CONFIG register, then to R\_SHARED\_RAM\_ADDR, and finally to R\_SHARED\_RAM\_CONFIG. For more information see chapter 18.5 *Shared RAM Interface Registers*. # 14.2 Shared RAM Interrupts One interrupt signal in <u>each</u> direction is provided. The incoming interrupt set on the Shared RAM interface <u>intio</u> pin is negative edge triggered. The interrupt is cleared by setting the <u>clri</u> bit of the R\_SHARED\_RAM\_CONFIG register. The interrupt going out, set on the Shared RAM interface pin **pr\_int**, is active low and stays low for 600 ns. This interrupt is generated if the **pint** field in R\_SHARED\_RAM\_CONFIG is set to **int**. # 15 TIMERS ## 15.1 General The timer block consists of: - A fixed clock divider - Clock prescaling (i.e. a programmable clock divider) - Two programmable 8-bit timers: timer0 and timer1 - One watchdog timer The fixed clock divider is also used as a baud rate generator for the asynchronous and synchronous serial ports. The two programmable timers can be cascaded to form one 16-bit timer. # 15.2 Timer Registers Table 15-1 below provides a brief description of the timer registers. For more detailed information, please see chapter 18.4 *Timer Registers*. | Register | Function | |--------------------|------------------------------------------------------------------------------------------------------------------------------------| | R_TIMER_CTRL | A 32-bit write only register to control the operation, clock selection, and divide factor for timer0 and timer1. | | R_TIMER_DATA | A 32-bit read only register for the high and low byte of the fixed clock divider, and the current value of timer0 and timer1. | | R_TIMER01_DATA | A 16-bit read only register for the combined count value of timer0 and timer1. Typically used when the timers are cascade coupled. | | R_TIMER0_DATA | A byte size read only register for the current count value of timer0. | | R_TIMER1_DATA | A byte size read only register for the current count value of timer1. | | R_WATCHDOG | A 32-bit write only register for enabling and restarting the watch<br>dog timer. $\label{eq:constraint}$ | | R_CLOCK_PRESCALE | A 32-bit write only register for the divide factor for timer- and serial clock prescaling. | | R_TIMER_PRESCALE | A 16-bit write only register for the divide factor for timer clock prescaling. | | R_PRESCALE_STATUS | A 32-bit read only register for the current value of the serial- and timer divide value. $$ | | R_TIM_PRESC_STATUS | A 16-bit read only register for the current count value of the timer divide factor. | Table 15-1 Timer registers # 15.3 Clock Prescaling: The Programmable Clock Divider The programmable clock divider divides a 25MHz clock with a 16-bit value. This 16-bit value ranges from 2 to 65535, and results in a new clock available for the timers that ranges from 12.5MHz down to 381.5Hz. The value for the new available clock is written and read in the internal register R\_TIMER\_PRESCALE. ## 15.4 Programmable Timers #### 15.4.1 Timer Operation The ETRAX 100LX has two programmable timers, timer0 and timer1, which are configured in the register R\_TIMER\_CTRL. Each one is an 8-bit binary down counter. Each timer can be loaded with a divide factor between 1 and 256, in R\_TIMER\_CTRL. When started, the timer: - 1 Counts down to 1 - **2** Generates an interrupt (timer0 or timer1 respectively) - **3** Restarts from the programmed divide factor If the divide factor is changed while the timer is running, it will not take effect until the ongoing count has expired. Each timer has two mode fields that control its operation: - timer0: tm0 and i0 - timer1: tm1 and i1 The **tm0** or **tm1** mode field controls the following: | Timer mode: | Operation: | |-------------|---------------------------------------------------| | 00 | Stop the timer and load it with the divide factor | | 01 | Stop the timer and preserve current count value | | 10 | Run | | 11 | Reserved, do not use | Each timer also has a **i0** or **i1** (clear interrupt) mode field. Setting it to 1 clears the interrupt, and setting it to 0 has no effect. The current count value of both timers can be read in R\_TIMER\_DATA. ## 15.5 Timer Input Clock The timer input clock can be individually selected for each timer. In addition to the programmable clock, the following input frequencies can be selected from the fixed clock divider: | Clock sel: | Nominal<br>frequency:<br>(Note 1) | |------------|-----------------------------------| | 0 | 0.3 kHz | | 1 | 0.6 kHz | | 2 | 1.2 kHz | | 3 | 2.4 kHz | | 4 | 4.8 kHz | | 5 | 9.6 kHz | | 6 | 19.2 kHz | | 7 | 38.4 kHz | | 8 | 57.6 kHz | | 9 | 115.2 kHz | | 10 | 230.4 kHz | | 11 | 460.8 kHz | | 12 | 921.6 kHz | | 13 | 1843.2 kHz | | 14 | 6250.0 kHz | **Note 1:** The actual frequency is 64 ppm higher than the nominal value (given an exact clock reference input), for all frequencies except 6250 kHz. # 15.5.1 Timer0 Input Clock Timer0 can use the external clock by connecting to the general IO pin **pb6**, or it can use the prescaled clock. In order to use the prescaled clock (from the programmable clock divider) or the external clock, the **clksel0** field of R\_TIMER\_CTRL must be set to **flexible** (15), as shown in table 15-2 below. To use the prescaled clock, **presc\_ext** must be cleared, and to use the external clock **presc\_ext** must be set. | clksel0 | presc_ext | clock rate | |---------|-----------|-----------------------| | 15 | 0 | timer prescaled clock | | 15 | 1 | external clock | Table 15-2 clksel0 settings When using the external clock, timer0 will act as a pulse counter with a maximum of 256 pulses. The external clock must be enabled in R\_GEN\_CONFIG\_II. Timer0 can also be cascaded with timer1, resulting in a maximum of 65536 pulses. ## 15.5.2 Timer1 Input Clock In order to use the prescaled clock (from the programmable clock divider), **presc\_timer1** of R\_TIMER\_CTRL must be set: | presc_timer1 | clock rate | |--------------|-----------------------| | 0 | normal (default) | | 1 | timer prescaled clock | **Note 2:** Setting **presc\_timer1** in R\_TIMER\_CTRL overrides all settings on **clksel1**. #### 15.6 Cascade Mode The two programmable counters can be cascaded to form one 16-bit timer. Cascade mode is selected by setting the **clksel1** field for timer1 to **cascade0**. The **timer0** interrupt is used to signal the end count of the cascaded counter. The **timer1** interrupt is not used in cascade mode, and should be masked off in R\_IRQ\_MASKO\_SET. When the counters operate in cascade mode, the timer modes, **tm0** and **tm1**, should be set to the same value for both counters with one single write operation. # 15.7 Watchdog Timer When the watchdog timer is started, it generates an NMI if the watchdog is not restarted or stopped within 0.1 s. If it still is not restarted or stopped after an additional 3.3 ms, the watchdog timer resets the chip. The watchdog timer is stopped after reset. The watchdog timer is controlled by the register R\_WATCHDOG, which contains an **enable** field and a 3-bit **key** value. The effect of writing to the register is described in the table below: | Watchdog | Value written: | | | |----------|----------------|---------------|-----------------------------------| | state: | To enable: | To key: | Operation: | | stopped | 0 | X | No effect | | stopped | 1 | key_val | Start watchdog with key = key_val | | started | 0 | ~key (Note 3) | Stop watchdog | | started | 1 | ~key (Note 3) | Restart watchdog with key = ~key | | started | X | new_key_val | Change key to new_key_val | **Note 3:** '~' is the bitwise NOT operator. # 15.8 Timer Interrupts There are two timer interrupts, one each for timer0 and timer1. #### timer1 This interrupt is set whenever timer1 reaches its terminal count. It is cleared by setting the i1 field in R\_TIMER\_CTRL. #### timer0 This interrupt is set whenever timer0 reaches its terminal count. It is cleared by setting the **i0** field in timer register R\_TIMER\_CTRL. For more information about ETRAX 100LX interrupts, please refer to chapter 17 *Interrupts*. # 16 GENERAL I/O PORTS ETRAX 100LX has two 8-bit ports for handling general input/output signals. They are designated General port PA and General Port PB respectively. General Port PA is available for general I/O purposes and can also be used to handle externally-generated interrupts. The signals at General Port PB are multiplexed on to the same pins as some other interfaces and therefore these signals are only available when the multiplexed pins are not in use by other interfaces. In addition to General Ports PA and PB, the multiplexed interfaces make available a number of other discrete pins for general I/O purposes when the pins are not in use by other interfaces. Each of these pins can be considered as a discrete general I/O port. The general I/O ports are configured in software by means of dedicated registers (See section 16.4 *General I/O Registers*). Please see chapter 18.7 *General Port Configuration Registers* for detailed information on the general port configuration registers, and chapter 19 *Electrical Information* for information on the multiplexed interfaces. #### 16.1 General Port PA Eight signals (**pa7** to **pa0**) are available at General Port PA. The direction and level of each bit is individually configurable in fields **dir7** to **dir0** (bits 7 to 0 respectively) of register R\_PORT\_PA\_SET. When a direction field is set to 0, the data signal is an input: when a direction field is set to 1 the data signal is an output. The port can be read in register R\_PORT\_PA\_READ. The pins of General Port PA can supply a maximum current of 12 mA. The port can, therefore, drive light emitting diodes (LED) and similar components. Please refer to chapter 19.7 *Asynchronous Serial Port O Signals*, for more information on the general port configuration registers. Please refer to chapter 19.6 *General Port PA Signals*, for electrical information on General Port PA. #### 16.1.1 Interrupts at General Port PA Each bit in General Port PA can be configured as a masked interrupt as well as a general I/O signal. Eight external interrupts are thus available, all with the same internally generated vector number. The interrupts are level-triggered by active-high signals. Please refer to chapter 17.6 *Masked Interrupts with Internally Generated Vector Numbers* for detailed information on the interrupts at General Port PA. The interrupts at General Port PA are configured in a set of interrupt mask and status registers. Please refer to chapter 18.13 *Interrupt Mask and Status Registers* for detailed information on the interrupt mask and status registers. #### 16.2 General Port PB The configuration of General Port PB is more complex than that of General Port PA because the bits at General Port PB are multi-functional and the pins allocated to the port are multiplexed with signals from the following interfaces: - I2C Port - Peripheral chip-select (CSP) Port - SCSI Ports - Synchronous Serial Ports - USB Ports General Port **pb6** can also be used as an external baud rate clock input. In this case, the port should be configured as a general port input. For more information see chapter 11 *Asynchronous Serial Ports*. Only one function may be used on a pin at one time, and the configuration of these pins for General Port PB is prioritized. The general port has the lowest priority, then the CSP Port, then the other interfaces that use the pins as shown in the table below: | Lowest Priority | Next Highest Priority | Next Highest Priority | Highest Priority | |------------------------------------------------------|-----------------------|-----------------------|-------------------------------| | General Port PB | | | I2C Port | | pb0 | | | i2c_d | | General Port PB | | | I2C Port | | pb1 | | | i2c_clk | | General Port PB | CSP | | USB Port p1 | | pb2 | csp1 | | usb1_vpo | | General Port PB | CSP | | USB Port p1 | | pb3 | csp2 | | usb1_vmo | | General Port PB | CSP | Synch. Serial Port p1 | SCSI-8 port p0<br>SCSI-W Port | | pb4 | | ss1_out3 | | | | csp3 | ss1_in3 | s0enph | | General Port PB | CSP | | USB Port p1 | | pb5 | csp5 | | usb1_vm | | General Port PB<br>External baud rate clock<br>input | CSP | | | | pb6 | csp6 | | | | General Port PB | CSP | Synch. Serial Port p3 | SCSI-8 Port p1<br>SCSI-W Port | | pb7 | csp7 | ss3_out3<br>ss3_in3 | s0en1oid<br>s1enph | Please refer to chapter 19.10 *Multiplexed Interfaces* for details of the multiplexed interfaces. ## 16.2.1 Configuration of Signal Directions at General Port PB When General Port PB is in use, each bit is individually configurable in register R\_PORT\_PB\_SET and can always be read in register R\_PORT\_PB\_READ. Fields dir7 to dir0 (bits 15 to 8 respectively) in R\_PORT\_PB\_SET establish the direction of the corresponding data signal at General Port PB. When a direction field is set to 0, the data signal is an input: when a direction field is set to 1 the data signal is an output. #### 16.2.2 General Port PB and the I2C Interface Bits **pb0** and **pb1** of General Port PB can be used by the I2C interface, making it possible to run the I2C interface without conflict with other bits of the General Port PB byte. The I2C interface can use pin V15 for data signal **i2c\_d** and pin W16 for clock signal **i2c\_clk**. Consequently, if the I2C interface is configured and enabled, bits **pb0** and **pb1** of General Port PB are unavailable for I/O purposes. Selection of the I2C mode is made by the **i2c\_en** (bit 27) and **i2c\_oe** (bit 24) fields of register R\_PORT\_PB\_SET in accordance with the following table. | i2c_en | i2c_oe | Pin V15 | Direction | Pin W16 | Direction | |--------|--------|---------|-----------|---------|-----------| | 0 | X | pb0 | in/out | pb1 | in/out | | 1 | 0 | i2c_d | out | i2c_clk | out | | 1 | 1 | i2c_d | in | i2c_clk | out | ## 16.2.3 General Port PB and the Peripheral Chip-Select Signals The peripheral chip-select (CSP) Port can use any or all of the upper six bits (**pb7** to **pb2**) of General Port PB. Each of these bits can be set separately by chip-select enable fields (**cs7** to **cs2**) in register R\_PORT\_PB\_SET. If a chip-select enable field is set to 0, then the corresponding bit is configured as a general I/O signal. If a chip-select enable field is set to 1, then the corresponding bit is configured as a chip-select signal and is unavailable for general I/O purposes. When chip-select signals are in use, General I/O pins **pb7** to **pb5** become $\overline{csp7}$ to $\overline{csp5}$ and pins **pb4** to **pb2** become $\overline{csp3}$ to $\overline{csp1}$ . After system reset, these pins are inputs so they require the connection of external pull-up resistors. Note that pins $\overline{csp0}$ and $\overline{csp4}$ are always available, and are always outputs. The effects of certain chip-select enable fields are overridden if the following are enabled: - Synchronous Serial Ports (see 16.2.4); - SCSI Ports (see 16.2.5); - USB Ports (see 16.2.6). ## 16.2.4 General Port PB and the Synchronous Serial Ports In some of their modes, Synchronous Serial Ports p1 and p3 use General Port PB bits **pb4** and **pb7** respectively. The **syncser1** and **syncser3** fields of the R\_PORT\_PB\_SET register configure the connection of pins **pb4** and **pb7** to the synchronous serial ports. The effect of chip-select enable field **cs7** is overridden by the **syncser3** field in R\_PORT\_PB\_SET. Similarly field **cs4** is overridden by the **syncser1** field in R\_PORT\_PB\_SET. A configuration of **pb7** for use with SCSI-8 Port p1 or SCSI-W will override the **syncser3** field in R\_PORT\_PB\_SET. Similarly, a configuration of **pb4** for use with SCSI-8 port p0 or SCSI-W will override the **syncser1** field in R\_PORT\_PB\_SET. #### 16.2.5 General Port PB and the SCSI Ports The SCSI-8 Ports p0 and p1 use General Port PB bits **pb4** and **pb7** respectively. The SCSI-W Port uses both **pb4** and **pb7**. The **scsi0** and **scsi1** fields of the R\_PORT\_PB\_SET register configure the connection of pins **pb4** and **pb7** to the SCSI ports. The effect of chip-select enable field **cs7** is overridden by the **scsi1** field in R\_PORT\_PB\_SET. Similarly field **cs4** is overridden by the **scsi0** field in R\_PORT\_PB\_SET. #### 16.2.6 General Port PB and the USB Ports USB Port p1 uses three of the pins allocated to General Port PB. Consequently, when the USB port is enabled, bits **pb2**, **pb3** and **pb5** of General Port PB are unavailable for general I/O purposes. Similarly, when USB Port p1 is active, the effect of chip-select enable fields cs1, cs2 and cs5 are automatically overridden. #### 16.3 Discrete General Ports Some of the pins that are not used in a chosen configuration of ETRAX 100LX are available as discrete I/O ports. The signals available at these ports are designated **gn**, where **n** is a signal number within the range 0 to 31. When a discrete I/O port is available, its signal direction and/or data are individually configurable. For some of the discrete I/O ports, separate pins are used for the input and output signals. These ports are: - g1 to g7 - g25 to g31 The signal directions at the other discrete I/O ports can be set in register R\_GEN\_CONFIG. Fields **g24dir** (bit 27), **g16\_23dir** (bit 26), **g8\_15dir** (bit 25) and **g0dir** (bit 24) establish the signal direction at the corresponding discrete I/O port. When a direction field is set to 0, the signal is an input: when a direction field is set to 1 the signal is an output. The discrete I/O ports are written and read in the data field (bits 31 to 0) of register R\_PORT\_G\_DATA. For detailed information on these miscellaneous I/O ports, please refer to chapter 19.9 *Multiplexed Signal Groups*, which provides pin-by-pin listings for the multiplexed interfaces. # 16.4 General I/O Registers As noted above, the general I/O ports are served by a set of dedicated configuration registers. The table below summarizes the purpose of each register. | Register | Function | |---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R_PORT_PA_SET comprising: | A 32-bit, write-only register in which the upper 16 bits are reserved. | | R_PORT_PA_DATA | An 8-bit, write-only register formed from the lowest byte of the lower 16 bits of PA_PORT_PA_SET. The register contains the <b>data_out</b> byte to General Port PA. | | R_PORT_PA_DIR | An 8-bit, write-only register formed from the high byte of the lower 16 bits of PA_PORT_PA_SET. Each bit sets the direction (in or out) of a corresponding signal to or from General Port PA. | | R_PORT_PA_READ | A 32-bit, read-only register in which the upper 24 bits are reserved. The 8 low bits contain the <b>data_in</b> byte from General Port PA. | | R_PORT_PB_SET comprising: | A 32-bit, write-only register in which the upper two bits are reserved. $ \\$ | | R_PORT_PB_DATA | An 8-bit, write-only register formed from the lowest byte of PA_PORT_PB_SET. The register contains the <b>data_out</b> byte to General Port PB. | | R_PORT_PB_DIR | An 8-bit, write-only register formed from the second lowest byte of PA_PORT_PB_SET. Each bit sets the direction (in or out) of a corresponding signal to or from General Port PB. | | R_PORT_PB_CONFIG | An 8-bit, write-only register formed from the third lowest byte of PA_PORT_PB_SET. Six bits are used to configure <b>pb7</b> to <b>pb2</b> as chipselect or general I/O signals, and the other two bits determine whether bits <b>pb7</b> and <b>pb4</b> are used to carry SCSI signals. | | R_PORT_PB_I2C | An 8-bit, write-only register formed from the highest byte of PA_PORT_PB_SET, but with the upper two bits reserved. Four bits are used to configure the I2C interface, and the other two bits determine whether bits <b>pb7</b> and <b>pb4</b> are used to carry synchronous serial port signals. | | R_PORT_PB_READ | A 32-bit, read-only register in which the upper 24 bits are reserved. The 8 lowest bits contain the <b>data_in</b> byte from General Port PB. | For detailed information on the general port configuration registers, please refer to chapter 18.6 *General Configuration Registers*. # 17 INTERRUPTS Most of the interfaces of the ETRAX 100LX generate interrupts. Three types of interrupts are supported: - Non-maskable interrupts (NMI); - Maskable interrupts with internally generated vector numbers; - Maskable interrupts with external vector numbers. The NMI have the highest priority, and the maskable interrupts with external vector numbers have the lowest priority. All maskable interrupts with internally generated vector numbers have the same priority. # 17.1 Interrupt Masks There are two levels of interrupt masks: Figure 17-1 Interrupt Masks At one level, the individual bits of all interrupts except the NMI are masked. At the other level there is one composite mask bit for each vector number (i.e. one composite bit for each different internal interface). There are separate addresses for setting and clearing the mask bits and only asserted mask bits (those set to 1), are set or cleared (see section 17.4 Interrupt Registers). It is recommended that the software driver for each interface should control its own mask bits at the individual interrupt masking level, while general system functions control the composite vector number mask. Thus there is one mask bit on each level, even for those vectors that have one interrupt only. All interrupt masks are undefined after reset. They must be initialised before the interrupt is enabled in the CPU. ## 17.2 Interrupt Status The status of the individual interrupts can be read before and after they are gated with the interrupt mask. Registers R\_IRQ\_READ0 to R\_IRQ\_READ2 and R\_USB\_IRQ\_RD contain the interrupt bits prior to individual masking. Registers R\_IRQ\_MASK0\_RD to R\_IRQ\_MASK2\_RD and R\_USB\_IRQ\_MASK\_RD contain the interrupt bits after the individual mask. The status of the interrupt vector numbers can be read before and after they are gated with the composite mask. Register R\_VECT\_READ shows the interrupt vector number bits prior to composite masking. Register R\_VECT\_MASK\_RD shows the interrupt vector number bits after the composite mask. ## 17.3 USB Interrupts The USB is capable of generating a relatively large number of maskable interrupts with internally generated vector numbers. Consequently the USB interrupts are handled within the set of registers dedicated to the USB, as distinct from the set of registers entirely dedicated to interrupt handling. ## 17.4 Interrupt Registers The interrupt capability of ETRAX 100LX is supported by a dedicated set of interrupt mask and status registers. These registers are arranged in three sub-sets (designated 0 to 2) that contain different interrupt bits at the individual masking level, and a fourth sub-set for the vector number bits at the composite masking level. As previously noted, a sub-set of the R\_USB register set contains the USB interrupt bits at the individual masking level. This architecture is summarized in the tables below. | Register Sub-Set 0 | Register | Purpose | |---------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Handles the NMI and maskable interrupts for: | R_IRQ_MASK0_SET | A 32-bit, write-only register for setting the 29 maskable interrupt fields with internally generated vector numbers. Four fields handle multiple interrupt mask bits by means of the multiplexed interfaces. | | Ethernet error and<br>statistics counters<br>Network | R_IRQ_READ0 | A 32-bit, read-only register that contains the NMI and maskable interrupts. It shows the status of these interrupts prior to the individual mask. | | Network ATA Parallel port p0 Parallel port W Shared RAM SCSI-8 port p0 SCSI port W External interrupt External DMA Timers | R_IRQ_MASK0_RD | A 32-bit, read-only register that contains the NMI and maskable interrupts. It shows the status of these interrupts after the individual mask. | | | R_IRQ_MASK0_CLR | A 32-bit, write-only register for clearing the mask bits of the maskable interrupts that have been set in register R_IRQ_MASK0_SET. | Table 17-1 Interrupt registers: Register sub-set 0 | Register Sub-Set 1 | Register | Purpose | |----------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Handles SW-generated interrupts and the maskable interrupts for: | R_IRQ_MASK1_SET | A 32-bit, write-only register for setting the maskable interrupts with internally generated vector numbers. Of these, one field handles two interrupt mask bits by means of the multiplexed interfaces. | | Parallel port p1<br>SCSI-8 port p1<br>Async. serial ports<br>Sync. serial ports<br>General port PA | R_IRQ_READ1 | A 32-bit, read-only register that contains the maskable interrupts. It shows the status of these interrupts prior to the individual mask. | | | R_IRQ_MASK1_RD | A 32-bit, read-only register that contains the maskable interrupts. It shows the status of these interrupts after the individual mask. | | | R_IRQ_MASK1_CLR | A 32-bit, write-only register for clearing the mask bits of the maskable interrupts that have been set in register R_IRQ_MASK1_SET. | Table 17-2 Interrupt registers: Register sub-set 1 | Register Sub-Set 2 | Register | Purpose | |--------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------| | Handles all the interrupts for the DMA channels. | R_IRQ_MASK2_SET | A 32-bit, write-only register for setting the maskable DMA channel interrupts with internally generated vector numbers. | | | R_IRQ_READ2 | A 32-bit, read-only register for reading the maskable DMA interrupts. It shows the status of these interrupts prior to the individual mask. | | | R_IRQ_MASK2_RD | A 32-bit, read-only register that contains the maskable interrupts. It shows the status of these interrupts after the individual mask. | | | R_IRQ_MASK2_CLR | A 32-bit, write-only register for clearing the mask bits of the maskable interrupts that have been set in register R_IRQ_MASK2_SET. | Table 17-3 Interrupt registers: Register sub-set 2 | USB Register Sub-Set | Register | Purpose | |-----------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------| | Handles all the interrupts for the USB. | R_USB_IRQ_MASK_SET | A 16-bit, write-only register for setting the maskable USB interrupts with internally generated vector numbers. | | | R_USB_IRQ_RD | A 16-bit, read-only register for reading the maskable interrupts. It shows the status of these interrupts prior to the individual mask. | | | R_USB_IRQ_MASK_RD | A 16-bit, read-only register that contains the maskable interrupts. It shows the status of these interrupts after the individual mask. | | | R_USB_IRQ_MASK_CLR | A 32-bit, write-only register for clearing the mask bits of the maskable interrupts that have been set in register R_USB_IRQ_MASK_SET. | Table 17-4 Interrupt registers: USB Register sub-set | Vector Register Sub-Set | Register | Purpose | |--------------------------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------| | Handles the interrupt vector number bits at the composite masking level. | R_VECT_MASK_SET | A 32-bit, write-only register for setting the interrupt vector number bits. | | | R_VECT_READ | A 32-bit, read-only register for reading the interrupt vector number bits. It shows the status of these bits prior to the composite mask. | | | R_VECT_MASK_RD | A 32-bit, read-only register for reading the interrupt vector number bits. It shows the status of these bits after the composite mask. $ \\$ | | | R_VECT_MASK_CLR | A 32-bit, write-only register for clearing the interrupt vector number bits that have been set in register R_VECT_MASK_SET. | Table 17-5 Interrupt registers: Vector register sub-set Please see chapter 18.13 *Interrupt Mask and Status Registers* for detailed information on the interrupt mask and status registers, and 18.16 *Universal Serial Bus Interface Control Registers* for USB registers. ## 17.5 Non-Maskable Interrupts There are two sources of non-maskable interrupt: - The $\overline{\mathbf{nmi}}$ pin: - The watchdog timer. The source of an NMI request can be identified by reading registers R\_IRQ\_MASK0\_RD or R\_IRQ\_READ0. Both NMI have the internally generated vector number 0x21. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|--------------------------------------------------------------------|-------------------------------------------------------------------------| | nmi_pin | 31 | This interrupt is from the external $\overline{\mathbf{nmi}}$ pin. | This interrupt is cleared in the external unit. | | watchdog_nmi | 30 | This interrupt is from watchdog timer. | This interrupt is cleared by stopping or restarting the watchdog timer. | Table 17-6 Non-maskable interrupts # 17.6 Masked Interrupts with Internally Generated Vector Numbers The internal interfaces of ETRAX 100LX that are not mutually exclusive have individual, internally generated vector numbers. Mutually exclusive interfaces (e.g. SCSI-8 p0 and parallel port p0), may have the same vector number. Each interface has one or more different interrupts, all of which share the same vector number. If two or more interfaces issue an interrupt at the same time, vector number 0x2F is generated and the different inputs are sorted by the software. See table 17-7 below: | Vector<br>number | Number of interrupts | Name | Explanation | |------------------|----------------------|------------|------------------------------------------------------------------------------------------------------------------------------| | 0x20 | - | - | Hardware breakpoint/single step bus fault. For more information, refer to chapter 2.9 <i>Hardware Breakpoint Mechanism</i> . | | 0x21 | 2 | nmi | Non-maskable interrupts (see table 17-6). | | 0x22 | 1 | timer0 | Timer 0 interrupt (see table 17-13) | | 0x23 | 1 | timer1 | Timer 1 interrupt (see table 17-13) | | 0x24 | 9 | scsi0_par0 | Multiple/multiplexed interrupts for ATA, parallel port p0, shared RAM and SCSI-8 p0 (see table 17-10). | | 0x25 | 4 | scsi1_par1 | Multiple/multiplexed interrupts for parallel port p1 and SCSI-8 p1 (see table 17-15). | | 0x26 | 4 | network | Network interrupts (see table 17-9). | | 0x27 | 10 | snmp | Ethernet error and statistics counter interrupts (see table 17-8). | | 0x28 | 8 | serial | Asynchronous and synchronous serial port interrupts (see table 17-16). | | 0x29 | 8 | SW | Software generated interrupts (see table 17-14). | | 0x2A | 1 | irq_intnr | $\overline{\textbf{irq}}$ pin when used with internally generated vector number (see table 17-11). | | 0x2B | 8 | pa | General port PA interrupts (see table 17-17). | | 0x2C | 1 | ext_dma0 | External DMA channel 0 interrupt (see table 17-12). | | 0x2D | 1 | ext_dma1 | External DMA channel 1 interrupt (see table 17-12). | | 0x2E | - | - | MMU bus fault. | | 0x2F | - | - | Simultaneous interrupts for more than one vector are active. | | 0x30 | 2 | dma0 | DMA channel 0 interrupts (see table 17-19). | | 0x31 | 2 | dma1 | DMA channel 1 interrupts (see table 17-19). | | 0x32 | 2 | dma2 | DMA channel 2 interrupts (see table 17-19). | | 0x33 | 2 | dma3 | DMA channel 3 interrupts (see table 17-19). | | 0x34 | 2 | dma4 | DMA channel 4 interrupts (see table 17-19). | | 0x35 | 2 | dma5 | DMA channel 5 interrupts (see table 17-19). | | 0x36 | 2 | dma6 | DMA channel 6 interrupts (see table 17-19). | | 0x37 | 2 | dma7 | DMA channel 7 interrupts (see table 17-19). | | 0x38 | 6 | dma8 | Interrupts for DMA channel 8 (see table 17-19), and for sub-channels 8.0 to 8.3 (see table 17-18). | | 0x39 | 2 | dma9 | DMA channel 9 interrupts (see table 17-19). | | 0x3F | 10 | usb | USB interface interrupts (see table 17-20). | Table 17-7 Masked Interrupts with Internally Generated Vector Numbers If a source interrupt is cleared while the CPU is executing its interrupt acknowledgement sequence, the vector number of the interrupting interface is nevertheless generated. However the interrupts are not present in the interrupt status registers. ## 17.6.1 Interrupts in Register Sub-Set 0 In register sub-set 0, the interrupt mask bits are set in register R\_IRQ\_MASK0\_SET, where only the asserted bits are set (bits written with 0 are not affected). The masked interrupts are read in registers R\_IRQ\_MASK0\_RD. Register R\_IRQ\_READ0 contains the interrupt bits before they are individually masked. The asserted mask bits are cleared in register R\_IRQ\_MASK0\_CLR. Each interrupt field occupies the same bit number in all the registers of sub-set 0. #### **Ethernet Error and Statistics Counter Interrupts** Register sub-set 0 handles ten interrupts associated with Ethernet error and statistics counters. They all have the internally generated vector number 0x27. | Name of interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |-------------------|-----------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | sqe_test_error | 29 | This interrupt is set when the <b>sqe_test_error</b> counter attains the value 128. | This interrupt is cleared by reading the <b>sqe_test_error</b> field of network interface register R_PHY_COUNTERS. | | carrier_loss | 28 | This interrupt is set when the <b>carrier_loss</b> counter attains the value 128. | This interrupt is cleared by reading the carrier_loss field of network interface register R_PHY_COUNTERS. | | deferred | 27 | This interrupt is set when the <b>deferred</b> counter attains the value 128. | This interrupt is cleared by reading the <b>deferred</b> field of network interface register R_TR_COUNTERS. | | late_col | 26 | This interrupt is set when the <b>late_col</b> counter attains the value 128. | This interrupt is cleared by reading the late_col field of the R_TR_COUNTERS register. | | multiple_col | 25 | This interrupt is set when the <b>multiple_col</b> counter attains the value 128. | This interrupt is cleared by reading the <b>multiple_col</b> field of network interface register R_TR_COUNTERS. | | single_col | 24 | This interrupt is set when the <b>single_col</b> counter attains the value 128. | This interrupt is cleared by reading the <b>single_col</b> field of network interface register R_TR_COUNTERS. | | congestion | 23 | This interrupt is set when the <b>congestion</b> counter attains the value 128. | This interrupt is cleared by reading the <b>congestion</b> field of network interface register R_REC_COUNTERS, an action which also clears the <b>overrun</b> interrupt. | | oversize | 22 | This interrupt is set when the <b>oversize</b> counter attains the value 128. | This interrupt is cleared by reading the <b>oversize</b> field of network interface register R_REC_COUNTERS. | | alignment_error | 21 | This interrupt is set when the <b>alignment_error</b> counter attains the value 128. | This interrupt is cleared by reading the <b>alignment_error</b> field of network interface register R_REC_COUNTERS. | | crc_error | 20 | This interrupt is set when the <b>crc_error</b> counter attains the value 128. | This interrupt is cleared by reading the crc_error field of network interface register R_REC_COUNTERS. | Table 17-8 Ethernet Error and Statistics Counter Interrupts ## **Network Interrupts** Register sub-set 0 contains four network interrupts, all with the internally generated vector number 0x26. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | overrun | 19 | This interrupt is set when the network receiver experiences a FIFO overrun condition (congestion error). Two interrupts are available (overrun and congestion), but usually only one of them should be enabled. The overrun interrupt should be used if software intervention is necessary when an overrun error occurs. The congestion interrupt should be used if the only action needed is an error count. | This interrupt is cleared by reading the <b>congestion</b> field of network interface register R_REC_COUNTERS, an action which also clears the <b>congestion</b> interrupt. | | underrun | 18 | This interrupt is set when the network transmitter experiences a FIFO underrun condition. | This interrupt is cleared by setting the clr_error field in network interface register R_NETWORK_TR_CTRL. | | excessive_col | 17 | This interrupt is set when the network transmitter experiences collisions for 16 consecutive transmission attempts. It is set after the first collision if the <b>retry</b> field in network interface register R_NETWORK_TR_CTRL is set to <b>disable</b> , or when the transmitter stops after the <b>cancel</b> field of R_NETWORK_TR_CTRL has been set. | This interrupt is cleared by setting the clr_error field in network interface register R_NETWORK_TR_CTRL. | | mdio | 16 | This interrupt is from the MII <b>mdio</b> pin. It is generated when the <b>mdio</b> pin is low. The interrupt should be masked off during normal data transfers over the <b>mdio</b> interface. | This interrupt should be cleared in the external unit that is driving the <b>mdio</b> pin. | Table 17-9 Network Interrupts # Masked Interrupts for ATA, Parallel Port p0, Shared RAM and SCSI-8 Port p0 In register sub-set 0 there are nine different interrupt fields that have the internally generated vector number 0x24. Four of these fields are multi-functional (bits 11 to 8), containing different interface-dependent interrupts. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ata_drq3 | 15 | This interrupt is set when a unit on ATA bus 3 requests a DMA transfer. $ \\$ | This interrupt is cleared at the end of the DMA transfer on ATA bus 3. | | ata_drq2 | 14 | This interrupt is set when a unit on ATA bus 2 requests a DMA transfer. | This interrupt is cleared at the end of the DMA transfer on ATA bus 2. | | ata_drq1 | 13 | This interrupt is set when a unit on ATA bus 1 requests a DMA transfer. | This interrupt is cleared at the end of the DMA transfer on ATA bus 1. | | ata_drq0 | 12 | This interrupt is set when a unit on ATA bus 0 requests a DMA transfer. | This interrupt is cleared at the end of the DMA transfer on ATA bus $\boldsymbol{0}.$ | | par0_ecp_cmd | 11 | When parallel port p0 is in ECP mode, this interrupt is set when an ECP command is received at the port. | This interrupt is cleared by reading the <b>ecp_cmd_bit</b> field in parallel port p0 register R_PAR0_DATA. | | ata_irq3 | | When ATA is in use, this interrupt is set when a unit on ATA bus 3 requests an interrupt. | This interrupt is cleared in the external unit on ATA bus 3. | | par0_peri | 10 | When parallel port p0 is in use, this interrupt is set by the peripheral connected to the port. | This interrupt is cleared by acknowledging the <b>peri_int</b> field in parallel port p0 register R_PAR0_CTRL_DATA. | | ata_irq2 | | When ATA is in use, this interrupt is set when a unit on ATA bus 2 requests an interrupt. | This interrupt is cleared in the external unit on ATA bus 2. | | par0_data | 9 | When parallel port p0 is in use, this interrupt is set when data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. | This interrupt is cleared by reading the <b>data</b> field of parallel port p0 register R_PAR0_DATA. | | ata_irq1 | | When ATA is in use, this interrupt is set when a unit on ATA bus 1 requests an interrupt. | This interrupt is cleared in the external unit on ATA bus 1. | | par0_ready | 8 | When parallel port par0 is in use, this interrupt is set when the port is ready to get new data for transmission. | The interrupt is cleared by writing new data to the <b>data</b> field of parallel port register R_PAR0_DATA. This field should be masked when the DMA is used for data transfers. | | ata_irq0 | | When ATA is in use, this interrupt is set when a unit on ATA bus 0 requests an interrupt. | The interrupt is cleared in the external unit on ATA bus $0$ . | | mio | | This interrupt is set on the <b>intio</b> pin of the shared RAM interface. | This interrupt is cleared by setting the <b>i</b> field of register R_SHARED_RAM_CONFIG. | | scsi0 | | When SCSI-8 port p0 is in use, this interrupt is set when the SCSI controller requests service from the CPU. | The interrupt is cleared by writing to the clr_status field (bit 24) of register R_SCSI0_CMD_DATA. | | ata_dmaend | 7 | This interrupt is set when the selected ATA unit releases its DMA request (transfer completed). This interrupt should be masked, except when an ATA DMA transfer is started. | The interrupt is cleared when next ATA DMA transfer commences. | Table 17-10 Masked Interrupts for ATA, Parallel Port p0, Shared RAM and SCSI-8 Port p0 #### **External Interrupt Configuration Fields** In register sub-set 0 there are two fields for configuring the external interrupt on the $\overline{irq}$ pin, as shown in the table below. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | irq_ext_vector_nr | 5 | This field configures the external interrupt on the $\overline{irq}$ pin to have an external vector number. The mask bit is only effective if the $irq\_int\_vector\_nr$ mask bit (4) is cleared. | This interrupt is cleared in the external unit. This can be done by software or the $\overline{\text{inta}}$ output. | | irq_int_vector_nr | 4 | This field configures the external interrupt on the $\overline{irq}$ pin to have the internally generated vector number 0x2A. | This interrupt is cleared in the external unit. This can be done by software only. | | | | When the corresponding mask bit is set, the internally generated interrupt vector number is used and the <code>irq_ext_vector_nr</code> mask bit (5) has no effect. | | Table 17-11 External Interrupt Configuration Fields #### **External DMA Interrupts** In register sub-set 0 there are two fields for handling external DMA interrupts. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------| | ext_dma1 | 3 | This interrupt has the internally generated vector number 0x2D. It is set when external DMA channel 1 has stopped. | This interrupt should be masked, except when waiting for the completion of a transfer on external DMA channel 1. | | ext_dma0 | 2 | This interrupt has the internally generated vector number 0x2C. It is set when external DMA channel 0 has stopped. | This interrupt should be masked, except when waiting for the completion of a transfer on external DMA channel 0. | Table 17-12 External DMA Interrupts #### **Timer Interrupts** In register sub-set 0 there are two fields for handling the timer interrupts. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | timer1 | 1 | This interrupt has the internally generated vector number 0x23. It is set whenever timer1 reaches its terminal count. | This interrupt is cleared by setting the <b>i1</b> bit in timer register R_TIMER_CTRL. | | timer0 | 0 | This interrupt has the internally generated vector number 0x22. It is set whenever timer0 reaches its terminal count. | This interrupt is cleared by setting the ${\bf i0}$ bit in timer register R_TIMER_CTRL. | Table 17-13 Timer Interrupts ## 17.6.2 Interrupts in Register Sub-Set 1 In this sub-set the masked interrupts are set in register R\_IRQ\_MASK1\_SET and read in register R\_IRQ\_MASK1\_RD. Register R\_IRQ\_READ1 contains the interrupt bits before they are individually masked. The asserted mask bits are cleared in register R\_IRQ\_MASK1\_CLR. Each interrupt field occupies the same bit number in all the registers of sub-set 1. #### **Software Generated Interrupts** Register sub-set 1 has eight fields for handling software generated interrupts. They all have the internally generated vector number 0x29. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | sw_int7 | 31 | This interrupt is generated in software when mask bit <b>sw_int7</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int7</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int6 | 30 | This interrupt is generated in software when mask bit <b>sw_int6</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int6</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int5 | 29 | This interrupt is generated in software when mask bit <b>sw_int5</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int5</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int4 | 28 | This interrupt is generated in software when mask bit <b>sw_int4</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int4</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int3 | 27 | This interrupt is generated in software when mask bit <b>sw_int3</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int3</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int2 | 26 | This interrupt is generated in software when mask bit <b>sw_int2</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int2</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int1 | 25 | This interrupt is generated in software when mask bit <b>sw_int1</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int1</b> field in register R_IRQ_MASK1_CLR is set. | | sw_int0 | 24 | This interrupt is generated in software when mask bit <b>sw_int0</b> in register R_IRQ_MASK1_SET is asserted. | This interrupt is cleared when the <b>sw_int0</b> field in register R_IRQ_MASK1_CLR is set. | Table 17-14 Software Generated Interrupts Please refer to section 17.8 *Software Interrupts* below for more information on the software interrupts. ## Parallel Port p1 and SCSI-8 Port p1 Interrupts Register sub-set 1 has four fields for handling the interrupts at parallel port p1. One field (bit 16), contains an interrupt bit for SCSI-8 port p1 also. All these interrupts have the internally generated vector number 0x25. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | par1_ecp_cmd | 19 | When parallel port p1 is in ECP mode, this interrupt is set when an ECP command is received at the port. | This interrupt is cleared by reading the <b>ecp_cmd_bit</b> field in parallel port p1 register R_PAR1_CTRL_DATA. | | par1_peri | 18 | When parallel port p1 is in use, this interrupt is set by the peripheral connected to the port. | This interrupt is cleared by acknowledging the <b>peri_int</b> field in parallel port p1 register R_PAR1_CTRL_DATA. | | par1_data | 17 | When parallel port p1 is in use, this interrupt is set when data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. | This interrupt is cleared by reading the <b>data</b> field of parallel port p1 register R_PAR1_CTRL_DATA. | | par1_ready | 16 | When parallel port p1 is in use, this interrupt is set when the port is ready to get new data for transmission. | The interrupt is cleared by writing new data to the <b>data</b> field of parallel port p1 register R_PAR1_CTRL_DATA. This field should be masked when the DMA is used for data transfers. | | scsi1 | | When SCSI-8 port p1 is in use, this interrupt is set when the SCSI controller requests service from the CPU. | The interrupt is cleared by writing to the clr_status field (bit 24) of register R_SCSI1_CMD_DATA. | Table 17-15 Parallel Port p1 and SCSI-8 Port p1 Interrupts #### **Asynchronous and Synchronous Serial Port Interrupts** Register sub-set 1 has eight fields for handling the interrupts of the four asynchronous serial ports (p3 to p0). All of these interrupts have the internally generated vector number 0x28. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | ser3_ready | 15 | This interrupt is set when Async/Sync serial port p3 is ready to acquire new data for transmission. It should be masked when the DMA is used for data transfers. | This interrupt is cleared by writing new data to the R_SERIAL3_TR_DATA register, or to the data_out field of R_SERIAL3_CTRL. | | ser3_data | 14 | When Async/Sync serial port p3 is in use, this interrupt is set when data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. | This interrupt is cleared when data is read from the R_SERIAL3_REC_DATA register, or from the data_in field of R_SERIAL3_READ. | | ser2_ready | 13 | This interrupt is set when asynchronous serial port p2 is ready to acquire new data for transmission. It should be masked when the DMA is used for data transfers. | This interrupt is cleared by writing new data to the R_SERIAL2_TR_DATA register, or to the data_out field of R_SERIAL2_CTRL. | | ser2_data | 12 | When asynchronous serial port p2 is in use, this interrupt is set when data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. | This interrupt is cleared when data is read from the R_SERIAL2_REC_DATA register, or from the data_in field of R_SERIAL2_READ. | | ser1_ready | 11 | This interrupt is set when Async/Sync serial port p1 is ready to acquire new data for transmission. It should be masked when the DMA is used for data transfers. | This interrupt is cleared by writing new data to the R_SERIAL1_TR_DATA register, or to the data_out field of R_SERIAL1_CTRL. | | ser1_data | 10 | When Async/Sync serial port p1 is in use, this interrupt is set when data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. | This interrupt is cleared when data is read from the R_SERIAL1_REC_DATA register, or from the data_in field of R_SERIAL1_READ. | | ser0_ready | 9 | This interrupt is set when asynchronous serial port p0 is ready to acquire new data for transmission. It should be masked when the DMA is used for data transfers. | This interrupt is cleared by writing new data to the R_SERIALO_TR_DATA register, or to the data_out field of R_SERIALO_CTRL. | | ser0_data | 8 | When asynchronous serial port p0 is in use, this interrupt is set when data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. | This interrupt is cleared when data is read from the R_SERIALO_REC_DATA register, or from the data_in field of R_SERIALO_READ. | Table 17-16 Asynchronous and Synchronous Serial Port Interrupts #### **General Port PA Interrupts** Register sub-set 1 has eight fields for handling the active-high, level-triggered interrupts at general I/O port PA. They all have the internally generated vector number 0x2B. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------| | pa7 | 7 | This interrupt is on bit 7 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 7 of general port PA. | | pa6 | 6 | This interrupt is on bit 6 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 6 of general port PA. | | pa5 | 5 | This interrupt is on bit 5 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 5 of general port PA. | | pa4 | 4 | This interrupt is on bit 4 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 4 of general port PA. | | pa3 | 3 | This interrupt is on bit 3 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 3 of general port PA. | | pa2 | 2 | This interrupt is on bit 2 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 2 of general port PA. | | pa1 | 1 | This interrupt is on bit 1 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 1 of general port PA. | | pa0 | 0 | This interrupt is on bit 0 of general port PA when the port is used for interrupt handling. | This interrupt is cleared in the external unit that is driving bit 0 of general port PA. | Table 17-17 General Port PA Interrupts ## 17.6.3 Interrupts in Register Sub-Set 2 Register sub-set 2 handles all the interrupts for the DMA channels. The masked interrupts are set in register R\_IRQ\_MASK2\_SET and read in register R\_IRQ\_MASK2\_RD. Register R\_IRQ\_READ2 contains the interrupt bits before they are individually masked. The asserted mask bits are cleared in register R\_IRQ\_MASK2\_CLR. Each interrupt field occupies the same bit number in all the registers of sub-set 2. #### **Sub-Channel Interrupts for DMA Channel 8** Register sub-set 2 has four fields for handling the descriptor interrupts of the four sub-channels in DMA channel 8. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | dma8_sub3_descr | 23 | This is the descriptor interrupt for DMA channel 8 sub-channel 3. It has the internally generated vector number 0x38. | This interrupt is cleared by asserting the clr_descr bit in DMA register R_DMA_CH8_SUB3_CLR_INTR. | | dma8_sub2_descr | 22 | This is the descriptor interrupt for DMA channel 8 sub-channel 2. It has the internally generated vector number 0x38. | This interrupt is cleared by asserting the clr_descr bit in DMA register R_DMA_CH8_SUB2_CLR_INTR. | | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | dma8_sub1_descr | 21 | This is the descriptor interrupt for DMA channel 8 sub-channel 1. It has the internally generated vector number 0x38. | This interrupt is cleared by asserting the clr_descr bit in DMA register R_DMA_CH8_SUB1_CLR_INTR. | | dma8_sub0_descr | 20 | This is the descriptor interrupt for DMA channel 8 sub-channel 0. It has the internally generated vector number 0x38. | This interrupt is cleared by asserting the clr_descr bit in DMA register R_DMA_CH8_SUB0_CLR_INTR. | Table 17-18 Sub-Channel Interrupts for DMA Channel 8 # **DMA End-of-Packet and Descriptor Interrupts** Register sub-set 2 handles all the end-of-packet and descriptor interrupts for the ten DMA channels. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | dma9_eop | 19 | This is the end-of-packet interrupt for DMA channel 9. It has the internally generated vector number 0x39. | This interrupt is cleared by asserting the clr_eop bit in register R_DMA_CH8_CLR_INTR. | | dma9_descr | 18 | This is the descriptor interrupt for DMA channel 9. It has the internally generated vector number 0x39. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH8_CLR_INTR. | | dma8_eop | 17 | This is the end-of-packet interrupt for DMA channel 8. It has the internally generated vector number 0x38. | This interrupt is cleared by asserting the clr_eop bit in register R_DMA_CH8_CLR_INTR. | | dma8_descr | 16 | This is the descriptor interrupt for DMA channel 8. It has the internally generated vector number 0x38. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH8_CLR_INTR. | | dma7_eop | 15 | This is the end-of-packet interrupt for DMA channel 7. It has the internally generated vector number 0x37. | This interrupt is cleared by asserting the <b>clr_eop</b> bit in register R_DMA_CH7_CLR_INTR. | | dma7_descr | 14 | This is the descriptor interrupt for DMA channel 7. It has the internally generated vector number 0x37. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH7_CLR_INTR. | | dma6_eop | 13 | This is the end-of-packet interrupt for DMA channel 6. It has the internally generated vector number 0x36. | This interrupt is cleared by asserting the clr_eop bit in register R_DMA_CH6_CLR_INTR. | | dma6_descr | 12 | This is the descriptor interrupt for DMA channel 6. It has the internally generated vector number 0x36. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH6_CLR_INTR. | | dma5_eop | 11 | This is the end-of-packet interrupt for DMA channel 5. It has the internally generated vector number 0x35. | This interrupt is cleared by asserting the clr_eop bit in register R_DMA_CH5_CLR_INTR. | | dma5_descr | 10 | This is the descriptor interrupt for DMA channel 5. It has the internally generated vector number 0x35. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH5_CLR_INTR. | | dma4_eop | 9 | This is the end-of-packet interrupt for DMA channel 4. It has the internally generated vector number 0x34. | This interrupt is cleared by asserting the clr_eop bit in register R_DMA_CH4_CLR_INTR. | | dma4_descr | 8 | This is the descriptor interrupt for DMA channel 4. It has the internally generated vector number 0x34. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH4_CLR_INTR. | | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | dma3_eop | 7 | This is the end-of-packet interrupt for DMA channel 3. It has the internally generated vector number 0x33. | This interrupt is cleared by asserting the <b>clr_eop</b> bit in register R_DMA_CH3_CLR_INTR. | | dma3_descr | 6 | This is the descriptor interrupt for DMA channel 3. It has the internally generated vector number 0x33. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH3_CLR_INTR. | | dma2_eop | 5 | This is the end-of-packet interrupt for DMA channel 2. It has the internally generated vector number 0x32. | This interrupt is cleared by asserting the <b>clr_eop</b> bit in register R_DMA_CH2_CLR_INTR. | | dma2_descr | 4 | This is the descriptor interrupt for DMA channel 2. It has the internally generated vector number 0x32. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH2_CLR_INTR. | | dma1_eop | 3 | This is the end-of-packet interrupt for DMA channel 1. It has the internally generated vector number 0x31. | This interrupt is cleared by asserting the <b>clr_eop</b> bit in register R_DMA_CH1_CLR_INTR. | | dma1_descr | 2 | This is the descriptor interrupt for DMA channel 1. It has the internally generated vector number 0x31. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH1_CLR_INTR. | | dma0_eop | 1 | This is the end-of-packet interrupt for DMA channel 0. It has the internally generated vector number 0x30. | This interrupt is cleared by asserting the <b>clr_eop</b> bit in register R_DMA_CH0_CLR_INTR. | | dma0_descr | 0 | This is the descriptor interrupt for DMA channel 0. It has the internally generated vector number 0x30. | This interrupt is cleared by asserting the clr_descr bit in register R_DMA_CH0_CLR_INTR. | Table 17-19 DMA End-of-Packet and Descriptor Interrupts # 17.6.4 Interrupts in the USB Register Set Register sub-set R\_USB\_IRQ handles all the interrupts for the USB interface. The masked interrupts are set in register R\_USB IRQ\_MASK\_SET and read in register R\_USB\_IRQ\_MASK\_RD. Register R\_USB IRQ\_READ contains the interrupt bits before they are individually masked. The asserted mask bits are cleared in register R\_USB IRQ\_MASK\_CLR. All USB interrupts have the internally generated vector number 0x3F. Each interrupt field occupies the same bit number in all the registers of this sub-set. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | iso_eof | 13 | This interrupt occurs when the DMA detects a set eof bit in an endpoint descriptor in the isochronous endpoint DMA list. | This interrupt is cleared when the <code>iso_eof</code> bit in register R_USB_EPID_ATTN is read. | | intr_eof | 12 | This interrupt occurs when the DMA detects a set eof bit in an endpoint descriptor in the interrupt endpoint DMA list. | This interrupt is cleared when the <code>intr_eof</code> bit in register R_USB_EPID_ATTN is read. | | iso_eot | 11 | This interrupt occurs when the DMA detects a set eof bit in an endpoint descriptor in the isochronous endpoint DMA list, and the USB interface has finished the last transaction of the transfer. | This interrupt is cleared when the <b>iso_eot</b> bit in register R_USB_EPID_ATTN is read. | | intr_eot | 10 | This interrupt occurs when the DMA detects a set eof bit in an endpoint descriptor in the interrupt endpoint DMA list, and the USB interface has finished the last transaction of the transfer. | This interrupt is cleared when the <b>intr_eot</b> bit in register R_USB_EPID_ATTN is read. | |-------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------| | ctl_eot | 9 | This interrupt occurs when the DMA detects a set eof bit in an endpoint descriptor in the control endpoint DMA list, and the USB interface has finished the last transaction of the transfer. | This interrupt is cleared when the <b>ctrl_eot</b> bit in register R_USB_EPID_ATTN is read. | | bulk_eot | 8 | This interrupt occurs when the DMA detects a set eof bit in an endpoint descriptor in the bulk endpoint DMA list, and the USB interface has finished the last transaction of the transfer. | This interrupt is cleared when <b>bulk_eot</b> bit in register R_USB_EPID_ATTN is read. | | epid_attn | 3 | This interrupt is triggered whenever a significant endpoint event occurs. | This interrupt is cleared when register R_USB_EPID_ATTN is read. | | sof | 2 | This interrupt is triggered each time the USB outputs a start-of-frame. | This interrupt is cleared when register R_USB_FM_NUMBER is read. | | port_status | ſ | This interrupt signals a change in any of the configured port status registers. | This interrupt is cleared after all changed port status registers (R_USB_RH_PORT_STATUS_{12}) have been read. | | ctl_status | 0 | This interrupt indicates a change of USB interface controller status. | This interrupt is cleared when register R_USB_STATUS is read. | Table 17-20 Interrupts in the USB Register Set ## 17.6.5 Vector Number Register Sub-Set In this sub-set the composite masked interrupts are set in register R\_VECT\_MASK\_SET and read in register R\_VECT\_MASK\_RD. Register R\_VECT\_READ contains the composite interrupt bits before they are masked. The asserted composite mask bits are cleared in register R\_VECT\_MASK\_CLR. Each composite field occupies the same bit number in all the registers of the vector number sub-set. | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |----------------------|-----------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------| | usb | 31 | This is the composed bit for interrupts from the USB. Vector number 0x3F. | This field is cleared by asserting the <b>usb</b> bit in register R_VECT_MASK_CLR. | | dma9 | 25 | This is the composed bit for interrupts from DMA channel 9. Vector number 0x39. | This field is cleared by asserting the <b>dma9</b> bit in register R_VECT_MASK_CLR. | | dma8 | 24 | This is the composed bit for interrupts from DMA channel 8. Vector number 0x38. | This field is cleared by asserting the <b>dma8</b> bit in register R_VECT_MASK_CLR. | | dma7 | 23 | This is the composed bit for interrupts from DMA channel 7. Vector number 0x37. | This field is cleared by asserting the <b>dma7</b> bit in register R_VECT_MASK_CLR. | | dma6 | 22 | This is the composed bit for interrupts from DMA channel 6. Vector number 0x36. | This field is cleared by asserting the <b>dma6</b> bit in register R_VECT_MASK_CLR. | | dma5 | 21 | This is the composed bit for interrupts from DMA channel 5. Vector number 0x35. | This field is cleared by asserting the <b>dma5</b> bit in register R_VECT_MASK_CLR. | | dma4 | 20 | This is the composed bit for interrupts from DMA channel 4. Vector number 0x34. | This field is cleared by asserting the <b>dma4</b> bit in register R_VECT_MASK_CLR. | | dma3 | 19 | This is the composed bit for interrupts from DMA channel 3. Vector number 0x33. | This field is cleared by asserting the <b>dma3</b> bit in register R_VECT_MASK_CLR. | | Name of<br>Interrupt | Register<br>Bit | Description of Interrupt | Interrupt Clearance | |-----------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | usb | 31 | This is the composed bit for interrupts from the USB. Vector number 0x3F. | This field is cleared by asserting the <b>usb</b> bit in register R_VECT_MASK_CLR. | | dma2 | 18 | This is the composed bit interrupts from DMA channel 2. Vector number 0x32. | This field is cleared by asserting the dma2 bit in register R_VECT_MASK_CLR. | | dma1 | 17 | This is the composed bit interrupts from DMA channel 1. Vector number 0x31. | This field is cleared by asserting the <b>dma1</b> bit in register R_VECT_MASK_CLR. | | dma0 | 16 | This is the composed bit for interrupts from DMA channel 0. Vector number 0x30. | This field is cleared by asserting the <b>dma0</b> bit in register R_VECT_MASK_CLR. | | ext_dma1 | 13 | This is the composed bit for interrupts from external DMA channel 1. Vector number 0x2D. | This field is cleared by asserting the <b>ext_dma1</b> bit in register R_VECT_MASK_CLR. | | ext_dma0 | 12 | This is the composed bit for interrupts from external DMA channel 0. Vector number 0x2C. | This field is cleared by asserting the <b>ext_dma0</b> bit in register R_VECT_MASK_CLR. | | pa | 11 | This is the composed bit for interrupts from general port PA. Vector number 0x2B. | This field is cleared by asserting the <b>pa</b> bit in register R_VECT_MASK_CLR. | | irq_intnr | 10 | $\frac{This}{irq} \ pin, \ vector \ number \ 0x2A.$ | This field is cleared by asserting the <code>irq_intnr</code> bit in register <code>R_VECT_MASK_CLR</code> . | | SW | 9 | This is the composed bit for software generated interrupts. Vector number 0x29. | This field is cleared by asserting the sw bit in register R_VECT_MASK_CLR. | | serial | 8 | This is the composed bit for interrupts from the asynchronous and synchronous serial ports. Vector number 0x28. | This field is cleared by asserting the <b>serial</b> bit in register R_VECT_MASK_CLR. | | snmp | 7 | This is the composed bit for Ethernet error and statistics counter interrupts. Vector number 0x27. | This field is cleared by asserting the <b>snmp</b> bit in register R_VECT_MASK_CLR. | | network | 6 | This is the composed bit for interrupts from the network interface. Vector number 0x26. | This field is cleared by asserting the <b>network</b> bit in register R_VECT_MASK_CLR. | | scsi1<br>par1 | 5 | This is the composed bit for interrupts from SCSI-8 Port p1 and parallel port p1. Vector number 0x25. | This field is cleared by asserting bit 5 in register R_VECT_MASK_CLR. | | scsi0<br>par0<br>ata<br>mio | 4 | This is the composed bit for interrupts from SCSI-8 Port p0, parallel port p0, the ATA port and the shared RAM port. Vector number 0x24. | This field is cleared by asserting bit 4 in register R_VECT_MASK_CLR. | | timer1 | 3 | This is the composed bit for interrupts from timer 1. Vector number 0x23. | This field is cleared by asserting bit 3 in register R_VECT_MASK_CLR. | | timer0 | 2 | This is the composed bit for interrupts from timer 0. Vector number 0x22. | This field is cleared by asserting bit 2 in register R_VECT_MASK_CLR. | | nmi | 1 | This is the composed bit for interrupts from the NMI. It cannot be masked and therefore the mask bit is always set to 1. Vector number 0x21. | This field cannot be cleared: it is always enabled. | | some | 0 | This is the composed bit for interrupts (except NMI but including irq with an external vector number), that are active after the individual masks. | This field cannot be cleared: it is always enabled. | Table 17-21 Vector Number Register Sub-Set # 17.7 External Maskable Interrupt with an External Vector Number The external interrupt on the $\overline{irq}$ pin can be configured for an external vector number or an internally generated vector number. To configure the external interrupt for an external vector number, the **irq\_ext\_vector\_nr** field (bit 5) must be set in R\_IRQ\_MASK0\_SET, and the **irq\_int\_vector\_nr** field (bit 4) must be cleared in interrupt mask register R\_IRQ\_MASK0\_CLR. <u>In the acknowledgement cycle for an interrupt with an external vector number, the inta</u> output is asserted. In response, the external device supplies its vector number in the least significant byte on the data bus. Please refer to chapter 5.8 *External Interrupt Acknowledge* for more information. #### 17.8 Software Interrupts As previously noted, the eight software interrupts with internally generated vector numbers are handled in register sub-set 1. They are set in register R\_IRQ\_MASK1\_SET and cleared with their respective mask bits in register R\_IRQ\_MASK1\_CLR, which actually constitutes the interrupts. During normal program flow, the software may occasionally enter a critical region in which it cannot share resources. Typically this could occur when incoming data from an interface almost entirely fills a buffer, and usually requires that the interrupts are disabled. However ETRAX 100LX has a solution wherein the original interrupt routine can be enabled more often. The software interrupts offer a simple and rapid response to hardware interrupts requiring actions that are extensive, but not so time-critical. When the original interrupt has executed the time-critical operation, it can set a software interrupt and return. Figure 17-2 Software Generated Interrupt Routines Figure 17-2 shows that, when the program enters a critical region, the software interrupt is disabled. The hardware interrupt then takes care of the time-critical operation and sets the software interrupt. As soon as the software interrupt is enabled, the software interrupt routine performs the more extensive action. # 18 Internal Registers This chapter contains detailed information about the internal registers in the ETRAX 100LX. The register descriptions are presented as appropriate sets, within which the content of each separate register is specified to bit level. The description of each register is introduced by a table giving the identification (ID), offset value, register address, size of the register, read/write capability and initial value. The bit allocation of each register is then presented in a table as follows: | Bit(s) | Name | Description | State/Range | |-----------|-------------|------------------------------------------------------------|-------------------------------------------------------| | bit no(s) | name of bit | Summary of the function of the bit and associated signals. | Significance of each bit state or range of bit field. | #### 18.1 Conventions #### 18.1.1 Notation All hexadecimal values, including addresses, are preceded by 0x. All other values are given in decimal notation. #### 18.1.2 Base Address The internal registers are positioned at base address 0xB0000000 and upwards. Thus the offset value given for each register must be added to the base address to obtain the true address of the respective register. ## 18.2 Bus Interface Configuration Registers #### 18.2.1 R\_WAITSTATES #### Wait States Register, General Characteristics | ID of register | R_WAITSTATES | Size | 32 bits | |----------------|--------------|---------------|------------| | Offset | 0x0 | Read/Write | Write only | | Address | 0xB0000000 | Initial value | 0xFFFFFFF | #### Bit Assignments of R\_WAITSTATES | Bit(s) | Name | Description | State/Range | |--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31- 30 | pcs4_7_zw | This 2-bit field sets the number of wait states during bus turn-off for peripheral chip select signals $\overline{csp4}$ - $\overline{csp7}$ . (note 1) | 0 - 3 | | 29 - 28 pcs4_7_ew This 2-bit field sets the number of early wait states for peripheral chip select signals csp4 - csp7. (note 2) | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|--------------------------------------------------------------------------------------------|--------| | peripheral chip select signals csp4 - csp7. (note 3) 23 - 22 pcs0_3_zw This 2-bit field sets the number of wait states during bus turn-off for peripheral chip select signals csp0 - csp3. (note 1) This 2-bit field sets the number of early wait states for peripheral chip select signals csp0 - csp3. (note 2) 19 - 16 pcs0_3_lw This 4-bit field sets the number of late wait states for peripheral chip select signals csp0 - csp3. (note 3) 15 - 14 sram_zw This 2-bit field sets the number of wait states during bus turn-off for SRAM chip select signals csr0 and csr1. (note 1) 13 - 12 sram_ew This 2-bit field sets the number of early wait states for SRAM chip select signals csr0 and csr1. (note 2) 11 - 8 sram_lw This 4-bit field sets the number of late wait states for SRAM chip select signals csr0 and csr1. (note 3) 7 - 6 flash_zw This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 29 - 28 | pcs4_7_ew | peripheral chip select signals $\overline{csp4}$ - $\overline{csp7}$ . | 0 - 3 | | turn-off for peripheral chip select signals csp0 - csp3. (note 1) 21 - 20 pcs0_3_ew This 2-bit field sets the number of early wait states for peripheral chip select signals csp0 - csp3. (note 2) 19 - 16 pcs0_3_lw This 4-bit field sets the number of late wait states for peripheral chip select signals csp0 - csp3. (note 3) 15 - 14 sram_zw This 2-bit field sets the number of wait states during bus turn-off for SRAM chip select signals csr0 and csr1. (note 1) 13 - 12 sram_ew This 2-bit field sets the number of early wait states for SRAM chip select signals csr0 and csr1. (note 2) 11 - 8 sram_lw This 4-bit field sets the number of late wait states for SRAM chip select signals csr0 and csr1. (note 3) 7 - 6 flash_zw This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. 0 - 15 | 27 - 24 | pcs4_7_lw | peripheral chip select signals $\overline{csp4}$ - $\overline{csp7}$ . | 0 - 15 | | peripheral chip select signals \(\overline{\cosp0} - \overline{\cosp3}\). 19 - 16 \text{pcs0_3_lw} \text{This 4-bit field sets the number of late wait states for peripheral chip select signals \(\overline{\cosp0} - \overline{\cosp3}\). (note 3) 15 - 14 \text{sram_zw} \text{This 2-bit field sets the number of wait states during bus turn-off for SRAM chip select signals \(\overline{\cosp0}\) and \(\overline{\cosp1}\). (note 1) 13 - 12 \text{sram_ew} \text{This 2-bit field sets the number of early wait states for SRAM chip select signals \(\overline{\cosp0}\) and \(\overline{\cosp1}\). (note 2) 11 - 8 \text{sram_lw} \text{This 4-bit field sets the number of late wait states for SRAM chip select signals \(\overline{\cosp0}\) and \(\overline{\cosp1}\). (note 3) 7 - 6 \text{flash_zw} \text{This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals \(\overline{\cosp0}\) and \(\overline{\cosp0}\). (note 1) 5 - 4 \text{flash_ew} \text{This 2-bit field sets the number of early wait states for flash-PROM chip select signals \(\overline{\cosp0}\) and \(\overline{\cosp0}\). (note 2) 3 - 0 \text{flash_lw} \text{This 4-bit field sets the number of late wait states for flash-PROM chip select signals \(\overline{\cosp0}\) and \(\overline{\cosp0}\). | 23 - 22 | pcs0_3_zw | turn-off for peripheral chip select signals $\overline{csp0}$ - $\overline{csp3}$ . | 0 - 3 | | peripheral chip select signals csp0 - csp3. (note 3) 15 - 14 sram_zw This 2-bit field sets the number of wait states during bus turn-off for SRAM chip select signals csr0 and csr1. (note 1) 13 - 12 sram_ew This 2-bit field sets the number of early wait states for SRAM chip select signals csr0 and csr1. (note 2) 11 - 8 sram_lw This 4-bit field sets the number of late wait states for SRAM chip select signals csr0 and csr1. (note 3) 7 - 6 flash_zw This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 21 - 20 | pcs0_3_ew | peripheral chip select signals $\overline{csp0}$ - $\overline{csp3}$ . | 0 - 3 | | turn-off for SRAM chip select signals csr0 and csr1. (note 1) 13 - 12 sram_ew This 2-bit field sets the number of early wait states for SRAM chip select signals csr0 and csr1. (note 2) 11 - 8 sram_lw This 4-bit field sets the number of late wait states for SRAM chip select signals csr0 and csr1. (note 3) 7 - 6 flash_zw This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 19 - 16 | pcs0_3_lw | peripheral chip select signals csp0 - csp3. | 0 - 15 | | SRAM chip select signals csr0 and csr1. (note 2) 11 - 8 sram_lw This 4-bit field sets the number of late wait states for SRAM chip select signals csr0 and csr1. (note 3) 7 - 6 flash_zw This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 15 - 14 | sram_zw | turn-off for SRAM chip select signals csr0 and csr1. | 0 - 3 | | SRAM chip select signals csr0 and csr1. (note 3) 7 - 6 flash_zw This 2-bit field sets the number of wait states during bus turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 13 - 12 | sram_ew | SRAM chip select signals $\overline{\text{csr0}}$ and $\overline{\text{csr1}}$ . | 0 - 3 | | turn-off for flash-PROM chip select signals cse0 and cse1. (note 1) 5 - 4 flash_ew This 2-bit field sets the number of early wait states for flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 11 - 8 | sram_lw | SRAM chip select signals $\overline{csr0}$ and $\overline{csr1}$ . | 0 - 15 | | flash-PROM chip select signals cse0 and cse1. (note 2) 3 - 0 flash_lw This 4-bit field sets the number of late wait states for flash-PROM chip select signals cse0 and cse1. | 7 - 6 | flash_zw | turn-off for flash-PROM chip select signals $\overline{cse0}$ and $\overline{cse1}$ . | 0 - 3 | | flash-PROM chip select signals $\overline{cse0}$ and $\overline{cse1}$ . | 5 - 4 | flash_ew | flash-PROM chip select signals $\overline{\textbf{cse0}}$ and $\overline{\textbf{cse1}}$ . | 0 - 3 | | | 3 - 0 | flash_lw | flash-PROM chip select signals $\overline{cse0}$ and $\overline{cse1}$ . | 0 - 15 | - Note 1: The wait state is inserted after a burst to give the accessed unit sufficient time to turn off its drivers (read cycles), and to ensure sufficient data hold time (write cycles). The number of turn-off clock cycles is 1 + zw. - Note 2: The early wait state is inserted before $\overline{rd}$ or $\overline{wr}$ goes low in each bus cycle. The number of early clock cycles is ew. When ew is 0, $\overline{rd}$ will be low throughout the entire burst. - **Note 3:** The late wait state is inserted during the $\overline{rd}$ or $\overline{wr}$ low period. The number of late clock cycles is 2 + lw. ## 18.2.2 R\_BUS\_CONFIG #### **Bus Configuration Register, General Characteristics** | ID of register | R_BUS_CONFIG | Size | 32 bits | |----------------|--------------|---------------|-----------------------------------------| | Offset | 0x4 | Read/Write | Write only | | Address | 0xB0000004 | Initial value | 0x0000000E or<br>0x0000000F<br>(note 1) | #### Bit Assignments of R\_BUS\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 10 | Reserved | - | 0 | | 9 | sram_type | This field selects the common write enable (cwe), or bytewise write enable (bwe) mode for SRAM chip select signals $\overline{csr0}$ and $\overline{csr1}$ . | 0 = bwe<br>1 = cwe | | 8 | dma_burst | This field selects 16 byte or 32 byte burst length for DMA transfers. | 0 = burst32<br>1 = burst16 | | 7 | pcs4_7_wr | This field sets the write delay mode for peripheral chip select signals $\overline{csp4}$ - $\overline{csp7}$ . (note 2) | 0 = norm<br>1 = ext | | 6 | pcs0_3_wr | This field sets the write delay mode for peripheral chip select signals $\overline{csp0}$ - $\overline{csp3}$ . (note 2) | 0 = norm<br>1 = ext | | 5 | sram_wr | This field sets the write delay mode for SRAM chip select signals $\overline{csr0}$ and $\overline{csr1}$ . (note 2) | 0 = norm<br>1 = ext | | 4 | flash_wr | This field sets the write delay mode for EPROM/flash-PROM chip select signals $\overline{cse0}$ and $\overline{cse1}$ . (note 2) | 0 = norm<br>1 = ext | | 3 | pcs4_7_bw | This field selects the bus width for peripheral chip select signals $\overline{csp4}$ - $\overline{csp7}$ . | 0 = bw16<br>1 = bw32 | | 2 | pcs0_3_bw | This field selects the bus width for peripheral chip select signals $\overline{csp0}$ - $\overline{csp3}$ . | 0 = bw16<br>1 = bw32 | | 1 | sram_bw | This field selects the bus width for SRAM chip select signals $\overline{csr0}$ and $\overline{csr1}$ . | 0 = bw16<br>1 = bw32 | | 0 | flash_bw | This field selects the bus width for EPROM/flash-PROM select signals $\overline{cse0}$ and $\overline{cse1}$ . | 0 = bw16<br>1 = bw32 | **Note 1:** Bit 0 is set to the value of the **bs0** pin at reset. **Note 2:** If set to **norm** (0), the $\overline{\mathbf{wr}}$ signals go high 0.5 clock cycles before the end of the bus cycle. If this bit is set to $\mathbf{ext}$ (1), the $\overline{\mathbf{wr}}$ signals go high at the end of the bus cycle. ## 18.2.3 R\_BUS\_STATUS #### **Bus Status Register, General Characteristics** | ID of register | R_BUS_STATUS | Size | 32 bits | |----------------|--------------|---------------|-------------| | Offset | 0x4 | Read/Write | Read only | | Address | 0xB0000004 | Initial value | See note 1. | #### Bit Assignments of R\_BUS\_STATUS | Bit(s) | Name | Description | State/Range | |--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | 31 - 6 | Reserved | | 0 | | 5 | pll_lock_tm | This bit shows the status of the timer that waits for PLL lock after reset. In normal operation, this bit should always be <b>expired</b> . When PLL bypass mode is enabled, the value changes from <b>counting</b> to <b>expired</b> after 32768 clock cycles. | 0 = expired<br>1 = counting | | 4 | both_faults | This bit is set if a single step bus fault and an MMU bus fault occur in the same CPU cycle. The bit is set to 0 by a CPU RBF instruction. | 0 = no<br>1 = yes | | 3 | bsen_ | This bit shows if the outputs on the bus status pins $\overline{bs3}$ - $\overline{bs0}$ are enabled or disabled. | 0 = enabled<br>1 = disabled | | 2 - 1 | boot | This 2-bit field indicates the selected bootstrap method: - uncached starts at 0x80000002; - serial loads the program via serial port to cache; - network loads the program via network to cache; - parallel loads the program via parallel port to cache. | 0 = uncached<br>1 = serial<br>2 = network<br>3 = parallel | | 0 | flashw | This bit shows the initial width of the EPROM/flash-PROM banks 0 and 1, selected by $\overline{cse0}$ and $\overline{cse1}$ (address 0x00000000-0x07FFFFFF). | 0 = bw16<br>1 = bw32 | **Note:** Bit 4 is set to 0 after reset. Bits 3 to 0 are initiated through bus status pins at reset. ## 18.2.4 R\_DRAM\_TIMING #### **DRAM Timing Register, General Characteristics** | ID of register | R_DRAM_TIMING | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0x8 | Read/Write | Write only | | Address | 0xB0000008 | Initial value | 0x0000FFFF | ## Bit Assignments of R\_DRAM\_TIMING | Bit(s) | Name | Description | State/Range | |---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 31 | sdram | This bit enables or disables the SDRAM interface. When it is set, the SDRAM interface is enabled and the R_SDRAM_TIMING and R_SDRAM_CONFIG registers are used to configure the interface. (See the description of R_SDRAM_TIMING and R_SDRAM_CONFIG.) | 0 = disable<br>1 = enable | | 30 - 16 | Reserved | - | 0 | | 15 - 14 | ref | This 2-bit field sets the DRAM refresh interval. For example <b>e52us</b> means that the DRAM will be refreshed at 52 $\mu s$ intervals. | 0 = e52us<br>1 = e13us<br>2 = e8700ns<br>3 = disable | | 13 - 12 | rp | $\overline{ras}$ precharge waitstates. Wait states inserted after $\overline{ras}$ goes high, but before the row address is output (RAS-CAS cycle) or $\overline{cas}$ goes low (CBR refresh cycle). The number of precharge cycles is $0.5 + rp$ . | 0 - 3 | | 11 - 10 | rs | Row address setup wait states. Wait states inserted between valid row address (RAS-CAS cycle) or cas low (CBR refresh cycle), and ras low. Number of setup cycles is 1 + rs. | 0 - 3 | | 9 - 8 | rh | Row address hold time. The number of row address hold clock cycles is $1+\mathbf{rh}$ . | 0 - 3 | | 7 | W | Write delay mode. If set to <b>norm</b> , the <b>wr</b> signals go high 0.5 clock cycles before the end of the bus cycle. If set to <b>ext</b> , the <b>wr</b> signals go high at the end of the bus cycle. | 0 = norm<br>1 = ext | | 6 | c | cas delay mode. If set to norm no extra delay is added, if set to ext the negative edge of cas is delayed 0.5 clock cycles. This does not affect the total time for the bus cycle. | 0 = norm<br>1 = ext | | 5 - 4 | cz | $\overline{\text{cas}}$ wait states during bus turn-off. Inserted after a burst to DRAM. Number of turn off cycles will be $1 + \text{cz}$ . In EDO mode, cz should only be set to 0 or 1, giving $1 + \text{cz}$ turn off clock cycles for write, and $3 + \text{cz}$ turn off clock cycles for read. | 0 - 3 | | 3 - 2 | ср | $\overline{\text{cas}}$ precharge wait states. Inserted before $\overline{\text{cas}}$ goes low in each CAS only or RAS-CAS cycle. Also inserted while $\overline{\text{cas}}$ is low in CBR refresh cycles. Number of $\overline{\text{cas}}$ precharge cycles is $1 + \text{cp}$ . | 0 - 3 | | 1 - 0 | cw | $\overline{\text{cas}}$ wait states. Inserted during $\overline{\text{cas}}$ low. Number of $\overline{\text{cas}}$ clock cycles i 1 + cw. | 0 - 3 | ## 18.2.5 R\_SDRAM\_TIMING #### **SDRAM Timing Register, General Characteristics** | ID of register | R_SDRAM_TIMING | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x8 | Read/Write | Write only | | Address | 0xB0000008 | Initial value | 0x0000FFFF | ## Bit Assignments of R\_SDRAM\_TIMING | Bit(s) | Name | Description | State/Range | |---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 31 | sdram | SDRAM enable. This bit must not be set before R_SDRAM_CONFIG is configured properly. | 0 = disable<br>1 = enable | | 30 - 16 | mrs_data | Data output on a15 - a1 during SDRAM mrs cycle. | | | 15 - 14 | ref | This 2-bit field sets the SDRAM refresh interval. For example <b>e52us</b> means that the SDRAM will be refreshed at 52 $\mu s$ intervals. | 0 = e52us<br>1 = e13us<br>2 = e6500ns<br>3 = disable | | 13 | ddr | Double Data Rate select. If this bit is set, the SDRAM interface functions as a DDR SDRAM interface. | 0 = off<br>1 = on | | 12 | clk100 | SDRAM master clock select. If this bit is set, a 100MHz master clock will be used, if not a 50MHz master clock will be used. | 0 = off<br>1 = on | | 11 | ps | Power save select. If this bit is set, the SDRAM interface will enter power down mode after each refresh. | 0 = off<br>1 = on | | 10 - 9 | cmd | Initiate an SDRAM command cycle. The types available are "mode register set" (mrs), "refresh" (ref) or "precharge all" (pre) cycle. The ref and mrs command should always be preceded by a pre command. All commands must always be followed by a nop command e.g. pre, nop, mrs, nop. This field is used during initializing of the SDRAM modules. | 0 = nop<br>1 = mrs<br>2 = ref<br>3 = pre | | 8 | pde | Power down exit delay. Number of delay cycles from power down exit to new command will be <b>pde</b> + 1. | 0 - 1 | | 7 - 6 | rc | Row cycle time. This is the auto refresh cycle time and will be $rc+6.$ | 0 - 3 | | 5 - 4 | rp | $\overline{\textbf{ras}}$ precharge delay cycles. Number of delay cycles after precharge bank command will be $\textbf{rp}+1$ in 50MHz mode and $\textbf{rp}+2$ in 100MHz mode. | 0 - 3 | | 3 - 2 | rcd | $\overline{\text{ras}}$ to $\overline{\text{cas}}$ delay. Number of delay cycles after activate bank command will be $\text{rcd} + 1$ in 50MHz mode and $\text{rcd} + 2$ in 100MHz mode. | 0 - 3 | | 1 - 0 | cl | $\overline{\text{cas}}$ latency cycles. In 50MHz mode, the number of delay cycles from read bank command to valid read data will be $\text{cl}+1$ , with $\text{cl}=1$ and $\text{cl}=2$ as allowed values. In 100 MHz modes the number of cyles will be $\text{cl}+2$ , with $\text{cl}=0$ and $\text{cl}=1$ as allowed values. Thus $\overline{\text{cas}}$ latency can be varied from 2 to 3 SDRAM clock cycles. Note that $\text{cl}=3$ is not allowed in either mode. | 0 - 2 | ## 18.2.6 R\_DRAM\_CONFIG ## **DRAM Configuration Register, General Characteristics** | ID of register | R_DRAM_CONFIG | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0xC | Read/Write | Write only | | Address | 0xB000000C | Initial value | Unknown | ## Bit Assignments of R\_DRAM\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | wmm1 | Wide module mode for group 1. In wide module mode, all 8 cas outputs are used in each bank. The use of casa3 - casa0 or casb3 - casb0 is selected by the highest address bit in the selected column address range (ca1 field). The ca1 field should in this case be set to one bit higher than the highest column address bit to the DRAM. This mode is used with 64-bit wide DRAM modules that don't have separate ras strobes for the upper and lower half of the data bus. | 0 = norm<br>1 = wmm | | 30 | wmm0 | Wide module mode for group 0. See $\mathbf{wmm1}$ for description. | 0 = norm<br>1 = wmm | | 29 - 27 | sh1 | This field gives the row address shift for group 1. The value given decides how many steps the address bits are shifted. Total shift is $\mathbf{sh1} + 8$ . If, for example, $\mathbf{sh1}$ equals 0 the internal address 29 - 9 is shifted down to pins A21 - A1 and if $\mathbf{sh1}$ equals 7 the internal address 29 - 16 is shifted down to pins A14 - A1. | 0 - 7 | | 26 - 24 | sh0 | Row address shift for group 0. See sh1 for details. | 0 - 7 | | 23 | W | DRAM bus width. | 0 = bw16<br>1 = bw32 | | 22 | c | cas organization, byte- or bank-wise. | 0 = byte<br>1 = bank | | 21 | e | DRAM type select, fast page or EDO. | 0 = fast<br>1 = edo | | 20 - 16 | group_sel | Selects which address bit that will be used to select between the two groups of DRAM banks. Always group 0 (grp0), always group 1 (grp1) or use address bit to select between groups. | 0 = grp0<br>1 = grp1<br>9 = bit9<br>10 = bit10<br>11 = bit11<br>12 = bit12<br>13 = bit13<br>14 = bit14<br>15 = bit15<br>16 = bit16<br>17 = bit17<br>18 = bit18<br>19 = bit19<br>20 = bit20<br>21 = bit21<br>22 = bit22<br>23 = bit23<br>24 = bit24<br>25 = bit25<br>26 = bit26<br>27 = bit27<br>28 = bit28<br>29 = bit29 | ## Bit Assignments of R\_DRAM\_CONFIG (continued) | Bit(s) | Name | Description | State/Range | |---------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 - 13 | ca1 | Column address range for group 1. This selects how many bits above bit 8 that are used for the column address. If ca1 equals 0 up to and including address bit 8 are used, if ca1 equals 7 up to and including bit 15 are used. | 0 - 7 | | 12 - 8 | bank23sel | Selects which address bit that will be used to select between the two banks in group 1. Always group 0 (grp0), always group 1 (grp1) or use address bit to select between groups. | 0 = bank0<br>1 = bank1<br>9 = bit9<br>10 = bit10<br>11 = bit11<br>12 = bit12<br>13 = bit13<br>14 = bit14<br>15 = bit15<br>16 = bit16<br>17 = bit17<br>18 = bit18<br>19 = bit19<br>20 = bit20<br>21 = bit21<br>22 = bit22<br>23 = bit23<br>24 = bit24<br>25 = bit25<br>26 = bit26<br>27 = bit27<br>28 = bit28<br>29 = bit29 | | 7 - 5 | ca0 | Column address range for group 0. See ca1 for details. | 0 - 7 | | 4 - 0 | bank01sel | Selects which address bit that will be used to select between the two banks in group 0. See bank23sel for details. | 0 = bank0<br>1 = bank1<br>9 = bit9<br>10 = bit10<br>11 = bit11<br>12 = bit12<br>13 = bit13<br>14 = bit14<br>15 = bit15<br>16 = bit16<br>17 = bit17<br>18 = bit18<br>19 = bit19<br>20 = bit20<br>21 = bit21<br>22 = bit22<br>23 = bit23<br>24 = bit24<br>25 = bit25<br>26 = bit26<br>27 = bit27<br>28 = bit28<br>29 = bit29 | ## 18.2.7 R\_SDRAM\_CONFIG ## **SDRAM Configuration Register, General Characteristics** | ID of register | R_SDRAM_CONFIG | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0xC | Read/Write | Write only | | Address | 0xB000000C | Initial value | Unknown | ## Bit Assignments of R\_SDRAM\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | wmm1 | Wide module mode for group 1. In wide module mode, all 8 dqm outputs are used in each group. The use of dqm7 - dqm4 or dqm3 - dqm0 is selected by the highest address bit in the selected column address range (ca1 field). The ca1 field should in this case be set to one bit higher than the highest column address bit to the SDRAM. This mode is used with 64-bit wide SDRAM modules that do not have separate chip selects for the upper and lower half of the data bus. | 0 = norm<br>1 = wmm | | 30 | wmm0 | Wide module mode for group 0. See $wmm1$ for description. | 0 = norm<br>1 = wmm | | 29 - 27 | sh1 | This field gives the row address shift for group 1. The value given decides how many steps the address bits are shifted. Total shift is $\mathbf{sh1} + 8$ . If, for example, $\mathbf{sh1}$ equals 0 the internal address 29 - 9 is shifted down to pins A21 - A1 and if $\mathbf{sh1}$ equals 7 the internal address 29 - 16 is shifted down to pins A14 - A1. | 0 - 7 | | 26 - 24 | sh0 | Row address shift for group 0. See sh1 for details. | 0 - 7 | | 23 | W | SDRAM bus width. | 0 = bw16<br>1 = bw32 | | 22 | type1 | This field selects 2 or 4 SDRAM banks for group 1. | 0 = bank2<br>1 = bank4 | | 21 | type0 | This field selects 2 or 4 SDRAM banks for group 0. | 0 = bank2<br>1 = bank4 | | 20 - 16 | group_sel | Selects which address bit that will be used to select between the two groups of SDRAM banks. Always group 0 (grp0), always group 1 (grp1) or use address bit to select between groups. | 0 = grp0<br>1 = grp1<br>9 = bit9<br>10 = bit10<br>11 = bit11<br>12 = bit12<br>13 = bit13<br>14 = bit14<br>15 = bit15<br>16 = bit16<br>17 = bit17<br>18 = bit18<br>19 = bit19<br>20 = bit20<br>21 = bit21<br>22 = bit22<br>23 = bit23<br>24 = bit24<br>25 = bit25<br>26 = bit26<br>27 = bit27<br>28 = bit28<br>29 = bit29 | #### Bit Assignments of R\_SDRAM\_CONFIG (continued) | Bit(s) | Name | Description | State/Range | |---------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 - 13 | ca1 | Column address range for group 1. This selects how many bits above bit 8 that are used for the column address. If ca1 equals 0 up to and including address bit 8 are used, If ca1 equals 7 up to and including bit 15 are used. | 0 - 7 | | 12 - 8 | bank_sel1 | Selects which address bit that will be used to select between bank 0/1 in group 1. In 4-bank mode bank 2/3 will be controlled by the next higher order address bit. | 9 = bit9<br>10 = bit10<br>11 = bit11<br>12 = bit12<br>13 = bit13<br>14 = bit14<br>15 = bit15<br>16 = bit16<br>17 = bit17<br>18 = bit18<br>19 = bit19<br>20 = bit20<br>21 = bit21<br>22 = bit22<br>23 = bit23<br>24 = bit24<br>25 = bit25<br>26 = bit26<br>27 = bit27<br>28 = bit28<br>29 = bit29 | | 7 - 5 | ca0 | Column address range for group 0. See ca1 for details. | 0 - 7 | | 4 - 0 | bank_sel0 | Selects which address bit that will be used to select between banks 0/1 in group 0. See bank_sel1 for details. | 9 = bit9<br>10 = bit10<br>11 = bit11<br>12 = bit12<br>13 = bit13<br>14 = bit14<br>15 = bit15<br>16 = bit16<br>17 = bit17<br>18 = bit18<br>19 = bit19<br>20 = bit20<br>21 = bit21<br>22 = bit22<br>23 = bit23<br>24 = bit24<br>25 = bit25<br>26 = bit26<br>27 = bit27<br>28 = bit28<br>29 = bit29 | Note: When using one group only, set register field **group\_sel** to either **grp0** or **grp1**. When using two groups, both groups must be configured equally as to row address shift and cas address range bits, i.e. both groups must have the same size. # 18.3 External DMA Registers ## 18.3.1 R\_EXT\_DMA\_0\_CMD ## **External DMA Channel 0 Command Register, General Characteristics** | ID of register | R_EXT_DMA_0_CMD | Size | 32 bits | |----------------|-----------------|---------------|------------| | Offset | 0x10 | Read/Write | Write only | | Address | 0xB0000010 | Initial value | 0 | ## Bit Assignments of R\_EXT\_DMA\_0\_CMD | Bit(s) | Name | Description | State/Range | |---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------| | 31 - 24 | Reserved | - | 0 | | 23 | cnt | This field enables/disables the transfer counter. If it is set (enable), the external DMA transfer will be stopped when trf_count reaches 0. | 0 = disable<br>1 = enable | | 22 | rqpol | Request polarity. Active high (ahigh) or active low (alow). | 0 = ahigh<br>1 = alow | | 21 | apol | Acknowledge polarity. Active high (ahigh) or active low (alow). | 0 = ahigh<br>1 = alow | | 20 | rq_ack | Request/acknowledge mode. | 0 = burst<br>1 = handsh | | 19 - 18 | wid | This field decides the width of the transfer, 8 bits (byte), 16 bits (word) or 32 bits (dword). | 0 = byte<br>1 = word<br>2 = dword | | 17 | dir | Direction. | 0 = input<br>1 = output | | 16 | run | Start/stop. | 0 = stop<br>1 = start | | 15 - 0 | trf_count | Counter for number of transfers. If <b>cnt</b> is set, the external DMA transfer will stop when <b>trf_count</b> has counted down to 0. <b>trf_count</b> = 0 gives 65536 transfers. <b>trf_count</b> is always counting, irrespective of the state of <b>cnt</b> . | 0 - 65535 | ## 18.3.2 R\_EXT\_DMA\_0\_STAT #### **External DMA Channel 0 Status Register, General Characteristics** | ID of register | R_EXT_DMA_0_STAT | Size | 32 bits | |----------------|------------------|---------------|-----------| | Offset | 0x10 | Read/Write | Read only | | Address | 0xB0000010 | Initial value | 0 | ## Bit Assignments of R\_EXT\_DMA\_0\_STAT | Bit(s) | Name | Description | State/Range | |---------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 31 - 17 | Reserved | - | | | 16 | run | Start/stop. | 0 = stop<br>1 = start | | 15 - 0 | trf_count | Counter for number of transfers. The counter is initialized by writing to the <b>tfr_count</b> field of the R_EXT_DMA_0_CMD register, and is decremented by 1 for each DMA access. When the counter reaches 0, the <b>run</b> bit is cleared if the <b>cnt</b> bit in the R_EXT_DMA_0_CMD register is set. | 0 - 65535 | ## 18.3.3 R\_EXT\_DMA\_0\_ADDR #### **External DMA Channel 0 Address Register, General Characteristics** | ID of register | R_EXT_DMA_0_ADDR | Size | 32 bits | |----------------|------------------|---------------|------------| | Offset | 0x14 | Read/Write | Write only | | Address | 0xB0000014 | Initial value | Unknown | ## Bit Assignments of R\_EXT\_DMA\_0\_ADDR | Bit(s) | Name | Description | State/Range | |---------|-----------|----------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 30 | Reserved | Always 2. | 2 | | 29 - 2 | ext0_addr | Bit 29 - 2 of the address to where the external DMA channel 0 accesses are mapped. Bit 30 and 1 - 0 of the address are always 0. | | | 1 - 0 | Reserved | Always 0. | 0 | ## 18.3.4 R\_EXT\_DMA\_I\_CMD #### **External DMA Channel 1 Command Register, General Characteristics** | ID of register | R_EXT_DMA_1_CMD | Size | 32 bits | |----------------|-----------------|---------------|------------| | Offset | 0x18 | Read/Write | Write only | | Address | 0xB0000018 | Initial value | 0 | ## Bit Assignments of R\_EXT\_DMA\_1\_CMD | Bit(s) | Name | Description | State/Range | |---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------| | 31 - 24 | Reserved | - | 0 | | 23 | cnt | This field enables/disables the transfer counter. If it is set (enable), the external DMA transfer will be stopped when trf_count reaches 0. | 0 = disable<br>1 = enable | | 22 | rqpol | Request polarity, active high (ahigh) or active low (alow). | 0 = ahigh<br>1 = alow | | 21 | apol | Acknowledge polarity, active high (ahigh) or active low (alow). | 0 = ahigh<br>1 = alow | | 20 | rq_ack | Request/acknowledge mode. | 0 = burst<br>1 = handsh | | 19 - 18 | wid | This field decides the width of the transfer, 8 bits (byte), 16 bits (word) or 32 bits (dword). | 0 = byte<br>1 = word<br>2 = dword | | 17 | dir | Direction. | 0 = input<br>1 = output | | 16 | run | Start/stop. | 0 = stop<br>1 = start | | 15 - 0 | trf_count | Counter for number of transfers. If <b>cnt</b> is set, the external DMA transfer will stop when <b>trf_count</b> has counted down to 0. <b>trf_count</b> = 0 gives 65536 transfers. <b>trf_count</b> is always counting. | 0 - 65535 | ## 18.3.5 R\_EXT\_DMA\_I\_STAT # **External DMA Channel 1 Status Register, General Characteristics** | ID of register | R_EXT_DMA_1_STAT | Size | 32 bits | |----------------|------------------|---------------|-----------| | Offset | 0x18 | Read/Write | Read only | | Address | 0xB0000018 | Initial value | 0 | ## Bit Assignments of R\_EXT\_DMA\_1\_STAT | Bit(s) | Name | Description | State/Range | |---------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 31 - 17 | Reserved | - | | | 16 | run | Start/stop. | 0 = stop<br>1 = start | | 15 - 0 | trf_count | Counter for number of transfers. The counter is initialized by writing to the <b>tfr_count</b> field of the R_EXT_DMA_1_CMD register, and is decremented by 1 for each DMA access. When the counter reaches 0, the <b>run</b> bit is cleared if the <b>cnt</b> bit in the R_EXT_DMA_1_CMD register is set. | 0 - 65535 | ## 18.3.6 R\_EXT\_DMA\_I\_ADDR #### **External DMA Channel 1 Address Register, General Characteristics** | ID of register | R_EXT_DMA_1_ADDR | Size | 32 bits | |----------------|------------------|---------------|------------| | Offset | 0x1C | Read/Write | Write only | | Address | 0xB000001C | Initial value | Unknown | ## Bit Assignments of R\_EXT\_DMA\_1\_ADDR | Bit(s) | Name | Description | State/Range | |---------|-----------|----------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 30 | Reserved | Always 2. | 2 | | 29 - 2 | ext0_addr | Bit 29 - 2 of the address to where the external DMA channel 0 accesses are mapped. Bit 30 and 1 - 0 of the address are always 0. | | | 1 - 0 | Reserved | Always 0. | 0 | # 18.4 Timer Registers ## 18.4.1 R\_TIMER\_CTRL #### **Timer Control Register, General Characteristics** | ID of register | R_TIMER_CTRL | Size | 32 bits | |----------------|--------------|---------------|------------| | Offset | 0x20 | Read/Write | Write only | | Address | 0xB0000020 | Initial value | Unknown | #### Bit Assignments of R\_TIMER\_CTRL | Bit(s) | Name | Description | State/Range | |---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 24 | timerdiv1 | This field contains the divide factor for timer 1. The usable range is $2$ - $256$ . A divide factor of $256$ is achieved by setting the field to 0. If the timer is used as an interval timer, i.e. generating a fixed interrupt frequency, the frequency will be the <b>clksel1</b> frequency divided by the divide factor. | 0 - 255 | | 23 - 16 | timerdiv0 | This field contains the divide factor for timer 0. See $timerdiv1$ . | 0 - 255 | | 15 | presc_timer1 | If this bit is set, the programmable clock divider is used to clock timer 1, thus overriding all settings to clksel1. | 0 = normal<br>1 = prescale | | 14 | i1 | This bit is the interrupt acknowledge for timer 1. An interrupt is acknowledged by setting this bit to <b>clr</b> . The bit value is not saved, but reverts to <b>nop</b> once the interrupt has been cleared. | 0 = nop<br>1 = clr | | 13 - 12 | tm1 | This field defines the operation of timer 1: if the value is <b>stop_ld</b> , <b>the timer</b> stops and loads the divide factor, if the value is <b>freeze</b> , the timer stops and preserves current count value and if it is <b>run</b> , the timer starts. <b>reserved</b> should not be used. | 0 = stop_ld<br>1 = freeze<br>2 = run<br>3 = reserved | | 11 - 8 | clksel1 | Clock select for timer 1. cascade0 cascades this timer with timer 0. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = cascade0 | | 7 | presc_ext | This bit is used to select the clock for <b>flexible</b> in the <b>clksel0</b> field. If it is set to <b>prescale</b> the programmable clock divider clock is selected. If it set to <b>external</b> the external clock is selected. | 0 = prescale<br>1 = external | | 6 | i0 | This bit is the interrupt acknowledge for timer 0. See i1. | 0 = nop<br>1 = clr | #### Bit Assignments of R\_TIMER\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 - 4 | tm0 | This field defines the operation of timer 0. See $tm1$ . | 0 = stop_ld<br>1 = freeze<br>2 = run<br>3 = reserved | | 3 - 0 | clksel0 | Clock select for timer 0. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = flexible | ## 18.4.2 R\_TIMER\_DATA ## **Timer Data Register, General Characteristics** | ID of register | R_TIMER_DATA | Size | 32 bits | |----------------|--------------|---------------|----------------------------------------------------------| | Offset | 0x20 | Read/Write | Read only | | Address | 0xB0000020 | Initial value | Bit 31 - 16<br>unknown, bit 15 - 0<br>set to 0 at reset. | ## Bit Assignments of R\_TIMER\_DATA | Bit(s) | Name | Description | State/Range | |---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 24 | timer1 | Current count value for timer1. Note that this is a down counter that starts at the <b>timerdiv1</b> value and then counts down to 1. | 0-255 | | 23 - 16 | timer0 | Current count value for timer0. Note that this is a down counter that starts at the <b>timerdiv0</b> value and then counts down to 1. | 0-255 | | 15 - 8 | clkdiv_high | High byte of clock divider. The bits in this field each toggle at a specific frequency according to: bit 8 - 38.4 kHz, bit 9 - 19.2 kHz, bit 10 - 9.6 kHz, bit 11 - 4.8 kHz, bit 12 - 2.4 kHz, bit 13 - 1.2 kHz, bit 14 - 600 Hz, bit 15 - 300 Hz. | | | 7 - 0 | clkdiv_low | Low byte of clock divider. The bits in this field each toggle at a specific frequency according to: bit 0 - 7.3728 MHz, bit 1 - 3.6864 MHz, bit 2 - 1.8432 MHz, bit 3 - 921.6 kHz, bit 4 - 460.8 kHz, bit 5 - 230.4 kHz, bit 6 - 115.2 kHz, bit 7 - 57.6 kHz. | | ## 18.4.3 R\_TIMER01\_DATA #### **Timer 01 Data Register** | ID of register | R_TIMER01_DATA | Size | 16 bits | |----------------|----------------|---------------|-----------| | Offset | 0x22 | Read/Write | Read only | | Address | 0xB0000022 | Initial value | Unknown | ## Bit Assignments of R\_TIMER01\_DATA | Bit(s) | Name | Description | State/Range | |--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | count | The combination of the values in fields <b>timer1</b> and <b>timer0</b> in R_TIMER_DATA ( <b>timer1[7:0]</b> , <b>timer0[7:0]</b> ). Typically used when the timers are cascaded. | 0-65535 | **Note:** This is a 16 bit wide register that is part of register R\_TIMER\_DATA. ## 18.4.4 R\_TIMERO\_DATA #### **Timer 0 Data Register, General Characteristics** | ID of register | R_TIMER0_DATA | Size | 8 bits | |----------------|---------------|---------------|-----------| | Offset | 0x22 | Read/Write | Read only | | Address | 0xB0000022 | Initial value | Unknown | #### Bit Assignments of R\_TIMER0\_DATA | Bit(s) | Name | Description | State/Range | |--------|-------|---------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 0 | count | Current count value for timer0. Note that this is a down counter that starts at the <b>timerdiv0</b> value and then counts down to 1. | 0-255 | **Note:** This is a 8 bit wide register which is part of register R\_TIMER\_DATA. ## 18.4.5 R\_TIMER1\_DATA #### **Timer 1 Data Register, General Characteristics** | ID of register | R_TIMER1_DATA | Size | 8 bits | |----------------|---------------|---------------|-----------| | Offset | 0x23 | Read/Write | Read only | | Address | 0xB0000023 | Initial value | Unknown | ## Bit Assignments of R\_TIMER1\_DATA | Bit(s) | Name | Description | State/Range | |--------|-------|---------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 0 | count | Current count value for timer1. Note that this is a down counter that starts at the <b>timerdiv1</b> value and then counts down to 1. | 0-255 | **Note:** This is a 8 bit wide register that is part of register R\_TIMER\_DATA. ## 18.4.6 R\_WATCHDOG ## **Watchdog Register, General Characteristics** | ID of register | R_WATCHDOG | Size | 32 bits | |----------------|------------|---------------|------------| | Offset | 0x24 | Read/Write | Write only | | Address | 0xB0000024 | Initial value | 0 | ## Bit Assignments of R\_WATCHDOG | Bit(s) | Name | Description | State/Range | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 31 - 4 | Reserved | - | 0 | | 3 - 1 | key | Key value for the watchdog. | 0 - 7 | | 0 | enable | Watchdog start/stop. If started, the watchdog timer generates an NMI if it is not restarted or stopped within 0.1 s. If it still is not restarted or stopped after an additional 3.3 ms, it resets the chip. Restart and stop only take effect if the new key value matches the inverse of the previously set key value. | 0 = stop<br>1 = start | ## 18.4.7 R\_CLOCK\_PRESCALE #### **Clock Prescale Register, General Characteristics** | ID of register | R_CLOCK_PRESCALE | Size | 32 bits | |----------------|------------------|---------------|------------| | Offset | 0xF0 | Read/Write | Write only | | Address | 0xB00000F0 | Initial value | Unknown | ## Bit Assignments of R\_CLOCK\_PRESCALE | Bit(s) | Name | Description | State/Range | |---------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | ser_presc | This fields gives the divide factor for serial clock prescaling. It is used when another baud rate than those predefined in the serial port control registers is needed for the asynchronous serial ports. The usable range is 2 - 65536. A divide factor of 65536 is achieved by setting the field to 0. The resulting baud rate equals 3.125MHz divided by the divide factor. The prescaling starts when the field is written. | 0, 2-65535 | | 15 - 0 | tim_presc | This field gives the divide factor for timer clock prescaling. It is used when another frequency than those predefined in R_TIMER_CTRL is needed for the internal timers. The usable range is 2 - 65536. A divide factor of 65536 is achieved by setting the field to 0. The generated frequency equals 25MHz divided by the divide factor. Thus the highest available frequency is 12.5 MHz and lowest available frequency is 381.5Hz. The prescaling starts when the field is written. | 0, 2-65535 | ## 18.4.8 R\_TIMER\_PRESCALE #### **Timer Prescale Register, General Characteristics** | ID of register | R_TIMER_PRESCALE | Size | 16 bits | |----------------|------------------|---------------|------------| | Offset | 0xF0 | Read/Write | Write only | | Address | 0xB00000F0 | Initial value | Unknown | #### Bit Assignments of R\_TIMER\_PRESCALE | Bit(s) | Name | Description | State/Range | |--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | tim_presc | This field gives the divide factor for timer clock prescaling. It is used when another frequency than those predefined in R_TIMER_CTRL is needed for the internal timers. The usable range is 2 - 65536. A divide factor of 65536 is achieved by setting the field to 0. The generated frequency equals 25MHz divided by the divide factor. Thus the highest available frequency is 12.5 MHz and lowest available frequency is 381.5Hz. The prescaling starts when the field is written. | 0, 2-65535 | **Note:** This is a 16 bit wide register that is part of register R\_CLOCK\_PRESCALE. ## 18.4.9 R\_PRESCALE\_STATUS #### **Prescale Status Register, General Characteristics** | ID of register | R_PRESCALE_STATUS | Size | 32 bits | |----------------|-------------------|---------------|-----------| | Offset | 0xF0 | Read/Write | Read only | | Address | 0xB00000F0 | Initial value | Unknown | # Bit Assignments of R\_PRESCALE\_STATUS | Bit(s) | Name | Description | State/Range | |---------|------------|---------------------------------------------------------------|-------------| | 31 - 16 | ser_status | Contains the current count value of the serial divide factor. | 0-65535 | | 15 - 0 | tim_status | Contains the current count value of the timer divide factor. | 0-65535 | ## 18.4.10 R\_TIM\_PRESC\_STATUS #### **Timer Prescale Status Register, General Characteristics** | ID of register | R_TIM_PRESC_STATUS | Size | 16 bits | |----------------|--------------------|---------------|-----------| | Offset | 0xF0 | Read/Write | Read only | | Address | 0xB00000F0 | Initial value | Unknown | ## Bit Assignments of R\_TIM\_PRESC\_STATUS | Bit(s) | Name | Description | State/Range | |--------|------------|--------------------------------------------------------------|-------------| | 15 - 0 | tim_status | Contains the current count value of the timer divide factor. | 0-65535 | **Note:** This is a 16 bit wide register that is part of register R\_CLOCK\_PRESCALE. ## 18.5 Shared RAM Interface Registers To initiate the shared RAM interface, first write to R\_GEN\_CONFIG, then to R\_SHARED\_RAM\_ADDR, and finally write to R\_SHARED\_RAM\_CONFIG with ONLY the **enable** bit set. #### 18.5.1 R\_SHARED\_RAM\_CONFIG #### **Shared RAM Configuration Register, General Characteristics** | ID of register | R_SHARED_RAM_CONFIG | Size | 32 bits | |----------------|---------------------|---------------|------------| | Offset | 0x40 | Read/Write | Write only | | Address | 0xB0000040 | Initial value | 0 | #### Bit Assignments of R\_SHARED\_RAM\_CONFIG | Bit(s) | Name | Description | State/Range | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------| | 31 - 4 | Reserved | - | 0 | | 3 | width | This field decides the shared RAM interface width, <b>byte</b> (8 bits) or <b>word</b> (16 bits). | 0 = byte<br>1 = word | | 2 | enable | If this field is set the shared RAM interface is enabled. | 0 = no<br>1 = yes | | 1 | pint | If this field is set, a peripheral interrupt is generated. <b>int</b> generates a 600ns active low pulse on the <b>pr_int</b> output. The bit value is not saved, but reverts to <b>nop</b> once the pulse has been generated. | 0 = nop<br>1 = int | | 0 | clri | This field clears the interrupt from the <b>intio</b> input. The bit value is not saved, but reverts to <b>nop</b> once the interrupt has been cleared. | 0 = nop<br>1 = clr | ## 18.5.2 R\_SHARED\_RAM\_ADDR #### **Shared RAM Address Register, General Characteristics** | ID of register | R_SHARED_RAM_ADDR | Size | 32 bits | |----------------|-------------------|---------------|------------| | Offset | 0x44 | Read/Write | Write only | | Address | 0xB0000044 | Initial value | Unknown | ## Bit Assignments of R\_SHARED\_RAM\_ADDR | Bit(s) | Name | Description | State/Range | |---------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 30 | Reserved | This part of the Shared RAM address is always 2 (10 binary), to address non cached, non DRAM area. | 2 | | 29 - 8 | base_addr | This field sets bit 29-8 of the base address for the shared RAM area. Bit 30 and 7 - 0 of the base address are always 0. Shared RAM accesses are always non-cacheable. | | | 7 - 0 | Reserved | - | 0 | # 18.6 General Configuration Registers ## 18.6.1 R\_GEN\_CONFIG #### **General Configuration Register, General Characteristics** | ID of register | R_GEN_CONFIG | Size | 32 bits | |----------------|--------------|---------------|------------| | Offset | 0x2C | Read/Write | Write only | | Address | 0xB000002C | Initial value | 0 | #### Bit Assignments of R\_GEN\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------| | 31 | par_w | If this field is set, parallel port wide (ecp_16) is selected. (note 1) | 0 = disable<br>1 = select | | 30 | usb2 | This field selects USB port 2. | 0 = disable<br>1 = select | | 29 | usb1 | This field selects USB port 1. | 0 = disable<br>1 = select | | 28 | Reserved | - | 0 | | 27 | g24dir | This field selects direction for pin ${\bf g24}$ (if configured). | 0 = in<br>1 = out | | 26 | g16_23dir | This field selects direction for pins $g16$ - $23$ (if configured). | 0 = in<br>1 = out | | 25 | g8_15dir | This field selects direction for pins ${\bf g8}$ -15 (if configured). | 0 = in<br>1 = out | | 24 | g0dir | This field selects direction for pin ${\bf g0}$ (if configured). | 0 = in<br>1 = out | | 23 | dma9 | This field decides the configuration for DMA channel 9. It can be connected to either USB or serial port 1. (note 2) | 0 = usb<br>1 = serial1 | | 22 | dma8 | This field decides the configuration for DMA channel 8. It can be connected to either USB or serial port 1. (note 2) | 0 = usb<br>1 = serial1 | | 21 - 20 | dma7 | This field decides the configuration for DMA channel 7. It is either unused, connected to serial port 0, to external DMA 1 or to internal DMA 6 (memory to memory DMA). | 0 = unused<br>1 = serial0<br>2 = extdma1<br>3 = intdma6 | | 19 - 18 | dma6 | This field decides the configuration for DMA channel 6. It is either unused, connected to serial port 0, to external DMA 1 or to internal DMA 7 (memory to memory DMA). | 0 = unused<br>1 = serial0<br>2 = extdma1<br>3 = intdma7 | | 17 - 16 | dma5 | This field decides the configuration for DMA channel 5. It can be connected to parallel port 1, SCSI 1, serial port 3 or external DMA 0. (note 2) | 0 = par1<br>1 = scsi1<br>2 = serial3<br>3 = extdma0 | | 15 - 14 | dma4 | This field decides the configuration for DMA channel 4. It can be connected to parallel port 1, SCSI 1, serial port 3 or external DMA 0. (note 2) | 0 = par1<br>1 = scsi1<br>2 = serial3<br>3 = extdma0 | ## Bit Assignments of R\_GEN\_CONFIG (continued) | Bit(s) | Name | Description | State/Range | |---------|--------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | 13 - 12 | dma3 | This field decides the configuration of DMA channel 3. It can be connected to parallel port 0, SCSI 0, serial port 2 or ATA. (note 2) | 0 = par0<br>1 = scsi0<br>2 = serial2<br>3 = ata | | 11 - 10 | dma2 | This field decides the configuration of DMA channel 2. It can be connected to parallel port 0, SCSI 0, serial port 2 or ATA. (note 2) | 0 = par0<br>1 = scsi0<br>2 = serial2<br>3 = ata | | 9 | mio_w | This field selects shared RAM wide (16 bits). The <b>mio</b> bit has to be set (see below). (note 3) | 0 = disable<br>1 = select | | 8 | ser3 | This field selects serial port 3. (note 3) | 0 = disable<br>1 = select | | 7 | par1 | This field selects parallel port 1. (note 3) | 0 = disable<br>1 = select | | 6 | scsi0w | This field selects wide (16 bits) scsi for scsi port 0. Bit <b>scsi0</b> has to be set (see below). (note 3) | 1 = select<br>0 = disable | | 5 | scsi1 | This field selects scsi port 1 (8 bits). (note 3) | 0 = disable<br>1 = select | | 4 | mio | This field selects shared RAM interface. (note 3) | 0 = disable<br>1 = select | | 3 | ser2 | This field selects serial port 2. (note 3) | 0 = disable<br>1 = select | | 2 | par0 | This field selects parallel port 0. (note 3) | 0 = disable<br>1 = select | | 1 | ata | This field selects ata. (note 3) | 0 = disable<br>1 = select | | 0 | scsi0 | This field select scsi 0. If <b>scsi0w</b> is also set, scsi wide is selected. (note 3) | 0 = disable<br>1 = select | - **Note 1:** Both the **wide** field in R\_PAR0\_CONFIG and the **par0** field in R\_GEN\_CONFIG must also be set, in order to activate the wide-mode in the parallel port. - **Note 2:** When a DMA channel is not used, it should be connected to an unused device. For example if DMA channel 5 and parallel port p1 are not in use, connect DMA channel 5 to parallel port p1. - Note 3: Only some combinations of bits, that are set, are meaningful. For example parallel port p0 and SCSI-8 port p0 can not be used simultaneously. See chapter 19.10 *Multiplexed Interfaces* for details. - **Note 4:** There must be a delay of >120 ns between writes to bits 23 to 0. Writing to bits 23 to 8 without writing to bits 7 to 0 has an undefined result. # 18.6.2 R\_GEN\_CONFIG\_II # **General Configuration register II, General Characteristics** | ID of register | R_GEN_CONFIG_II | Size | 32 bits | |----------------|-----------------|---------------|------------| | Offset | 0x34 | Read/Write | Write only | | Address | 0xB0000034 | Initial value | 0 | # Bit Assignments of R\_GEN\_CONFIG\_II | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | 31 - 7 | Reserved | - | 0 | | 6 | sermode3 | This bit decides if serial port 3 is used in asynchronous or in synchronous mode. If this field is set to <b>sync</b> , serial port 3 is in the synchronous mode. | 0 = async<br>1 = sync | | 5 | Reserved | - | 0 | | 4 | sermode1 | This bit decides if serial port 1 is used in asynchronous or in synchronous mode. If this field is set to <b>sync</b> , serial port 1 is in the synchronous mode. | 0 = async<br>1 = sync | | 3 | Reserved | - | 0 | | 2 | ext_clk | If this bit is set, the external clock is selected for the serial ports and the timers. | 0 = disable<br>1 = select | | 1 - 0 | Reserved | - | 0 | # 18.6.3 R\_PORT\_G\_DATA #### **General Port Data Register, General Characteristics** | ID of register | R_PORT_G_DATA | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0x28 | Read/Write | Read/Write | | Address | 0xB0000028 | Initial value | 0 | # Bit Assignments of R\_PORT\_G\_DATA | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | data | Through this register data can be read from and written to the IO pins ${\tt g0-31}$ . The different IO-devices are multiplexed on these pins. The availability of the pins varies with the setting of R_GEN_CONFIG bits $0$ - $9$ . | | # 18.7 General Port Configuration Registers # 18.7.1 R\_PORT\_PA\_SET #### **General Port PA Set Register, General Characteristics** | ID of register | R_PORT_PA_SET | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0x30 | Read/Write | Write only | | Address | 0xB0000030 | Initial value | 0 | # Bit Assignments of R\_PORT\_PA\_SET | Bit(s) | Name | Description | State/Range | |---------|----------|--------------------------------------------------------------------------------------------|-------------------------| | 31 - 16 | Reserved | - | 0 | | 15 | dir7 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 7 in general port PA. | 0 = input<br>1 = output | | 14 | dir6 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 6 in general port PA. | 0 = input<br>1 = output | | 13 | dir5 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 5 in general port PA. | 0 = input<br>1 = output | | 12 | dir4 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 4 in general port PA. | 0 = input<br>1 = output | | 11 | dir3 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 3 in general port PA. | 0 = input<br>1 = output | | 10 | dir2 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 2 in general port PA. | 0 = input<br>1 = output | | 9 | dir1 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 1 in general port PA. | 0 = input<br>1 = output | | 8 | dir0 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 0 in general port PA. | 0 = input<br>1 = output | | 7 - 0 | data_out | Data byte to general port PA. | 0 - 255 | # 18.7.2 R\_PORT\_PA\_DATA #### **General Port PA Data Register General Characteristics** | ID of register | R_PORT_PA_DATA | Size | 8 bits | |----------------|----------------|---------------|------------| | Offset | 0x30 | Read/Write | Write only | | Address | 0xB0000030 | Initial value | 0 | #### Bit Assignments of R\_PORT\_PA\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------|-------------| | 7 - 0 | data_out | Data byte to general port PA. | 0 - 255 | **Note:** This is an 8 bit wide register that is part of register R\_PORT\_PA\_SET. # 18.7.3 R\_PORT\_PA\_DIR #### **General Port PA Direction Register, General Characteristics** | ID of register | R_PORT_PA_DIR | Size | 8 bits | |----------------|---------------|---------------|------------| | Offset | 0x31 | Read/Write | Write only | | Address | 0xB0000031 | Initial value | 0 | # Bit Assignments of R\_PORT\_PA\_DIR | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------|-------------------------| | 7 | dir7 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 7 in general port PA. | 0 = input<br>1 = output | | 6 | dir6 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 6 in general port PA. | 0 = input<br>1 = output | | 5 | dir5 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 5 in general port PA. | 0 = input<br>1 = output | | 4 | dir4 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 4 in general port PA. | 0 = input<br>1 = output | | 3 | dir3 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 3 in general port PA. | 0 = input<br>1 = output | | 2 | dir2 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 2 in general port PA. | 0 = input<br>1 = output | | 1 | dir1 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 1 in general port PA. | 0 = input<br>1 = output | | 0 | dir0 | This bit sets the direction ( <b>input</b> or <b>output</b> ) of bit 0 in general port PA. | 0 = input<br>1 = output | **Note:** This is an 8 bit wide register that is part of register R\_PORT\_PA\_SET. # 18.7.4 R\_PORT\_PA\_READ # **General Port PA Read Register, General Characteristics** | ID of register | R_PORT_PA_READ | Size | 32 bits | |----------------|----------------|---------------|-----------| | Offset | 0x30 | Read/Write | Read only | | Address | 0xB0000030 | Initial value | Unknown | # Bit Assignments of R\_PORT\_PA\_READ | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------|-------------| | 31 - 8 | Reserved | - | | | 7 - 0 | data_in | Data byte from general port PA. | 0 - 255 | # 18.7.5 R\_PORT\_PB\_SET # **General Port PB Set Register, General Characteristics** | ID of register | R_PORT_PB_SET | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0x38 | Read/Write | Write only | | Address | 0xB0000038 | Initial value | 0 | # Bit Assignments of R\_PORT\_PB\_SET | Bit(s) | Name | Description | State/Range | |---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 31 - 30 | Reserved | - | 0 | | 29 | syncser3 | If this bit is set, <b>pb7</b> is used for synchronous serial port p3, which in some modes needs an extra signal. The setting of the <b>syncser3</b> field overrides that of the <b>cs7</b> and <b>dir7</b> fields. The setting of the <b>syncser3</b> field is ignored if the <b>scsi1</b> field is set to <b>enph</b> . | 0 = port_cs<br>1 = ss3extra | | 28 | syncser1 | If this bit is set, <b>pb4</b> is used for synchronous serial port p1, which in some modes needs an extra signal. The setting of the <b>syncser1</b> field overrides that of the <b>cs4</b> and <b>dir4</b> fields. The setting of the <b>syncser1</b> field is ignored if the <b>scsi0</b> field is set to <b>enph</b> . | 0 = port_cs<br>1 = ss1extra | | 27 | i2c_en | This bit enables or disables the I2C mode at <b>pb1</b> and <b>pb0</b> . | 0 = off<br>1 = on | | 26 | i2c_d | This bit is the I2C output data bit. When the I2C mode is selected (field $i2c\_en = on$ ) and the output is enabled (field $i2c\_oe\_= enable$ ), $i2c\_d$ is output on $pb0$ . The $i2c\_d$ field is ignored if the I2C mode is not enabled ( $i2c\_en = off$ ). (note) | 0 - 1 | | 25 | i2c_clk | This bit is the I2C clock signal. When the I2C mode is selected (field i2c_en = on), i2c_clk is output on pb1. The i2c_clk field is ignored if the I2C mode is not enabled (i2c_en = off). | 0 - 1 | | 24 | i2c_oe_ | This bit is the output enable for the I2C mode. When the I2C mode is selected (field $i2c\_en = on$ ), this field enables or disables the output at $pb0$ . The $i2c\_oe\_$ field is ignored if the I2C mode is not enabled ( $i2c\_en = off$ ). | 0 = enable<br>1 = disable | | 23 | cs7 | This bit determines whether <b>pb7</b> is a general I/O or peripheral chip-select signal. The setting of the <b>cs7</b> field is ignored if the <b>scsi1</b> field is set to <b>enph</b> or if the <b>syncser3</b> field is set to <b>ss3extra</b> . | 0 = port<br>1 = cs | | 22 | cs6 | This bit determines whether <b>pb6</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 21 | cs5 | This bit determines whether <b>pb5</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 20 | cs4 | This bit determines whether <b>pb4</b> is a general I/O or peripheral chip-select signal. The setting of the <b>cs4</b> field is ignored if the <b>scsi0</b> field is set to <b>enph</b> or if the <b>syncser1</b> field is set to <b>ss1extra</b> . | 0 = port<br>1 = cs | | 19 | cs3 | This bit determines whether <b>pb3</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 18 | cs2 | This bit determines whether <b>pb2</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | #### Bit Assignments of R\_PORT\_PB\_SET (continued) | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 17 | scsi1 | This bit determines whether signal slenph at port SCSI-8 p1 is output on pb7. In SCSI-W mode, the scsi1 field determines whether signal s0enloid is output on pb7. The setting of the scsi1 field overrides that of the cs7 and dir7 fields, as well as the syncser3 field. | 0 = port_cs<br>1 = enph | | 16 | scsi0 | This bit determines whether signal <b>s0enph</b> at port SCSI-8 p0 is output on <b>pb4</b> . The setting of the <b>scsi0</b> field overrides that of the <b>cs4</b> and <b>dir4</b> fields, as well as the <b>syncser1</b> field. | 0 = port_cs<br>1 = enph | | 15 | dir7 | This bit sets the direction (input or output) of <b>pb7</b> . The <b>dir7</b> field is ignored if the <b>scsi1</b> field is set to <b>enph</b> , if the <b>syncser3</b> field is set to <b>ss3extra</b> or if the <b>cs7</b> field is set to <b>cs</b> . | 0 = input<br>1 = output | | 14 | dir6 | This bit sets the direction (input or output) of <b>pb6</b> . The dir6 field is ignored if the <b>cs6</b> field is set to <b>cs</b> . | 0 = input<br>1 = output | | 13 | dir5 | This bit sets the direction (input or output) of <b>pb5</b> . The dir5 field is ignored if the <b>cs5</b> field is set to <b>cs</b> . | 0 = input<br>1 = output | | 12 | dir4 | This bit sets the direction (input or output) of <b>pb4</b> . The <b>dir4</b> field is ignored if the <b>scsi0</b> field is set to <b>enph</b> , if the <b>syncser1</b> field is set to <b>ss1extra</b> or if the <b>cs4</b> field is set to <b>cs</b> . | 0 = input<br>1 = output | | 11 | dir3 | This bit sets the direction (input or output) of <b>pb3</b> . The dir3 field is ignored if the <b>cs3</b> field is set to <b>cs</b> . | 0 = input<br>1 = output | | 10 | dir2 | This bit sets the direction (input or output) of <b>pb2</b> . The dir2 field is ignored if the <b>cs2</b> field is set to <b>cs</b> . | 0 = input<br>1 = output | | 9 | dir1 | This bit sets the direction (input or output) of $pb1$ . The $dir1$ field is ignored if the $i2c\_en$ field is set to $on$ . | 0 = input<br>1 = output | | 8 | dir0 | This bit sets the direction (input or output) of $pb0$ . The $dir0$ field is ignored if the $i2c\_en$ field is set to $on$ . | 0 = input<br>1 = output | | 7 - 0 | data_out | Output data byte to pins that are configured for general I/O purposes at port PB. | 0 - 255 | **Note:** The I2C data bit should normally be an open collector output. Open collector behavior is achieved by setting the **i2c\_d** bit to 0 and using the **i2c\_oe\_** field to control the data output. # 18.7.6 R\_PORT\_PB\_DATA #### **General Port PB Data Register, General Characteristics** | ID of register | R_PORT_PB_DATA | Size | 8 bits | |----------------|----------------|---------------|------------| | Offset | 0x38 | Read/Write | Write only | | Address | 0xB0000038 | Initial value | 0 | # Bit Assignments of R\_PORT\_PB\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------|-------------| | 7 - 0 | data_out | Output data byte to pins that are configured for general I/O purposes at port PB. | 0 - 255 | **Note:** This is an 8 bit wide register that is part of register R\_PORT\_PB\_SET. # 18.7.7 R\_PORT\_PB\_DIR #### **General Port PB Direction Register, General Characteristics** | ID of register | R_PORT_PB_DIR | Size | 8 bits | |----------------|---------------|---------------|------------| | Offset | 0x39 | Read/Write | Write only | | Address | 0xB0000039 | Initial value | 0 | # Bit Assignments of R\_PORT\_PB\_DIR | Bit(s) | Name | Description | State/Range | |--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 7 | dir7 | This bit sets the direction (input or output) of <b>pb7</b> . The <b>dir7</b> field is ignored if the <b>scsi1</b> field in R_PORT_PB_SET is set to <b>enph</b> , if the <b>syncser3</b> field in R_PORT_PB_SET is set to <b>ss3extra</b> or if the <b>cs7</b> field in R_PORT_PB_SET is set to <b>cs</b> . | 0 = input<br>1 = output | | 6 | dir6 | This bit sets the direction (input or output) of <b>pb6</b> . The dir6 field is ignored if the <b>cs6</b> field in R_PORT_PB_SET is set to <b>cs</b> . | 0 = input<br>1 = output | | 5 | dir5 | This bit sets the direction (input or output) of <b>pb5</b> . The dir5 field is ignored if the <b>cs5</b> field in R_PORT_PB_SET is set to <b>cs</b> . | 0 = input<br>1 = output | | 4 | dir4 | This bit sets the direction (input or output) of <b>pb4</b> . The <b>dir4</b> field is ignored if the <b>scsi0</b> field in R_PORT_PB_SET is set to <b>enph</b> , if the <b>syncser1</b> field in R_PORT_PB_SET is set to <b>ss1extra</b> or if the <b>cs4</b> field in R_PORT_PB_SET is set to <b>cs</b> . | 0 = input<br>1 = output | | 3 | dir3 | This bit sets the direction (input or output) of <b>pb3</b> . The dir3 field is ignored if the <b>cs3</b> field in R_PORT_PB_SET is set to <b>cs</b> . | 0 = input<br>1 = output | | 2 | dir2 | This bit sets the direction (input or output) of <b>pb2</b> . The dir2 field is ignored if the <b>cs2</b> field in R_PORT_PB_SET is set to <b>cs</b> . | 0 = input<br>1 = output | | 1 | dir1 | This bit sets the direction (input or output) of <b>pb1</b> . The <b>dir1</b> field is ignored if the <b>i2c_en</b> field in R_PORT_PB_SET is set to <b>on</b> . | 0 = input<br>1 = output | | 0 | dir0 | This bit sets the direction (input or output) of <b>pb0</b> . The <b>dir0</b> field is ignored if the <b>i2c_en</b> field in R_PORT_PB_SET is set to <b>on</b> . | 0 = input<br>1 = output | **Note:** This is an 8-bit wide register that is part of register R\_PORT\_PB\_SET. # 18.7.8 R\_PORT\_PB\_CONFIG #### **General Port PB Configuration Register, General Characteristics** | ID of register | R_PORT_PB_CONFIG | Size | 8 bits | |----------------|------------------|---------------|------------| | Offset | 0x3A | Read/Write | Write only | | Address | 0xB000003A | Initial value | 0 | # Bit Assignments of R\_PORT\_PB\_CONFIG | Bit(s) | Name | Description | State/Range | |--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 7 | cs7 | This bit determines whether <b>pb7</b> is a general I/O or peripheral chip-select signal. The setting of the <b>cs7</b> field is ignored if the <b>scsi1</b> field in R_PORT_PB_SET is set to <b>enph</b> or if the <b>syncser3</b> field in R_PORT_PB_SET is set to <b>ss3extra</b> . | 0 = port<br>1 = cs | | 6 | cs6 | This bit determines whether <b>pb6</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 5 | cs5 | This bit determines whether <b>pb5</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 4 | cs4 | This bit determines whether <b>pb4</b> is a general I/O or peripheral chip-select signal. The setting of the <b>cs4</b> field is ignored if the <b>scsi0</b> field in R_PORT_PB_SET is set to <b>enph</b> or if the <b>syncser1</b> field in R_PORT_PB_SET is set to <b>ss1extra</b> . | 0 = port<br>1 = cs | | 3 | cs3 | This bit determines whether <b>pb3</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 2 | cs2 | This bit determines whether <b>pb2</b> is a general I/O or peripheral chip-select signal. | 0 = port<br>1 = cs | | 1 | scsi1 | This bit determines whether signal slenph at port SCSI-8 p1 is output on pb7. In SCSI-W mode, the scsi1 field determines whether signal s0enloid is output on pb7. The setting of the scsi1 field overrides that of the cs7, dir7 and syncser3 fields in R_PORT_PB_SET | 0 = port_cs<br>1 = enph | | 0 | scsi0 | This bit determines whether signal <b>soenph</b> at port SCSI-8 p0 is output on pb4. The setting of the <b>scsi0</b> field overrides that of the <b>cs4</b> , <b>dir4</b> and <b>syncser1</b> fields in R_PORT_PB_SET. | 0 = port_cs<br>1 = enph | **Note:** This is an 8 bit wide register that is part of register R\_PORT\_PB\_SET. # 18.7.9 R\_PORT\_PB\_I2C #### **General Port PB I2C Register, General Characteristics** | ID of register | R_PORT_PB_I2C | Size | 8 bits | |----------------|---------------|---------------|------------| | Offset | 0x3B | Read/Write | Write only | | Address | 0xB000003B | Initial value | 0 | #### Bit Assignments of R\_PORT\_PB\_I2C | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 7 - 6 | Reserved | - | | | 5 | syncser3 | If this bit is set, <b>pb7</b> is used for synchronous serial port p3, which in some modes needs an extra signal. The setting of the <b>syncser3</b> field overrides that of the <b>cs7</b> and <b>dir7</b> fields in R_PORT_PB_SET. The setting of the <b>syncser3</b> field is ignored if the <b>scsi1</b> field in R_PORT_PB_SET is set to <b>enph</b> . | 0 = port_cs<br>1 = ss3extra | | 4 | syncser1 | If this bit is set, <b>pb4</b> is used for synchronous serial port p1, which in some modes needs an extra signal. The setting of the <b>syncser1</b> field overrides that of the <b>cs4</b> and <b>dir4</b> fields in R_PORT_PB_SET. The setting of the <b>syncser1</b> field is ignored if the <b>scsi0</b> field in R_PORT_PB_SET is set to <b>enph</b> . | 0 = port_cs<br>1 = ss1extra | | 3 | i2c_en | This bit enables or disables the I2C mode at <b>pb1</b> and <b>pb0</b> . | 0 = off<br>1 = on | | 2 | i2c_d | This bit is the I2C output data bit. When the I2C mode is selected (field $i2c\_en = on$ ) and the output is enabled (field $i2c\_oe\_= enable$ ), $i2c\_d$ is output on $pb0$ . The $i2c\_d$ field is ignored if the I2C mode is not enabled ( $i2c\_en = off$ ). (note 1) | 0 - 1 | | 1 | i2c_clk | This bit is the I2C clock signal. When the I2C mode is selected (field $i2c\_en = on$ ), $i2c\_clk$ is output on $pb1$ . The $i2c\_clk$ field is ignored if the I2C mode is not enabled ( $i2c\_en = off$ ). | 0 - 1 | | 0 | i2c_oe_ | This bit is the output enable for the I2C mode. When the I2C mode is selected (field $i2c\_en = on$ ), this field enables or disables the output at $pb0$ . The $i2c\_oe\_$ field is ignored if the I2C mode is not enabled ( $i2c\_en = off$ ). | 0 = enable<br>1 = disable | Note 1: The I2C data bit should normally be an open collector output. Open collector behavior is achieved by setting the i2c\_d bit to 0 and using the i2c\_oe\_field to control the data output. **Note 2:** This is an 8 bit wide register that is part of 32-bit register R\_PORT\_PB\_SET. # 18.7.10 R\_PORT\_PB\_READ # **General Port PB Read Register, General Characteristics** | ID of register | R_PORT_PB_READ | Size | 32 bits | |----------------|----------------|---------------|-----------| | Offset | 0x38 | Read/Write | Read only | | Address | 0xB0000038 | Initial value | Unknown | # Bit Assignments of R\_PORT\_PB\_READ | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------|-------------| | 31 - 8 | Reserved | | | | 7 - 0 | data_in | Data in from general port PB. | 0 - 255 | # 18.8 Serial Port Registers # 18.8.1 R\_SERIALO\_CTRL #### **Serial Port 0 Control Register, General Characteristics** | ID of register | R_SERIALO_CTRL | Size | 32 bits | |----------------|----------------|---------------|---------------------------------------------| | Offset | 0x60 | Read/Write | Write only | | Address | 0xB0000060 | Initial value | Bit 14 and 22 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL0\_CTRL | Bit(s) | Name | Description | State/Range | |---------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 28 | tr_baud | This 4 bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 27 - 24 | rec_baud | This 4 bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 23 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 22 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | # Bit Assignments of R\_SERIAL0\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 21 | rts_ | This bit controls the $\overline{\text{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 20 | sampling | This bit determines the sampling mode for the serial receiver.If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | | 19 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 18 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 17 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 16 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | | 15 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 14 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 13 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 12 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 11 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 10 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 9 | tr_par_en | This bit enables the parity for the serial transmitter. | 0 = disable<br>1 = enable | | 8 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | | 7 - 0 | data_out | Data out to serial port 0. | | **Note:** For the serial port to operate correctly, register R\_SERIALO\_XOFF must also be initialized. # 18.8.2 R\_SERIALO\_BAUD #### Serial Port 0 Baud Register, General Characteristics | ID of register | R_SERIALO_BAUD | Size | 8 bits | |----------------|----------------|---------------|------------| | Offset | 0x63 | Read/Write | Write only | | Address | 0xB0000063 | Initial value | Unknown | # Bit Assignments of R\_SERIAL0\_BAUD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | tr_baud | This 4-bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 3 - 0 | rec_baud | This 4-bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | # 18.8.3 R\_SERIALO\_REC\_CTRL #### **Serial Port 0 Receive Control Register, General Characteristics** | ID of register | R_SERIALO_REC_CTRL | Size | 8 bits | |----------------|--------------------|---------------|-------------------------------------| | Offset | 0x62 | Read/Write | Write only | | Address | 0xB0000062 | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIALO\_REC\_CTRL | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 7 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 6 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 5 | rts_ | This bit controls the $\overline{\text{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 4 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | | 3 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 2 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 1 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 0 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | # 18.8.4 R\_SERIALO\_TR\_CTRL #### **Serial Port 0 Transmit Control Register, General Characteristics** | ID of register | R_SERIALO_TR_CTRL | Size | 8 bits | |----------------|-------------------|---------------|-------------------------------------| | Offset | 0x61 | Read/Write | Write only | | Address | 0xB0000061 | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL0\_TR\_CTRL | Bit(s) | Name | Description | State/Range | |--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 7 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 6 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 5 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 4 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 3 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 2 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 1 | tr_par_en | This bit enables/disables the parity for the serial transmitter. | 0 = disable<br>1 = enable | | 0 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | # 18.8.5 R\_SERIALO\_TR\_DATA #### Serial Port 0 Transmit Data Register, General Characteristics | ID of register | R_SERIALO_TR_DATA | Size | 8 bits | |----------------|-------------------|---------------|------------| | Offset | 0x60 | Read/Write | Write only | | Address | 0xB0000060 | Initial value | Unknown | # Bit Assignments of R\_SERIAL0\_TR\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------|-------------| | 7 - 0 | data_out | Data out to serial port 0 | | # 18.8.6 R\_SERIALO\_READ #### **Serial Port 0 Read Register, General Characteristics** | ID of register | R_SERIALO_READ | Size | 32 bits | |----------------|----------------|---------------|-----------| | Offset | 0x60 | Read/Write | Read only | | Address | 0xB0000060 | Initial value | Unknown | # Bit Assignments of R\_SERIAL0\_READ | Bit(s) | Name | Description | State/Range | |---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 16 | Reserved | - | | | 15 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIALO_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIALO_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 14 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 13 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 12 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 11 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 10 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 9 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 8 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the data_avail, overrun, par_err and framing_error bits in this register and in R_SERIALO_STATUS. | | # 18.8.7 R\_SERIALO\_STATUS # Serial Port 0 Status Register, General Characteristics | ID of register | R_SERIALO_STATUS | Size | 8 bits | |----------------|------------------|---------------|-----------| | Offset | 0x61 | Read/Write | Read only | | Address | 0xB0000061 | Initial value | Unknown | # Bit Assignments of R\_SERIAL0\_STATUS | Bit(s) | Name | Description | State/Range | |--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 7 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIALO_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIALO_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 6 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin | 0 = active<br>1 = inactive | | 5 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 4 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 3 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIALO_REC_DATA or in R_SERIALO_READ is read. | 0 = no<br>1 = yes | | 2 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIALO_REC_DATA or in R_SERIALO_READ is read. | 0 = no<br>1 = yes | | 1 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIALO_REC_DATA or in R_SERIALO_READ is read. | 0 = no<br>1 = yes | | 0 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIALO_REC_DATA or in R_SERIALO_READ is read. | 0 = no<br>1 = yes | # 18.8.8 R\_SERIALO\_REC\_DATA #### Serial Port 0 Receive Data Register, General Characteristics | ID of register | R_SERIALO_REC_DATA | Size | 8 bits | |----------------|--------------------|---------------|-----------| | Offset | 0x60 | Read/Write | Read only | | Address | 0xB0000060 | Initial value | Unknown | #### Bit Assignments of R\_SERIALO\_REC\_DATA | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the data_avail, overrun, par_err and framing_error bits in R_SERIALO_STATUS and in R_SERIALO_READ. | | # 18.8.9 R\_SERIALO\_XOFF #### **Serial Port 0 XOFF Register, General Characteristics** | ID of register | R_SERIAL0_XOFF | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x64 | Read/Write | Write only | | Address | 0xB0000064 | Initial value | Unknown | # Bit Assignments of R\_SERIAL0\_XOFF | Bit(s) | Name | Description | State/Range | |---------|-----------|----------------------------------------------------------------------------|---------------------------| | 31 - 10 | Reserved | - | 0 | | 9 | tx_stop | When this bit is set, the serial transmitter stops after the ongoing byte. | 0 = enable<br>1 = stop | | 8 | auto_xoff | This bit enables/disables automatic xoff handling. | 0 = disable<br>1 = enable | | 7 - 0 | xoff_char | The code for the xoff character. | | **Note:** Writing to bits 15:8 of this register will clear the **xoff\_detect** bit in register R\_SERIALO\_READ. # 18.8.10 R\_SERIAL1\_CTRL # **Serial Port 1 Control Register, General Characteristics** | ID of register | R_SERIAL1_CTRL | Size | 32 bits | |----------------|----------------|---------------|---------------------------------------------| | Offset | 0x68 | Read/Write | Write only | | Address | 0xB0000068 | Initial value | Bit 14 and 22 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL1\_CTRL | Bit(s) | Name | Description | State/Range | |---------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 28 | tr_baud | This 4 bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 27 - 24 | rec_baud | This 4 bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 23 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 22 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 21 | rts_ | This bit controls the $\overline{\mathbf{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 20 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | # Bit Assignments of R\_SERIAL1\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 19 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 18 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 17 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 16 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | | 15 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 14 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 13 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 12 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 11 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 10 | tr_par | This bits selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 8 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | | 7 - 0 | data_out | Data out to serial port 1. | | **Note:** For this serial port to operate correctly, register R\_SERIAL1\_XOFF must also be initialized. # 18.8.11 R\_SERIAL1\_BAUD #### **Serial Port 1 Baud Register, General Characteristics** | ID of register | R_SERIAL1_BAUD | Size | 8 bits | |----------------|----------------|---------------|------------| | Offset | 0x6B | Read/Write | Write only | | Address | 0xB000006B | Initial value | Unknown | # Bit Assignments of R\_SERIAL1\_BAUD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | tr_baud | This 4 bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 3 - 0 | rec_baud | This 4 bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | # 18.8.12 R\_SERIAL1\_REC\_CTRL #### **Serial Port 1 Receive Control Register, General Characteristics** | ID of register | R_SERIAL1_REC_CTRL | Size | 8 bits | |----------------|--------------------|---------------|-------------------------------------| | Offset | 0x6A | Read/Write | Write only | | Address | 0xB000006A | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL1\_REC\_CTRL | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 7 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 6 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 5 | rts_ | This bit controls the $\overline{\mathbf{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 4 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | | 3 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 2 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 1 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 0 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | # 18.8.13 R\_SERIAL1\_TR\_CTRL #### **Serial Port 1 Transmit Control Register, General Characteristics** | ID of register | R_SERIAL1_TR_CTRL | Size | 8 bits | |----------------|-------------------|---------------|-------------------------------------| | Offset | 0x69 | Read/Write | Write only | | Address | 0xB0000069 | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL1\_TR\_CTRL | Bit(s) | Name | Description | State/Range | |--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 7 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 6 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 5 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 4 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 3 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 2 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 1 | tr_par_en | This bit enables/disables the parity for the serial transmitter. | 0 = disable<br>1 = enable | | 0 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | # 18.8.14 R\_SERIAL1\_TR\_DATA #### Serial Port 1 Transmit Data Register, General Characteristics | ID of register | R_SERIAL1_TR_DATA | Size | 8 bits | |----------------|-------------------|---------------|------------| | Offset | 0x68 | Read/Write | Write only | | Address | 0xB0000068 | Initial value | Unknown | # Bit Assignments of R\_SERIAL1\_TR\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------|-------------| | 7 - 0 | data_out | Data out to serial port 1. | | # 18.8.15 R\_SERIAL1\_READ #### **Serial Port 1 Read Register, General Characteristics** | ID of register | R_SERIAL1_READ | Size | 32 bits | |----------------|----------------|---------------|-----------| | Offset | 0x68 | Read/Write | Read only | | Address | 0xB0000068 | Initial value | Unknown | # Bit Assignments of R\_SERIAL1\_READ | Bit(s) | Name | Description | State/Range | |---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 16 | Reserved | - | | | 15 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIAL1_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIAL1_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 14 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 13 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 12 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 11 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 10 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 9 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 8 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the data_avail, overrun, par_err and framing_error bits in this register and in R_SERIAL1_STATUS. | | # 18.8.16 R\_SERIAL1\_STATUS #### **Serial Port 1 Status Register, General Characteristics** | ID of register | R_SERIAL1_STATUS | Size | 8 bits | |----------------|------------------|---------------|-----------| | Offset | 0x69 | Read/Write | Read only | | Address | 0xB0000069 | Initial value | Unknown | # Bit Assignments of R\_SERIAL1\_STATUS | Bit(s) | Name | Description | State/Range | |--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 7 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIAL1_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIAL1_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 6 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 5 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 4 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 3 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL1_REC_DATA or in R_SERIAL1_READ is read. | 0 = no<br>1 = yes | | 2 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL1_REC_DATA or in R_SERIAL1_READ is read. | 0 = no<br>1 = yes | | 1 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL1_REC_DATA or in R_SERIAL1_READ is read. | 0 = no<br>1 = yes | | 0 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL1_REC_DATA or in R_SERIAL1_READ is read. | 0 = no<br>1 = yes | # 18.8.17 R\_SERIAL1\_REC\_DATA #### Serial Port I Receive Data Register, General Characteristics | ID of register | R_SERIAL1_REC_DATA | Size | 8 bits | |----------------|--------------------|---------------|-----------| | Offset | 0x68 | Read/Write | Read only | | Address | 0xB0000068 | Initial value | Unknown | #### Bit Assignments of R\_SERIAL1\_REC\_DATA | Bit(s) | Name | Description | State/Range | |--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the <b>data_avail</b> , <b>overrun</b> , <b>par_err and framing_error</b> bits in R_SERIAL1_STATUS and in R_SERIAL1_READ. | | # 18.8.18 R\_SERIAL1\_XOFF #### **Serial Port 1 XOFF Register, General Characteristics** | ID of register | R_SERIAL1_XOFF | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x6C | Read/Write | Write only | | Address | 0xB000006C | Initial value | Unknown | # Bit Assignments of R\_SERIAL1\_XOFF | Bit(s) | Name | Description | State/Range | |---------|-----------|----------------------------------------------------------------------------|---------------------------| | 31 - 10 | Reserved | - | 0 | | 9 | tx_stop | When this bit is set, the serial transmitter stops after the ongoing byte. | 0 = enable<br>1 = stop | | 8 | auto_xoff | This bit enables/disables automatic xoff handling. | 0 = disable<br>1 = enable | | 7 - 0 | xoff_char | The code for the xoff character. | | **Note:** Writing to bits 15:8 of this register will clear the **xoff\_detect** bit in register R\_SERIAL1\_READ. # 18.8.19 R\_SERIAL2\_CTRL # **Serial Port 2 Control Register, General Characteristics** | ID of register | R_SERIAL2_CTRL | Size | 32 bits | |----------------|----------------|---------------|---------------------------------------------| | Offset | 0x70 | Read/Write | Write only | | Address | 0xB0000070 | Initial value | Bit 14 and 22 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL2\_CTRL | Bit(s) | Name | Description | State/Range | |---------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 28 | tr_baud | This 4-bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 27 - 24 | rec_baud | This 4-bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 23 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 22 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 21 | rts_ | This bit controls the $\overline{\text{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 20 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | # Bit Assignments of R\_SERIAL2\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 19 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 18 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 17 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 16 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | | 15 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 14 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 13 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 12 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 11 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 10 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 9 | tr_par_en | This bit enables/disables the parity for the serial transmitter. | 0 = disable<br>1 = enable | | 8 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | | 7 - 0 | data_out | Data out to serial port 2. | | **Note:** For this serial port to operate correctly, register R\_SERIAL2\_XOFF must also be initialized. # 18.8.20 R\_SERIAL2\_BAUD #### **Serial Port 2 Baud Register, General Characteristics** | ID of register | R_SERIAL2_BAUD | Size | 8 bits | |----------------|----------------|---------------|------------| | Offset | 0x73 | Read/Write | Write only | | Address | 0xB0000073 | Initial value | Unknown | # Bit Assignments of R\_SERIAL2\_BAUD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | tr_baud | This 4 bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 3 - 0 | rec_baud | This 4 bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>8 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | # 18.8.21 R\_SERIAL2\_REC\_CTRL #### **Serial Port 2 Receive Control Register, General Characteristics** | ID of register | R_SERIAL2_REC_CTRL | Size | 8 bits | |----------------|--------------------|---------------|-------------------------------------| | Offset | 0x72 | Read/Write | Write only | | Address | 0xB0000072 | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL2\_REC\_CTRL | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 7 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 6 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 5 | rts_ | This bit controls the $\overline{\text{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 4 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | | 3 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 2 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 1 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 0 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | # 18.8.22 R\_SERIAL2\_TR\_CTRL #### **Serial Port 2 Transmit Control Register, General Characteristics** | ID of register | R_SERIAL2_TR_CTRL | Size | 8 bits | |----------------|-------------------|---------------|-------------------------------------| | Offset | 0x71 | Read/Write | Write only | | Address | 0xB0000071 | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL2\_TR\_CTRL | Bit(s) | Name | Description | State/Range | |--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 7 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 6 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 5 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 4 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 3 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 2 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 1 | tr_par_en | This bit enables/disables parity for the serial transmitter. | 0 = disable<br>1 = enable | | 0 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | # 18.8.23 R\_SERIAL2\_TR\_DATA #### Serial Port 2 Transmit Data Register, General Characteristics | ID of register | R_SERIAL2_TR_DATA | Size | 8 bits | |----------------|-------------------|---------------|------------| | Offset | 0x70 | Read/Write | Write only | | Address | 0xB0000070 | Initial value | Unknown | #### Bit Assignments of R\_SERIAL2\_TR\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------|-------------| | 7 - 0 | data_out | Data out to serial port 2. | | # 18.8.24 R\_SERIAL2\_READ #### **Serial Port 2 Read Register, General Characteristics** | ID of register | R_SERIAL2_READ | Size | 32 bits | |----------------|----------------|---------------|-----------| | Offset | 0x70 | Read/Write | Read only | | Address | 0xB0000070 | Initial value | Unknown | # Bit Assignments of R\_SERIAL2\_READ | Bit(s) | Name | Description | State/Range | |---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 16 | Reserved | - | | | 15 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIAL2_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIAL2_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 14 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 13 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 12 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 11 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 10 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 9 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 8 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the <b>data_avail</b> , <b>overrun</b> , <b>par_err and framing_error</b> bits in this register and in R_SERIAL2_STATUS. | | # 18.8.25 R\_SERIAL2\_STATUS # **Serial Port 2 Status Register, General Characteristics** | ID of register | R_SERIAL2_STATUS | Size | 8 bits | |----------------|------------------|---------------|-----------| | Offset | 0x71 | Read/Write | Read only | | Address | 0xB0000071 | Initial value | Unknown | # Bit Assignments of R\_SERIAL2\_STATUS | Bit(s) | Name | Description | State/Range | |--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 7 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIAL2_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIAL2_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 6 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 5 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 4 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 3 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL2_REC_DATA or in R_SERIAL2_READ is read. | 0 = no<br>1 = yes | | 2 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL2_REC_DATA or in R_SERIAL2_READ is read. | 0 = no<br>1 = yes | | 1 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL2_REC_DATA or in R_SERIAL2_READ is read. | 0 = no<br>1 = yes | | 0 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL2_REC_DATA or in R_SERIAL2_READ is read. | 0 = no<br>1 = yes | # 18.8.26 R\_SERIAL2\_REC\_DATA #### Serial Port 2 Receive Data Register, General Characteristics | ID of register | R_SERIAL2_REC_DATA | Size | 8 bits | |----------------|--------------------|---------------|-----------| | Offset | 0x70 | Read/Write | Read only | | Address | 0xB0000070 | Initial value | Unknown | #### Bit Assignments of R\_SERIAL2\_REC\_DATA | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the data_avail, overrun, par_err and framing_error bits in R_SERIAL2_STATUS and in R_SERIAL2_READ. | | # 18.8.27 R\_SERIAL2\_XOFF #### **Serial Port 2 XOFF Register, General Characteristics** | ID of register | R_SERIAL2_XOFF | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x116 | Read/Write | Write only | | Address | 0xB0000116 | Initial value | Unknown | # Bit Assignments of R\_SERIAL2\_XOFF | Bit(s) | Name | Description | State/Range | |---------|-----------|----------------------------------------------------------------------------|---------------------------| | 31 - 10 | Reserved | - | 0 | | 9 | tx_stop | When this bit is set, the serial transmitter stops after the ongoing byte. | 0 = enable<br>1 = stop | | 8 | auto_xoff | This bit enables/disables automatic xoff handling. | 0 = disable<br>1 = enable | | 7 - 0 | xoff_char | The code for the xoff character. | | **Note:** Writing to bits 15:8 of this register will clear the **xoff\_detect** bit in register R\_SERIAL2\_READ. # 18.8.28 R\_SERIAL3\_CTRL # **Serial Port 3 Control Register, General Characteristics** | ID of register | R_SERIAL3_CTRL | Size | 32 bits | |----------------|----------------|---------------|---------------------------------------------| | Offset | 0x78 | Read/Write | Write only | | Address | 0xB0000078 | Initial value | Bit 14 and 22 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL3\_CTRL | Bit(s) | Name | Description | State/Range | |---------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 28 | tr_baud | This 4 bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 27 - 24 | rec_baud | This 4 bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 23 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 22 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 21 | rts_ | This bit controls the $\overline{\text{rts}}$ pin for the serial port. | 0 = active<br>1 = inactive | | 20 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | # Bit Assignments of R\_SERIAL3\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 19 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ. | 0 = normal<br>1 = stick | | 18 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 17 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 16 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | | 15 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 14 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 13 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte. | 0 = disabled<br>1 = active | | 12 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 11 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 10 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 9 | tr_par_en | This bit enables/disables the parity for the serial transmitter. | 0 = disable<br>1 = enable | | 8 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | | 7 - 0 | data_out | Data out to serial port 3. | | **Note:** For this serial port to operate correctly, register R\_SERIAL3\_XOFF must also be initialized. # 18.8.29 R\_SERIAL3\_BAUD # **Serial Port 3 Baud Register, General Characteristics** | ID of register | R_SERIAL3_BAUD | Size | 8 bits | |----------------|----------------|---------------|------------| | Offset | 0x7B | Read/Write | Write only | | Address | 0xB000007B | Initial value | Unknown | #### Bit Assignments of R\_SERIAL3\_BAUD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | tr_baud | This 4 bit field is used to select the baud rate for the transmitter. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | | 3 - 0 | rec_baud | This 4 bit field is used to select the baud rate for the receiver. | 0 = c300Hz<br>1 = c600Hz<br>2 = c1200Hz<br>3 = c2400Hz<br>4 = c4800Hz<br>5 = c9600Hz<br>6 = c19k2Hz<br>7 = c38k4Hz<br>8 = c57k6Hz<br>9 = c115k2Hz<br>10 = c230k4Hz<br>11 = c460k8Hz<br>12 = c921k6Hz<br>13 = c1843k2Hz<br>14 = c6250kHz<br>15 = reserved | # 18.8.30 R\_SERIAL3\_REC\_CTRL #### **Serial Port 3 Receive Control Register, General Characteristics** | ID of register | R_SERIAL3_REC_CTRL | Size | 8 bits | |----------------|--------------------|---------------|-------------------------------------| | Offset | 0x7A | Read/Write | Write only | | Address | 0xB000007A | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL3\_REC\_CTRL | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 7 | dma_err | This bit controls the handling of receive errors when DMA is used. If this bit is set to <b>stop</b> , a receive error generates an end_of_packet to the DMA. The erroneous byte is not entered into the fifo. If the bit is set to <b>ignore</b> , receive errors are ignored when DMA is used. | 0 = stop<br>1 = ignore | | 6 | rec_enable | This bit enables/disables the serial receiver. | 0 = disable<br>1 = enable | | 5 | rts_ | This bit controls the <b>rts</b> pin for the serial port. | 0 = active<br>1 = inactive | | 4 | sampling | This bit determines the sampling mode for the serial receiver. If set to <b>middle</b> , one sample is taken in the middle of each data bit. If set to <b>majority</b> , the majority of three samples in the middle of each data bit is taken. | 0 = middle<br>1 = majority | | 3 | rec_stick_par | This bit selects normal or stick parity for the serial receiver. If set to <b>normal</b> , normal parity checking is used. If set to <b>stick</b> , parity is checked as a logic 0 or 1, compared to the value of <b>rec_par</b> . A parity error is generated if the values differ | 0 = normal<br>1 = stick | | 2 | rec_par | This bit selects the parity for the serial receiver. | 0 = even<br>1 = odd | | 1 | rec_par_en | This bit enables/disables the parity for the serial receiver. | 0 = disable<br>1 = enable | | 0 | rec_bitnr | This bit determines the number of data bits for the serial receiver. | 0 = rec_8bit<br>1 = rec_7bit | # 18.8.31 R\_SERIAL3\_TR\_CTRL #### **Serial Port 3 Transmit Control Register, General Characteristics** | ID of register | R_SERIAL3_TR_CTRL | Size | 8 bits | |----------------|-------------------|---------------|-------------------------------------| | Offset | 0x79 | Read/Write | Write only | | Address | 0xB0000079 | Initial value | Bit 6 set to 0. Other bits unknown. | #### Bit Assignments of R\_SERIAL3\_TR\_CTRL | Bit(s) | Name | Description | State/Range | |--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 7 | txd | This bit determines the value of the txd pin when the serial transmitter is disabled. | | | 6 | tr_enable | This bit enables/disables the serial transmitter. | 0 = disable<br>1 = enable | | 5 | auto_cts | This bit enables automatic $\overline{cts}$ handling. If set (active), a high signal on $\overline{cts}$ stops transmission after the ongoing byte | 0 = disabled<br>1 = active | | 4 | stop_bits | This bit determines the number of stop bits for the serial transmitter. | 0 = one_bit<br>1 = two_bits | | 3 | tr_stick_par | This bit selects normal or stick parity mode for the serial transmitter. If set to <b>normal</b> , normal parity generation is used. If set to <b>stick</b> , parity is set to a logic 0 or 1, depending on the value of <b>tr_par</b> . | 0 = normal<br>1 = stick | | 2 | tr_par | This bit selects the parity for the serial transmitter. | 0 = even<br>1 = odd | | 0 | tr_bitnr | This bit determines the number of data bits for the serial transmitter. | 0 = tr_8bit<br>1 = tr_7bit | # 18.8.32 R\_SERIAL3\_TR\_DATA #### Serial Port 3 Transmit Data Register, General Characteristics | ID of register | R_SERIAL3_TR_DATA | Size | 8 bits | |----------------|-------------------|---------------|------------| | Offset | 0x78 | Read/Write | Write only | | Address | 0xB0000078 | Initial value | Unknown | # Bit Assignments of R\_SERIAL3\_TR\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------|-------------| | 7 - 0 | data_out | Data out to serial port 3. | | # 18.8.33 R\_SERIAL3\_READ #### **Serial Port 3 Read Register, General Characteristics** | ID of register | R_SERIAL3_READ | Size | 32 bits | |----------------|----------------|---------------|-----------| | Offset | 0x78 | Read/Write | Read only | | Address | 0xB0000078 | Initial value | Unknown | # Bit Assignments of R\_SERIAL3\_READ | Bit(s) | Name | Description | State/Range | |---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 16 | Reserved | - | | | 15 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIAL3_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIAL3_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 14 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 13 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 12 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 11 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 10 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 9 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 8 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field of this register is read. | 0 = no<br>1 = yes | | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the data_avail, overrun, par_err and framing_error bits in this register and in R_SERIAL3_STATUS. | | # 18.8.34 R\_SERIAL3\_STATUS #### **General Characteristics of R\_SERIAL3\_STATUS** | ID of register | R_SERIAL3_STATUS | Size | 8 bits | |----------------|------------------|---------------|-----------| | Offset | 0x79 | Read/Write | Read only | | Address | 0xB0000079 | Initial value | Unknown | #### **Bit Assignments of R\_SERIAL3\_STATUS** | Bit(s) | Name | Description | State/Range | |--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 7 | xoff_detect | This bit is set if the xoff character is detected in the received data. The bit is cleared by writing to bits 15:8 of R_SERIAL3_XOFF. The data written doesn't matter for the clear operation. xoff will only be detected if bit auto_xoff in R_SERIAL3_XOFF is set to enable. | 0 = no_xoff<br>1 = xoff | | 6 | cts_ | This bit gives the value on the $\overline{\mathbf{cts}}$ pin. | 0 = active<br>1 = inactive | | 5 | tr_ready | If this bit is set ( <b>ready</b> ), the serial transmitter is ready and one byte can be written to it. | 0 = full<br>1 = ready | | 4 | rxd | This bit gives the value on the <b>rxd</b> pin. | | | 3 | overrun | This bit is set when an overrun error is detected in the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL3_REC_DATA or in R_SERIAL3_READ is read. | 0 = no<br>1 = yes | | 2 | par_err | This bit is set when a parity error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL3_REC_DATAor in R_SERIAL3_READ is read. | 0 = no<br>1 = yes | | 1 | framing_err | This bit is set when a framing error is detected by the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL3_REC_DATAor in R_SERIAL3_READ is read. | 0 = no<br>1 = yes | | 0 | data_avail | This bit is set when data is available from the serial receiver. The bit is cleared when the <b>data_in</b> field in R_SERIAL3_REC_DATAor in R_SERIAL3_READ is read. | 0 = no<br>1 = yes | # 18.8.35 R\_SERIAL3\_REC\_DATA #### Serial Port 3 Receive Data Register, General Characteristics | ID of register | R_SERIAL3_REC_DATA | Size | 8 bits | |----------------|--------------------|---------------|-----------| | Offset | 0x78 | Read/Write | Read only | | Address | 0xB0000078 | Initial value | Unknown | #### Bit Assignments of R\_SERIAL3\_REC\_DATA | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 0 | data_in | Data in from the serial receiver. Reading this register will clear the data_avail, overrun, par_err and framing_error bits in R_SERIAL3_STATUS and in R_SERIAL3_READ. | | # 18.8.36 R\_SERIAL3\_XOFF #### **Serial Port 3 XOFF Register, General Characteristics** | ID of register | R_SERIAL3_XOFF | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x7C | Read/Write | Write only | | Address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SERIAL3\_XOFF | Bit(s) | Name | Description | State/Range | |---------|-----------|----------------------------------------------------------------------------|---------------------------| | 31 - 10 | Reserved | - | 0 | | 9 | tx_stop | When this bit is set, the serial transmitter stops after the ongoing byte. | 0 = enable<br>1 = stop | | 8 | auto_xoff | This bit enables/disables automatic xoff handling. | 0 = disable<br>1 = enable | | 7 - 0 | xoff_char | The code for the xoff character. | | **Note:** Writing to bit 15:8 of this register will clear the **xoff\_detect** bit in register R\_SERIAL3\_READ. # 18.8.37 R\_ALT\_SER\_BAUDRATE #### **Alternative Serial Baud Rate Register, General Characteristics** | ID of register | R_ALT_SER_BAUDRATE | Size | 32 bits | |----------------|--------------------|---------------|------------| | Offset | 0x5C | Read/Write | Write only | | Address | 0xB000005C | Initial value | 0 | #### **Bit Assignments of R\_ALT\_SER\_BAUDRATE** | Bit(s) | Name | Description | State/Range | |---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | 31 - 30 | Reserved | - | 0 | | 29 - 28 | ser3_tr | Alternative baud rates for the serial port 3 transmitter can be chosen by setting the value of this field. If set to <b>normal</b> (default) the baud rate is chosen by the R_SERIAL3_BAUD register. <b>prescale</b> overrides R_SERIAL3_BAUD and uses the baud rate generated by R_SERIAL_PRESCALE (user baud rate). <b>extern</b> overrides R_SERIAL3_BAUD and uses the external baud rate. <b>timer</b> overrides R_SERIAL3_BAUD and uses the timer0 as baud rate generator. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 27 - 26 | Reserved | - | 0 | | 25 - 24 | ser3_rec | Alternative baud rates for the serial port 3 receiver can be chosen by setting the value of this field. If set to <b>normal</b> (default) the baud rate is chosen by the R_SERIAL3_BAUD register. <b>prescale</b> overrides R_SERIAL3_BAUD and uses the baud rate generated by R_SERIAL_PRESCALE (user baud rate). <b>extern</b> overrides R_SERIAL3_BAUD and uses the external baud rate. <b>timer</b> overrides R_SERIAL3_BAUD and uses the timer0 as baud rate generator. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 23 - 22 | Reserved | - | 0 | | 21 - 20 | ser2_tr | Alternative baud rates for the serial port 2 transmitter can be chosen by setting the value of this field. See ser3_tr. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 19 - 18 | Reserved | - | 0 | | 17 - 16 | ser2_rec | Alternative baud rates for the serial port 2 receiver can be chosen by setting the value of this field. See ser3_rec. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 15 - 14 | Reserved | - | 0 | | 13 - 12 | ser1_tr | Alternative baud rates for the serial port 1 transmitter can be chosen by setting the value of this field. See ser3_tr. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 11 - 10 | Reserved | - | 0 | | 9 - 8 | ser1_rec | Alternative baud rates for the serial port 1 receiver can be chosen by setting the value of this field. See ser3_rec. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 7 - 6 | Reserved | - | 0 | #### Bit Assignments of R\_ALT\_SER\_BAUDRATE (continued) | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | 5 - 4 | ser0_tr | Alternative baud rates for the serial port 0 transmitter can be chosen by setting the value of this field. See ser3_tr. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | | 3 - 2 | Reserved | - | 0 | | 1 - 0 | ser0_rec | Alternative baud rates for the serial port 0 receiver can be chosen by setting the value of this field. See ser3_rec. | 0 = normal<br>1 = prescale<br>2 = extern<br>3 = timer | # 18.8.38 R\_SERIAL\_PRESCALE #### **Serial Prescale Register, General Characteristics** | ID of register | R_SERIAL_PRESCALE | Size | 16 bits | |----------------|-------------------|---------------|------------| | Offset | 0xF2 | Read/Write | Write only | | Address | 0xB00000F2 | Initial value | Unknown | #### Bit Assignments of R\_SERIAL\_PRESCALE | Bit(s) | Name | Description | State/Range | |--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | ser_presc | This fields gives the divide factor for serial clock prescaling. It is used when another baud rate than those predefined in the serial port control registers is needed for the asynchronous serial ports. The usable range is 2 - 65536. A divide factor of 65536 is achieved by setting the field to 0. The resulting baud rate equals 3.125MHz divided by the divide factor. The prescaling starts when the field is written. | 0, 2-65535 | **Note:** This is a 16 bit wide register that is part of register R\_CLOCK\_PRESCALE, see section 18.4 *Timer Registers.* # 18.8.39 R\_SER\_PRESC\_STATUS #### **Serial Prescale Status Register, General Characteristics** | ID of register | R_SER_PRESC_STATUS | Size | 16 bits | |----------------|--------------------|---------------|-----------| | Offset | 0xF2 | Read/Write | Read only | | Address | 0xB00000F2 | Initial value | Unknown | #### Bit Assignments of R\_SER\_PRESC\_STATUS | Bit(s) | Name | Description | State/Range | |--------|------------|---------------------------------------------------------------|-------------| | 15 - 0 | ser_status | Contains the current count value of the serial divide factor. | 0-65535 | Note: Table 18-1 This is a 16 bit wide register that is part of register R\_PRESCALE\_STATUS, see section 18.4 Timer Registers. ### 18.9 Network Interface Registers Mode registers R\_NETWORK\_SA\_0 to R\_NETWORK\_SA\_2 contain two 48-bit station addresses: MA0 and MA1. Each station address can be set to match an individual address, or it can be set to match a single group/multicast address by setting the multicast bit in the address. The bit ordering convention used here is that address bit 0 (addr[0]) is the first bit transmitted/received on the network and address bit 47 (addr[47]) is the last bit. The multicast bit in Ethernet is addr[0]. The normal way of printing and displaying Ethernet addresses is: addr[7:0]:addr[15:8]:addr[23:16]:addr[31:24]:addr[39:32]:addr[47:40] where each byte is printed in hexadecimal. For more information about the ETRAX 100LX interface, see chapter *9 Network Interface*. Note: With the IEEE802.5 frame format, any of the addresses MA0 or MA1 are interpreted as a functional address if it matches the functional address format of IEEE802.5. # 18.9.1 R\_NETWORK\_SA\_0 # **Network Station Address Register Part 0, General Characteristics** | ID of register | R_NETWORK_SA_0 | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x80 | Read/Write | Write only | | Register address | 0xB0000080 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_SA\_0 | Bit(s) | Name | Description | State/Range | |--------|---------|----------------------------------------|-------------| | 31 - 0 | ma0_low | Bit addr[31:0] of station address MA0. | | # 18.9.2 R\_NETWORK\_SA\_1 #### **Network Station Address Register Part 1, General Characteristics** | ID of register | R_NETWORK_SA_1 | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x84 | Read/Write | Write only | | Register address | 0xB0000084 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_SA\_1 | Bit(s) | Name | Description | State/Range | |---------|----------|-----------------------------------------|-------------| | 31 - 16 | ma1_low | Bit addr[15:0] of station address MA1. | 65535 | | 15 - 0 | ma0_high | Bit addr[47:32] of station address MA0. | 65535 | # 18.9.3 R\_NETWORK\_SA\_2 #### **Network Station Address Register Part 2, General Characteristics** | ID of register | R_NETWORK_SA_2 | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x88 | Read/Write | Write only | | Register address | 0xB0000088 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_SA\_2 | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------|-------------| | 31 - 0 | ma1_high | Bit addr[47:16] of station address MA1. | | # 18.9.4 R\_NETWORK\_GA\_0 # **Network Group Address Table Register Part 0, General Characteristics** | ID of register | R_NETWORK_GA_0 | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x8C | Read/Write | Write only | | Register address | 0xB000008C | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_GA | Bit(s) | Name | Description | State/Range | |--------|--------|----------------------------------------|-------------| | 31 - 0 | ga_low | Bit [31:0] of the group address table. | | # 18.9.5 R\_NETWORK\_GA\_1 # **Network Group Address Table Register Part 1, General Characteristics** | ID of register | R_NETWORK_GA_1 | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x90 | Read/Write | Write only | | Register address | 0xB0000090 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_GA\_1 | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------|-------------| | 31 - 0 | ga_high | Bit [63:32] of the group address table. | | # 18.9.6 R\_NETWORK\_REC\_CONFIG # **Network Receive Configuration Register, General Characteristics** | ID of register | R_NETWORK_REC_CONFIG | Size | 32 bits | |------------------|----------------------|---------------|------------| | Offset | 0x94 | Read/Write | Write only | | Register address | 0xB0000094 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_REC\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 31 - 11 | Reserved | - | 0 | | 10 | max_size | This bit determines the maximum packet size for Ethernet packets. If the IEEE 802.1q standard is used, maximum packet size 1522 bytes is selected (size1522). If the IEEE 802.3 standard is used, maximum packet size 1518 bytes is selected (size1518). | 0 = size1518<br>1 = size1522 | | 9 | duplex | This bit decides whether full or half duplex mode is used. In full duplex mode, the receiver is not turned off during transmission. The transmitter ignores the col and crs signals. Full duplex flow control is enabled. This mode can also be used for external loopback test. | 0 = half<br>1 = full | | 8 | bad_crc | This bit determines whether to receive or discard frames with CRC errors or alignment errors. | 0 = discard<br>1 = receive | | 7 | oversize | This bit determines whether to receive or discard oversized frames. | 0 = discard<br>1 = receive | | 6 | undersize | This bit determines whether to receive or discard undersized frames. | 0 = discard<br>1 = receive | | 5 | all_roots | This bit determines whether to receive or discard all roots in functional addresses. If set to <b>receive (1)</b> , bit [45:32] in functional addresses will be ignored. This bit is only used with IEEE802.5 frame format. | 0 = discard<br>1 = receive | | 4 | tr_broadcast | This bit determines whether to receive or discard Token Ring broadcast frames (address 0xFFFFFFFF000C). | 0 = discard<br>1 = receive | | 3 | broadcast | This bit determines whether to receive or discard broadcast frames (address 0xFFFFFFFFFFF). | 0 = discard<br>1 = receive | | 2 | individual | If this field is set to <b>receive (1)</b> , individual addresses will also be matched with the group address table. | 0 = discard<br>1 = receive | | 1 | ma1 | This bit enables or disables station address MA1. | 0 = disable<br>1 = enable | | 0 | ma0 | This bit enables or disables station address MA0. | 0 = disable<br>1 = enable | # 18.9.7 R\_NETWORK\_GEN\_CONFIG # **Network General Configuration Register, General Characteristics** | ID of register | R_NETWORK_GEN_CONFIG | Size | 32 bits | |------------------|----------------------|---------------|------------| | Offset | 0x98 | Read/Write | Write only | | Register address | 0xB0000098 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_GEN\_CONFIG | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 31 - 6 | Reserved | - | 0 | | 5 | loopback | This field turns internal loopback mode on or off. If on, the transmitted frames are directly passed to the receiver, and the MII or SNI interface is disabled. The col and crs signals are therefore also disabled in loopback mode, which has the side effect that each transmitted frame will cause the carrier_loss counter in "R_PHY_COUNTERS" to increment. The col signal can however be enabled, for testing purposes, via R_TEST_MODE. The transmit speed in internal loopback mode is 100 Mbit/s. Loop back mode also forces the reception of transmitted frames, regardless of the value of the duplex bit in the "R_NETWORK_REC_CONFIG" register. | 0 = off<br>1 = on | | 4 | frame | If this field is set to <b>ether</b> , frame format according to IEEE802.3 (Ethernet) will be used, if set to <b>tokenr</b> , frame format according to IEEE802.5 (Token Ring) will be used. | 0 = ether<br>1 = tokenr | | 3 | vg | This bit turns IEEE802.12 mode (VG-anylan) mode ${\bf on}$ (1) or ${\bf off}$ (0). | 0 = off<br>1 = on | | 2 - 1 | phy | This field determines the physical connection. If set to <b>sni</b> (0), SNI mode is used. All other states give MII mode, but the <b>txer</b> pin will be used in different ways according to the setting of this field. If the field is set to <b>mii_clk</b> , a 25 MHz clock will be output on the <b>txer</b> pin. If the field is set to <b>mii_err</b> , the <b>txer</b> pin will be used to indicate a transmit error. If the field is set to <b>mii_req</b> , the output indicates that an address is recognized. | 0 = sni<br>1 = mii_clk<br>2 = mii_err<br>3 = mii_req | | 0 | enable | This bit enables or disables the network controller. | 0 = off<br>1 = on | # 18.9.8 R\_NETWORK\_TR\_CTRL #### **Network Transmit Control Register, General Characteristics** | ID of register | R_NETWORK_TR_CTRL | Size | 32 bits | |------------------|-------------------|---------------|------------| | Offset | 0x9C | Read/Write | Write only | | Register address | 0xB000009C | Initial value | Unknown | #### Bit Assignments of R\_NETWORK\_TR\_CTRL | Bit(s) | Name | Description | State/Range | |--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 9 | Reserved | - | 0 | | 8 | clr_error | This bit clears underrun and excessive collision conditions. If the transmitter has stopped due to either error condition it is restarted by setting this bit to <b>clr</b> . The bit is not saved, i.e. the state reverts to <b>nop</b> . There is no need to set it to <b>nop</b> again to be able to detect a new underrun. | 0 = nop<br>1 = clr | | 7 - 6 | Reserved | - | 0 | | 5 | delay | In IEEE802.12 mode this bit enables a 2 $\mu s$ delay from transmit request acknowledge until transmission starts. (note 1) | 0 = none<br>1 = d2us | | 4 | cancel | This bit cancels a pending frame. If it is set to <b>do</b> (1), the transmitter completes the current transmission attempt (if any), and then stops. The excessive retry condition is then entered, regardless of whether a transmission was in progress. | 0 = dont<br>1 = do | | 3 | cd | In IEEE802.12 mode this bit determines if a transmit request acknowledge will occur on the collision detect (ack_col) pin or the carrier sense (ack_crs) pin. (note 1) | 0 = ack_col<br>1 = ack_crs | | 2 | retry | This bit enables or disables retransmission. If it is set, the transmitter will stop and enter the excessive retry condition after the first collision instead of making 15 transmission retries. This bit is ignored in IEEE802.12 mode. | 0 = enable<br>1 = disable | | 1 | pad | If this bit is set to <b>enable</b> , a frame shorter than 60 bytes (excluding preamble, start of frame delimiter and CRC) is padded to 60 bytes. The pad consists of all 0's. This bit should be 0 in IEEE802.12 mode. | 0 = disable<br>1 = enable | | 0 | crc | This bit enables or disables CRC. If it is set, the transmitter will not add the CRC after the frame. | 0 = enable<br>1 = disable | **Note:** In IEEE802.3 (Ethernet) mode this bit is reserved and should be set to 0. # 18.9.9 R\_NETWORK\_MGM\_CTRL #### **Network MGM Control Register, General Characteristics** | ID of register | R_NETWORK_MGM_CTRL | Size | 32 bits | |------------------|--------------------|---------------|------------| | Offset | 0xA0 | Read/Write | Write only | | Register address | 0xB00000A0 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_MGM\_CTRL | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 31 - 8 | Reserved | - | 0 | | 7 - 4 | txd_pins | These bits are output on <b>txdata3</b> - <b>txdata0</b> when the network controller is disabled or in internal loopback mode. Bits 7 - 5 are output on <b>txdata3</b> - <b>txdata1</b> also when SNI mode is selected. | 0 - 15 | | 3 | txer_pin | This bit is output on the <b>txer</b> pin when SNI mode is selected. | 0 - 1 | | 2 | mdck | Management clock. This bit is output on the <b>mdc</b> pin. | 0 - 1 | | 1 | mdoe | This bit is the output enable for the <b>mdio</b> pin. | 0=disable<br>1=enable | | 0 | mdio | mdio pin output data. | 0 - 1 | # 18.9.10 R\_NETWORK\_STAT #### **Network Status Register, General Characteristics** | ID of register | R_NETWORK_STAT | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xA0 | Read/Write | Read only | | Register address | 0xB00000A0 | Initial value | Unknown | # Bit Assignments of R\_NETWORK\_STAT | Bit(s) | Name | Description | State/Range | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 31 - 8 | Reserved | i- | 0 | | 7 - 4 | rxd_pins | This field shows the values on rxdata3 - rxdata0. | 0 - 15 | | 3 | rxer | This field shows the value on the <b>rxer</b> pin. | 0 - 1 | | 2 | underrun | This bit is set if a transmitter underrun is detected, i.e. it is set if DMA channel 0 is not capable to keep up with the speed of the transmitter. It is cleared by setting the <code>clr_error</code> bit in the "R_NETWORK_TR_CTRL" register. | 0 = no<br>1 = yes | | 1 | exc_col | This bit indicates when excessive collision has been detected. It is set after 15 unsuccessful transmission retries, or after the first collision if retransmission is disabled. It is also set when the transmitter stops after the transmit cancel bit has been set. It is cleared by setting the clr_error bit in the "R_NETWORK_TR_CTRL" register. | 0 = no<br>1 = yes | | 0 | mdio | mdio pin input data. | 0 - 1 | # 18.9.11 R\_REC\_COUNTERS #### **Receive Error Counters Register, General Characteristics** | ID of register | R_REC_COUNTERS | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xA4 | Read/Write | Read only | | Register address | 0xB00000A4 | Initial value | Unknown | # Bit Assignments of R\_REC\_COUNTERS | Bit(s) | Name | Description | State/Range | |---------|-----------------|--------------------------------------------------------------------------------------------------------------|-------------| | 31 - 24 | congestion | This field gives the number of otherwise correct frames that were not received due to a FIFO full condition. | 0 - 255 | | 23 - 16 | oversize | This field gives the number of oversized frames. | 0 - 255 | | 15 - 8 | alignment_error | This field gives the number of frames with alignment errors. | 0 - 255 | | 7 - 0 | crc_error | This field gives the number of frames with CRC errors. | 0 - 255 | **Note:** Each 8-bit counter is reset by reading it. # 18.9.12 R\_TR\_COUNTERS #### **Transmit Statistics Counters Register, General Characteristics** | ID of register | R_TR_COUNTERS | Size | 32 bits | |------------------|---------------|---------------|-----------| | Offset | 0xA8 | Read/Write | Read only | | Register address | 0xB00000A8 | Initial value | Unknown | # Bit Assignments of R\_TR\_COUNTERS | Bit(s) | Name | Description | State/Range | |---------|--------------|--------------------------------------------------------------------------------------|-------------| | 31 - 24 | deferred | This field gives the number of deferred transmit frames. | 0 - 255 | | 23 - 16 | late_col | This field gives the number of frames that were involved in late collisions. | 0 - 255 | | 15 - 8 | multiple_col | This field gives the number of frames that were involved in more than one collision. | 0 - 255 | | 7 - 0 | single_col | This field gives the number of frames that were involved in exactly one collision. | 0 - 255 | **Note:** Each 8-bit counter is reset by reading it. # 18.9.13 R\_PHY\_COUNTERS #### **PHY Error Counters Register, General Characteristics** | ID of register | R_PHY_COUNTERS | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xAC | Read/Write | Read only | | Register address | 0xB00000AC | Initial value | Unknown | #### **Bit Assignments of R\_PHY\_COUNTERS** | Bit(s) | Name | Description | State/Range | |---------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | Reserved | - | 0 | | 15 - 8 | sqe_test_error | When the chip is configured for 10Mb Ethernet, this field gives the number of transmit frames for which the sqe test signal was not recognized. | 0 - 255 | | 7 - 0 | carrier_loss | This field gives the number of transmit frames for which the carrier sense signal was not constantly present during the transmission. | 0 - 255 | **Note:** Each 8-bit counter is reset by reading it. # 18.10 Parallel Port Registers #### 18.10.1 R\_PARO\_CTRL\_DATA #### Parallel Port p0 Control and Data Register, General Characteristics | ID of register | R_PAR0_CTRL_DATA | Size | 32 bits | |------------------|------------------|---------------|------------| | Offset | 0x40 | Read/Write | Write only | | Register address | 0xB0000040 | Initial value | Unknown | #### Bit Assignments of R\_PAR0\_CTRL\_DATA | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 25 | Reserved | - | 0 | | 24 | peri_int | This bit is used to acknowledge a peripheral interrupt. This must be done to enable new interrupts from a peripheral. To avoid false interrupts, it should also be done before peri_int is enabled for the first time. This bit takes action on write, and its state is not saved. | 0 = nop<br>1 = ack | | 23 - 21 | Reserved | - | 0 | | 20 | oe | This bit enables or disables the output for the data buffer when Parallel Port $p\theta$ is in manual mode. | 0 = disable<br>1 = enable | | 19 | seli | This bit controls the $\overline{\textbf{p0selectin}}$ signal when Parallel Port p0 is in manual mode. $\overline{\textbf{p0selectin}}$ is asserted when the $\overline{\textbf{seli}}$ bit is set to $\overline{\textbf{active}}$ . (note 1) | 0 = inactive<br>1 = active | | 18 | autofd | This bit controls the <b>poautofd</b> signal when Parallel Port p0 is in Manual, Centronics (Compatibility), or IBM fastbyte modes. <b>poautofd</b> is asserted when the <b>autofd</b> bit is set to <b>active</b> . (note 2) | 0 = inactive<br>1 = active | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 17 | strb | This bit controls the <b>p0strobe</b> signal when Parallel Port p0 is in manual mode. <b>p0strobe</b> is asserted when the <b>strb</b> bit is set to <b>active</b> . (note 3) | 0 = inactive<br>1 = active | | 16 | init | This bit controls the $\overline{p0init}$ signal when Parallel Port p0 is in manual, Centronics (Compatibility), IBM fastbyte, nibble or byte modes. $\overline{p0init}$ is asserted when the $init$ bit is set to active. (note 4) | 0 = inactive<br>1 = active | | 15 - 9 | Reserved | - | 0 | | 8 | ecp_cmd | If Parallel Port p0 is in ECP forward mode, this bit indicates whether the transmitted byte contains data or a command. The bit is automatically set low when a command byte has been transmitted. | 0 = data<br>1 = command | | 7 - 0 | data | Output data to <b>p0d7</b> - <b>p0d0</b> in non DMA operation. | | - Note 1: The polarity of the $\overline{\text{p0selectin}}$ signal depends upon inversion control bit control bit 24 (iseli) in register R\_PARO\_CONFIG. When iseli is set to noninv (0), the value active will set $\overline{\text{p0selectin}}$ to 0. - Note 2: The polarity of the **polaritofd** signal depends upon inversion control bit 23 (**iautofd**) in register R\_PARO\_CONFIG. When **iautofd** is set to **noninv** (0), the value **active** will set **polaritofd** to 0. - Note 3: The polarity of the $\overline{p0strobe}$ signal depends upon inversion control bit 22 (istrb) in register R\_PARO\_CONFIG. When istrb is set to noninv (0), the value active will set $\overline{p0strobe}$ to 0. - Note 4: The polarity of the $\overline{\textbf{p0init}}$ signal depends upon inversion control bit 21 (iinit) in register R\_PAR0\_CONFIG. When iinit is set to noninv (0), the value active will set $\overline{\textbf{p0init}}$ to 0. ## 18.10.2 R\_PARO\_CTRL ## Parallel Port p0 Control Register, General Characteristics | ID of register | R_PAR0_CTRL | Size | 8 bits | |------------------|-------------|---------------|------------| | Offset | 0x42 | Read/Write | Write only | | Register address | 0xB0000042 | Initial value | Unknown | # Bit Assignments of R\_PAR0\_CTRL | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------|-------------| | 7 - 5 | Reserved | - | 0 | | 4 - 0 | ctrl | This field is the same as bits 20 to 16 in register R_PARO_CTRL_DATA. | 0 - 31 | ## 18.10.3 R\_PARO\_STATUS\_DATA ## Parallel Port p0 Status and Data Register, General Characteristics | ID of register | R_PAR0_STATUS_DATA | Size | 32 bits | |------------------|--------------------|---------------|-----------| | Offset | 0x40 | Read/Write | Read only | | Register address | 0xB0000040 | Initial value | Unknown | ## Bit Assignments of R\_PAR0\_STATUS\_DATA | Bit(s) | Name | Description | State/Range | |---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 29 | mode | The value of this field indicates the current data transfer mode status of Parallel Port p0. These values are valid only if ext_mode in register "R_PAR0_CONFIG" is set. (note 1) | 0 = manual<br>1 = centronics<br>2 = fastbyte<br>3 = nibble<br>4 = byte<br>5 = ecp_fwd<br>6 = ecp_rev<br>7 = off<br>0 = epp_rd<br>5 = epp_wr1<br>6 = epp_wr2 | | | | | $7 = epp\_wr3$ | | 28 | perr | This bit indicates the status of external peripheral error signal <b>p0perror</b> at Parallel Port p0. (note 2) | 0 = inactive<br>1 = active | | 27 | ack | This bit indicates the status of external acknowledge signal <b>p0ack</b> at Parallel Port p0. (note 2) | 0 = active<br>1 = inactive | | 26 | busy | This bit indicates the status of external signal <b>p0busy</b> at Parallel Port p0. (note 2) | 0 = inactive<br>1 = active | | 25 | fault | This bit indicates the status of external signal $\overline{\text{p0fault}}$ at Parallel Port p0. (note 2) | 0 = active<br>1 = inactive | | 24 | sel | This bit indicates the status of external signal <b>p0select</b> at Parallel Port p0. (note 2) | 0 = inactive<br>1 = active | | 23 | ext_mode | This bit indicates whether EPP extended mode is selected at Parallel Port p0. (note 3) | 0 = disable<br>1 = enable | | 22 | ecp_16 | This bit indicates whether ECP 16-bit mode is selected at Parallel Port $p0$ . | 0 = inactive<br>1 = active | | 21 - 18 | Reserved | - | 0 | | 17 | tr_rdy | This bit indicates whether a peripheral is ready for a transmission from Parallel Port p0. It is set <b>ready</b> (1) when a new byte can be written to register "R_PARO_CTRL_DATA". | 0 = busy<br>1 = ready | | 16 | dav | This bit indicates whether new data has been received in register "R_PAR0_STATUS_DATA" in non DMA mode. In DMA mode, set this bit to data (1) whenever data is stored in the DMA FIFO. In both DMA and non DMA modes this bit is cleared when R_PAR0_STATUS_DATA is read. | 0 = nodata<br>1 = data | | 15 - 9 | Reserved | - | 0 | #### Bit Assignments of R\_PAR0\_STATUS\_DATA (continued) | 8 | ecp_cmd | If Parallel Port p0 is in ECP reverse mode, bit <b>ecp_cmd</b> indicates whether the received byte contains data or a command. | 0 = data<br>1 = command | |-------|---------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 7 - 0 | data | Contains the latest byte received on the data lines at Parallel Port p0. | | - **Note 1:** This field can be used to detect mode change when **force** in register R\_PAR0\_CONFIG is set to **off**, see the mode field in R\_PAR0\_CONFIG. - The state of the poack, pobusy, pofault, poperror and poselect signals depend respectively upon the states of iack, ibusy, ifault, iperr and isel in register R\_PARO\_CONFIG. The table below gives the relationship between pin values, inversion control bits, and status bits: | p0ack<br>p0busy<br><u>p0perro</u> r<br>p0fault<br>p0select | iack<br>ibusy<br>ifault<br>iperr<br>isel | ack<br>busy<br>fault<br>perr<br>sel | |------------------------------------------------------------|------------------------------------------|-------------------------------------| | 0 | 0 | 0 | | 1 | 0 | 1 | | 0 | 1 | 1 | | 1 | 1 | 0 | **Note 3:** See 18.10.6, note 2. ## 18.10.4 R\_PARO\_STATUS # Parallel Port p0 Status Register, General Characteristics | ID of register | R_PAR0_STATUS | Size | 16 bits (Word) | |------------------|---------------|---------------|----------------| | Offset | 0x42 | Read/Write | Read only | | Register address | 0xB0000042 | Initial value | Unknown | ## **Bit Assignments of R\_PAR0\_STATUS** | Bit(s) | Name | Description | State/Range | |---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | 15 - 13 | mode | The value of this field indicates the current data transfer mode of Parallel Port p0. These values are valid only if ext_mode in register "R PARO CONFIG" is set. | 0 = manual<br>1 = centronics<br>2 = fastbyte<br>3 = nibble<br>4 = byte<br>5 = ecp_fwd<br>6 = ecp_rev<br>7 = off<br>0 = epp_rd | | | | (note 1) | 5 = epp_wr1<br>6 = epp_wr2<br>7 = epp_wr3 | | 12 | perr | This bit indicates the status of external peripheral error signal <b>p0perror</b> at Parallel Port p0. (note 2) | 0 = inactive<br>1 = active | | 11 | ack | This bit indicates the status of external acknowledge signal $\overline{\textbf{p0ack}}$ at Parallel Port p0. (note 3) | 0 = active<br>1 = inactive | | 10 | busy | This bit indicates the status of external signal <b>p0busy</b> at Parallel Port p0. (note 3) | 0 = inactive<br>1 = active | | 9 | fault | This bit indicates the status of external signal $\overline{\text{p0fault}}$ at Parallel Port p0. (note 3) | 0 = active<br>1 = inactive | | 8 | sel | This bit indicates the status of external signal <b>p0select</b> at Parallel Port p0. (note 3) | 0 = inactive<br>1 = active | | 7 | ext_mode | This bit indicates whether the EPP extended mode is selected at Parallel Port $p0$ . (note 4) | 0 = disable<br>1 = enable | | 6 | ecp_16 | This bit indicates whether the ECP 16-bit mode is selected at Parallel Port p0. | 0 = inactive<br>1 = active | | 5 - 2 | Reserved | - | 0 | | 1 | tr_rdy | This bit indicates whether a peripheral is ready for a transmission from Parallel Port p0. It is set <b>ready</b> (1) when a new byte can be written to register "R_PARO_CTRL_DATA". | 0 = busy<br>1 = ready | | 0 | dav | This bit indicates whether new data has been received in register "R_PAR0_STATUS_DATA" in non DMA mode. In DMA mode, set this bit to <b>data</b> (1) whenever data is stored in the DMA FIFO. In both DMA and non DMA modes this bit is cleared when R_PAR0_STATUS_DATA is read. | 0 = nodata<br>1 = data | - Note 1: This field can be used to detect mode change when force in register R\_PAR0\_CONFIG is set to off, see the mode field in R\_PAR0\_CONFIG. - The state of the poack, pobusy, pofault, poperror and poselect signals depend respectively upon the states of iack, ibusy, ifault, iperr and isel in register R\_PARO\_CONFIG. The table below gives the relationship between pin values, inversion control bits, and status bits: | p0ack<br>p0busy<br><u>p0perro</u> r<br>p0fault<br>p0select | iack<br>ibusy<br>ifault<br>iperr<br>isel | ack<br>busy<br>fault<br>perr<br>sel | |------------------------------------------------------------|------------------------------------------|-------------------------------------| | 0 | 0 | 0 | | 1 | 0 | 1 | | 0 | 1 | 1 | | 1 | 1 | 0 | - **Note 3:** See 18.10.6, note 2. - **Note 4:** This 16-bit register is part of the 32-bit register "R\_PAR0\_STATUS\_DATA". ## 18.10.5 R\_PAR\_ECP16\_DATA ## Parallel Port ECP Wide Data Register, General Characteristics | ID of register | R_PAR_ECP16_DATA | Size | 16 bits | |----------------|------------------|---------------|------------| | Offset | 0x40 | Read/Write | Read/Write | | Address | 0xB0000040 | Initial value | Unknown | ## Bit Assignments of R\_PAR\_ECP16\_DATA | Bit(s) | Name | Description | State/Range | |--------|------|------------------------------------------------------------------------------|-------------| | 15 - 0 | data | In ECP wide mode this register contains the last data word sent or received. | | ## 18.10.6 R\_PARO\_CONFIG #### Parallel Port p0 Configuration Register, General Characteristics | ID of register | R_PAR0_CONFIG | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0x44 | Read/Write | Write only | | Address | 0xB0000044 | Initial value | 0 | ## Bit Assignments of R\_PAR0\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 31 - 26 | Reserved | - | 0 | | 25 | ioe | This bit inverts the data output enable signal. It is set if the output enable signal on the (optional) external driver is active low. | 0 = noninv<br>1 = inv | | 24 | iseli | This bit inverts the $\overline{\text{p0selectin}}$ signal. In manual mode, if $\overline{\text{seli}}$ in R_PARO_CTRL_DATA is set to active (1), the $\overline{\text{p0selectin}}$ pin will be set to one if this bit is set to $\overline{\text{inv}}$ (1). | 0 = noninv<br>1 = inv | | 23 | iautofd | This bit inverts the $\overline{\textbf{p0autofd}}$ signal. In manual mode, if $\overline{\textbf{autofd}}$ in R_PARO_CTRL_DATA is set to $\overline{\textbf{active}}$ (1), the $\overline{\textbf{p0autofd}}$ pin will be set to one if this bit is set to $\overline{\textbf{inv}}$ (1). | 0 = noninv<br>1 = inv | | 22 | istrb | This bit inverts the $\overline{\textbf{p0strobe}}$ signal. In manual mode, if $\overline{\textbf{strb}}$ in R_PAR0_CTRL_DATA is set to $\overline{\textbf{active}}$ (1), the $\overline{\textbf{p0strobe}}$ pin will be set to one if this bit is set to $\overline{\textbf{inv}}$ (1). | 0 = noninv<br>1 = inv | | 21 | iinit | This bit inverts the $\overline{\textbf{p0init}}$ signal. In manual mode, if $\overline{\textbf{init}}$ in R_PARO_CTRL_DATA is set to $\overline{\textbf{active}}$ (1), the $\overline{\textbf{p0init}}$ pin will be set to one if this bit is set to $\overline{\textbf{inv}}$ (1). | 0 = non-invert<br>1 = invert | | 20 | iperr | This bit inverts the <b>p0perror</b> signal. If this bit is set to <b>inv</b> (1) and the <b>p0perror</b> signal is set to one, <b>perr</b> in R_PAR0_STATUS is set to <b>inactive</b> (0). | 0 = noninv<br>1 = inv | | 19 | iack | This bit inverts the $\overline{p0ack}$ signal. If this bit is set to $inv$ (1) and the $\overline{p0ack}$ signal is set to one, $ack$ in R_PAR0_STATUS is set to $active$ (0). | 0 = noninv<br>1 = inv | | 18 | ibusy | This bit inverts the <b>p0busy</b> signal. If this bit is set to <b>inv</b> (1) and the <b>p0busy</b> signal is set to one, <b>busy</b> in R_PAR0_STATUS is set to <b>inactive</b> (0). | 0 = noninv<br>1 = inv | | 17 | ifault | This bit inverts the $\overline{\text{p0fault}}$ signal. If this bit is set to inv (1) and the $\overline{\text{p0fault}}$ signal is set to one, fault in R_PAR0_STATUS is set to active (0). | 0 = noninv<br>1 = inv | | 16 | isel | This bit inverts the <b>p0select</b> signal. If this bit is set to <b>inv</b> (1) and the <b>p0select</b> signal is set to one, <b>sel</b> in R_PARO_STATUS is set to <b>inactive</b> (0). | 0 = noninv<br>1 = inv | | 15 - 12 | Reserved | - | 0 | | 11 | ext_mode | This bit enables the EPP read and write modes in parallel Port ${\bf p0}$ . (note 2) | 0 = disable<br>1 = enable | | 10 | wide | This bit enables the ECP 16-bit mode in Parallel Port p0. (note 3) $$ | 0 = disable<br>1 = enable | | 9 | dma | This bit enables the DMA operation for Parallel Port p0. | 0 = disable<br>1 = enable | #### **Bit Assignments of R\_PAR0\_CONFIG (continued)** | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------| | 8 | rle_in | When Parallel Port p0 is in ECP mode, this bit enables the expansion of RLE-compressed incoming data. | 0 = disable<br>1 = enable | | 7 | rle_out | $When \ Parallel \ Port \ p0 \ is \ in \ ECP \ mode, this \ bit \ enables \\ the \ RLE \ compression \ of \ outgoing \ data.$ | 0 = disable<br>1 = enable | | 6 | enable | This bit enables/resets Parallel Port p0. | 0 = reset<br>1 = on | | 5 | force | When <b>on</b> , this bit forces an immediate mode change in Parallel Port p0. When <b>off</b> , the mode changes at the next handshake. To detect a mode change, register R_PAR0_STATUS must be read. | 0 = off<br>1 = on | | 4 | ign_ack | When Parallel Port $p0$ is in (compatibility) mode and this bit is set to <b>ignore</b> (1), the $\overline{p0ack}$ signal is ignored. (note 4) | 0 = wait<br>1 = ignore | | 3 | oe_ack | This bit controls whether data output is disabled after the <b>hold</b> time set in R_PAR0_DELAY has expired, or if data output is enabled until an ack is received. | | | | epp_addr_data | When Parallel Port p0 is in Centronics (Compatibility) mode, the bit determines whether the port waits, or does not wait, for acknowledgement from the peripheral. (note 5) | 0 = dont_wait<br>1 = wait_oe | | | | When Parallel Port p0 is in EPP mode, the bit indicates whether the byte present at Parallel Port p0 contains data or an address. | 0 = epp_data<br>1 = epp_addr | | 2 - 0 | mode | The value of this field selects the current data transfer mode of Parallel Port p0. | 0 = manual<br>1 = centronics<br>2 = fastbyte<br>3 = nibble<br>4 = byte<br>5 = ecp_fwd<br>6 = ecp_rev | | | | The OFF mode can be used to initiate an IEEE 1284 termination phase. In OFF mode the output signals of Parallel Port p0 are set as follows: | 7 = off | | | | To operate in an EPP mode, <b>ext_mode</b> in this register must be set to <b>enable</b> . (note 2) | 0 = epp_rd<br>5 = epp_wr1<br>6 = epp_wr2<br>7 = epp_wr3 | **Note 1:** The values, in parentheses, for the physical output signals above are affected by the value of the inversion bits in R\_PARO\_CTRL\_DATA. Note 2: The EPP mode is selected by the ext\_mode field and bits 2 to 0 of the mode field in register R\_PARO\_CONFIG. The ext\_mode field is the mode on/off switch and bits 2 to 0 of the mode field choose the read or write mode. This is shown in the truth table below. | avt mada | mode | | | EPP Mode | |----------|-------|-------|-------|------------------| | ext_mode | bit 2 | bit 1 | bit 0 | EFF Wode | | 0 | - | - | - | EPP mode off | | 1 | 0 | 0 | 0 | EPP read mode | | 1 | 1 | 0 | 1 | EPP write mode 1 | | 1 | 1 | 1 | 0 | EPP write mode 2 | | 1 | 1 | 1 | 1 | EPP write mode 3 | - Note 3: To enable the ECP wide mode in Parallel Port p0, par\_w and par0 in general configuration register R\_GEN\_CONFIG must both be set to select. - **Note 4:** To obtain the expected result when setting the **ign\_ack** bit to **ignore**, **oe\_ack** must be set to **dont\_wait**. - **Note 5:** To obtain the expected result when setting the **oe\_ack** bit to **wait\_oe**, **ign\_ack** must be set to **wait**. #### 18.10.7 R\_PARO\_DELAY #### Parallel Port p0 Delay Register, General Characteristics | ID of register | R_PAR0_DELAY | Size | 32 bits (Dword) | |------------------|--------------|---------------|-----------------| | Offset | 0x48 | Read/Write | Write only | | Register address | 0xB0000048 | Initial value | Unknown | # Bit Assignments of R\_PAR0\_DELAY | Bit(s) | Name | Description | State/Range | |---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 31 - 24 | Reserved | - | 0 | | 23 - 21 | fine_hold | The value of this field applies fine adjustment to the hold time (T $_{\mbox{\scriptsize hold}}$ ) of Parallel Port p0. | 0 -7 | | 20 - 16 | hold | The value of this field determines the minimum hold time $(T_{hold})$ when Parallel Port p0 is in Centronics (Compatibility) mode. It is the period from the active to inactive transition of the $\overline{\textbf{p0strobe}}$ signal until $\textbf{p0d7}$ to $\textbf{p0d0}$ are no longer valid. If the $\textbf{oe\_ack}$ bit in R_PARO_CONFIG is used, the data is valid until $\textbf{ack}$ arrives. (note 1) | 0 - 31<br>(20 ns to 5.0 μs) | | 15 - 13 | fine_strb | The value of this field applies fine adjustment to the strobe time ( $T_{strb}$ ) of Parallel Port p0. (note 2) | 0 - 7 | | 12 - 8 | strobe | The value of this field determines the strobe time $(T_{strb})$ when Parallel Port p0 is in Centronics (Compatibility) mode. It is the period in which the $\overline{\textbf{p0strobe}}$ signal is active. (note 2) | 0 - 31<br>(20 ns to 5.0 μs) | | 7 - 5 | fine_setup | The value of this field applies fine adjustment to the setup time $(T_{ub})$ of Parallel Port p0. (note 3) | 0 - 7 | | 4 - 0 | setup | The value of this field determines the setup time $(T_{su})$ when Parallel Port p0 is in IBM fastbyte, Centronics (Compatibility) and ECP forward modes. It is the period from the start of data output to the inactive to active transition of the $\overline{\textbf{p0strobe}}$ signal. (note 3) | 0 - 31<br>(10 ns to 5.0 μs) | Note 1: The formula for $T_{hold}$ is (hold x 160 + fine\_hold x 20 + 20) ns. **Note 2:** The formula for $T_{srtb}$ is (strobe x 160 + fine\_strb x 20 + 20) ns. Note 3: The formula for $T_{su}$ is (setup x 160 + fine\_setup x 20 + 10) ns. For example if setup is binary 00010 (0x2) and fine\_setup is binary 001 (0x1), then $T_{su}$ will be (2 x 160) + (1 x 20) + 10 = 350 ns. #### 18.10.8 R\_PAR1\_CTRL\_DATA #### Parallel Port p1 Control and Data Register, General Characteristics | ID of register | R_PAR1_CTRL_DATA | Size | 32 bits (Dword) | |------------------|------------------|---------------|-----------------| | Offset | 0x50 | Read/Write | Write only | | Register address | 0xB0000050 | Initial value | Unknown | #### Bit Assignments of R\_PAR1\_CTRL\_DATA | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 25 | Reserved | - | 0 | | 24 | peri_int | This bit is used to acknowledge a peripheral interrupt. This must be done to enable new interrupts from a peripheral. To avoid false interrupts, it should also be done before peri_int is enabled for the first time. This bit takes action on write, and its state is not saved. | 0 = nop<br>1 = ack | | 23 - 21 | Reserved | - | 0 | | 20 | oe | This bit enables or disables the output for the data buffer when Parallel Port $p1$ is in manual mode. | 0 = disable<br>1 = enable | | 19 | seli | This bit controls the $\overline{\textbf{p1selectin}}$ signal when Parallel Port p1 is in manual mode. $\overline{\textbf{p1selectin}}$ is asserted when the <b>seli</b> bit is set (active). (note 1) | 0 = inactive<br>1 = active | | 18 | autofd | This bit controls the $\overline{\textbf{p1autofd}}$ signal when Parallel Port p1 is in manual, Centronics (Compatibility), or IBM fastbyte modes. $\overline{\textbf{p1autofd}}$ is asserted when the $\overline{\textbf{autofd}}$ bit is set (active). (note 2) | 0 = inactive<br>1 = active | | 17 | strb | This bit controls the <b>p1strobe</b> signal when Parallel Port p1 is in manual mode. <b>p1strobe</b> is asserted when the <b>strb</b> bit is set ( <b>active</b> ). (note 3) | 0 = inactive<br>1 = active | | 16 | init | This bit controls the $\overline{p1init}$ signal when Parallel Port p1 is in manual, Centronics (Compatibility), IBM fastbyte, nibble or byte modes. $\overline{p1init}$ is asserted when the $init$ bit is set (active). (note 4) | 0 = inactive<br>1 = active | | 15 - 9 | Reserved | - | 0 | | 8 | ecp_cmd | If Parallel Port p1 is in ECP forward mode, this bit indicates whether the transmitted byte contains data or a command. | 0 = data<br>1 = command | | 7 - 0 | data | Data byte to <b>p1d7</b> - <b>p1d0</b> in non DMA operation. | | - Note 1: The polarity of the $\overline{\textbf{p1selectin}}$ signal depends upon inversion control bit control bit 24 (iseli) in register R\_PAR1\_CONFIG. When iseli is set to noninv (0), the value active will set $\overline{\textbf{p1selectin}}$ to 0. - Note 2: The polarity of the $\overline{p1autofd}$ signal depends upon inversion control bit 23 (iautofd) in register R\_PAR1\_CONFIG. When iautofd is set to noninv (0), the value active will set $\overline{p1autofd}$ to 0. - Note 3: The polarity of the $\overline{p1strobe}$ signal depends upon inversion control bit 22 (istrb) in register R\_PAR1\_CONFIG. When istrb is set to noninv (0), the value active will set $\overline{p1strobe}$ to 0. - **Note 4:** The polarity of the $\overline{p1init}$ signal depends upon inversion control bit 21 (iinit) in register R\_PAR1\_CONFIG. When **iinit** is set to **noninv** (0), the value **active** will set $\overline{\textbf{p1init}}$ to 0. ## 18.10.9 R\_PAR1\_CTRL ## Parallel Port p1 Control Register, General Characteristics | ID of register | R_PAR1_CTRL | Size | 8 bits | |------------------|-------------|---------------|------------| | Offset | 0x52 | Read/Write | Write only | | Register address | 0xB0000052 | Initial value | Unknown | # Bit Assignments of R\_PAR1\_CTRL | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------|-------------| | 7 - 5 | Reserved | - | 0 | | 4 - 0 | ctrl | This field is the same as bits 20 to 16 in register "R_PAR1_CTRL_DATA". | 0 - 31 | ## 18.10.10 R\_PAR1\_STATUS\_DATA #### Parallel Port p1 Status and Data Register, General Characteristics | ID of register | R_PAR1_STATUS_DATA | Size | 32 bits | |------------------|--------------------|---------------|-----------| | Offset | 0x50 | Read/Write | Read only | | Register address | 0xB0000050 | Initial value | Unknown | ## Bit Assignments of R\_PAR1\_STATUS\_DATA | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 29 | mode | The value of this field indicates the current data transfer mode status of Parallel Port p1. These values are valid only if ext_mode in register "R_PAR1_CONFIG" is set. (note 1) | 0 = manual<br>1 = centronics<br>2 = fastbyte<br>3 = nibble<br>4 = byte<br>5 = ecp_fwd<br>6 = ecp_rev<br>7 = off<br>0 = epp_rd<br>5 = epp_wr1<br>6 = epp_wr2 | | | | | 7 = epp_wr3 | | 28 | perr | This bit indicates the status of external peripheral error signal <b>p1perror</b> at Parallel Port p1. (note 2) | 0 = inactive<br>1 = active | | 27 8 | ack | This bit indicates the status of external acknowledge signal $\overline{\textbf{p1ack}}$ at Parallel Port p1. (note 2) | 0 = active<br>1 = inactive | | 26 | busy | This bit indicates the status of external signal <b>p1busy</b> at Parallel Port p1. (note 2) | 0 = inactive<br>1 = active | | 25 | fault | This bit indicates the status of external signal $\overline{\textbf{p1fault}}$ at Parallel Port p1. (note 2) | 0 = active<br>1 = inactive | | 24 | sel | This bit indicates the status of external signal ${\bf p1select}$ at Parallel Port ${\bf p1}$ . (note 2) | 0 = inactive<br>1 = active | | 23 | ext_mode | This bit indicates whether EPP extended mode is selected at Parallel Port p1. (note 3) | 0 = disable<br>1 = enable | | 22 | ecp_16 | This bit indicates whether ECP 16-bit mode is selected at Parallel Port $p1$ . | 0 = inactive<br>1 = active | | 21 - 18 | Reserved | - | 0 | | 17 | tr_rdy | This bit indicates whether a peripheral is ready for a transmission from Parallel Port p0. It is set <b>ready</b> (1) when a new byte can be written to register "R_PAR1_CTRL_DATA". | 0 = busy<br>1 = ready | | 16 | dav | This bit indicates whether new data has been received in register "R_PAR1_STATUS_DATA" in non DMA mode. In DMA mode, set this bit to <b>data</b> (1) whenever data is stored in the DMA FIFO. In both DMA and non DMA modes this bit is cleared when | 0 = nodata<br>1 = data | | | | "R_PAR1_STATUS_DATA" is read. | | #### Bit Assignments of R\_PAR1\_STATUS\_DATA (continued) | 8 | ecp_cmd | If Parallel Port p1 is in ECP reverse mode, bit <b>ecp_cmd</b> indicates whether the received byte contains data or a command. | 0 = data<br>1 = command | |-------|---------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 7 - 0 | data | Contains the latest byte received on data lines $d1d7:d1d0$ at Parallel Port $p1.$ | | - **Note 1:** This field can be used to detect mode change when **force** in register R\_PAR1\_CONFIG is set to **off**, see the **mode** field in R\_PAR1\_CONFIG. - The state of the plack, plbusy, plperror, plfault and plselect signals depend respectively upon the states of iack, ibusy, ifault, iperr and isel in register R\_PAR1\_CONFIG. The table below gives the relationship between pin values, inversion control bits, and status bits: | p1ack<br>p1busy<br><u>p1perro</u> r<br>p1fault<br>p1select | iack<br>ibusy<br>ifault<br>iperr<br>isel | ack<br>busy<br>fault<br>perr<br>sel | |------------------------------------------------------------|------------------------------------------|-------------------------------------| | 0 | 0 | 0 | | 1 | 0 | 1 | | 0 | 1 | 1 | | 1 | 1 | 0 | **Note 3:** See 18.10.12, note 2. ## 18.10.11 R\_PAR1\_STATUS #### Parallel Port p1 Status Register, General Characteristics | ID of register | R_PAR1_STATUS | Size | 16 bits | |------------------|---------------|---------------|-----------| | Offset | 0x52 | Read/Write | Read only | | Register address | 0xB0000052 | Initial value | Unknown | #### Bit Assignments of R\_PAR1\_STATUS | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | 15 - 13 | mode | The value of this field indicates the current data transfer mode of Parallel Port p1. | 0 = manual<br>1 = centronics<br>2 = fastbyte<br>3 = nibble<br>4 = byte<br>5 = ecp_fwd<br>6 = ecp_rev<br>7 = off | | | | These values are valid only if bit 11 in register "R_PAR1_CONFIG" is set. (note 1) | 0 = epp_rd<br>5 = epp_wr1<br>6 = epp_wr2<br>7 = epp_wr3 | | 12 | perr | This bit indicates the status of external peripheral error signal <b>p1perror</b> at Parallel Port p1. (note 2) | 0 = inactive<br>1 = active | | 11 | ack | This bit indicates the status of external acknowledge signal $\overline{\textbf{p1ack}}$ at Parallel Port p1. (note 3) | 0 = active<br>1 = inactive | | 10 | busy | This bit indicates the status of external signal <b>p1busy</b> at Parallel Port p1. (note 3) | 0 = inactive<br>1 = active | | 9 | fault | This bit indicates the status of external signal $\overline{\textbf{p1fault}}$ at Parallel Port p1. (note 3) | 0 = active<br>1 = inactive | | 8 | sel | This bit indicates the status of external signal <b>p1select</b> at Parallel Port p1. (note 3) | 0 = inactive<br>1 = active | | 7 | ext_mode | This bit indicates whether EPP extended mode is selected at Parallel Port p1. (note 4) | 0 = disable<br>1 = enable | | 6 - 2 | Reserved | - | 0 | | 1 | tr_rdy | This bit indicates whether a peripheral is ready for a transmission from Parallel Port p0. It is set <b>ready</b> (1) when a new byte can be written to register "R_PAR1_CTRL_DATA". | 0 = busy<br>1 = ready | | 0 | dav | This bit indicates whether new data has been received in register "R_PAR1_STATUS_DATA" in non DMA mode. In DMA mode, set this bit to <b>data</b> (1) whenever data is stored in the DMA FIFO. In both DMA and non DMA modes this bit is cleared when "R_PAR1_STATUS_DATA" is read. | 0 = nodata<br>1 = data | **Note 1:** This field can be used to detect mode change when force in register R\_PAR1\_CONFIG is set to **off**, see the **mode** field in R\_PAR1\_CONFIG. Note 2: The state of the $\overline{p1ack}$ , p1busy, p1perror, $\overline{p1fault}$ and p1select signals depend respectively upon the states of iack, ibusy, ifault, iperr and isel in register R\_PAR1\_CONFIG. The table below gives the relationship between pin values, inversion control bits, and status bits: | p1ack<br>p1busy<br><u>p1perro</u> r<br>p1fault<br>p1select | iack<br>ibusy<br>ifault<br>iperr<br>isel | ack<br>busy<br>fault<br>perr<br>sel | |------------------------------------------------------------|------------------------------------------|-------------------------------------| | 0 | 0 | 0 | | 1 | 0 | 1 | | 0 | 1 | 1 | | 1 | 1 | 0 | **Note 3:** See 18.10.12, note 2. **Note 4:** This 16-bit register is part of the 32-bit register "R\_PAR1\_STATUS\_DATA". ## 18.10.12 R\_PAR1\_CONFIG #### Parallel Port p1 Configuration Register, General Characteristics | ID of register | R_PAR1_CONFIG | Size | 32 bits | |----------------|---------------|---------------|------------| | Offset | 0x54 | Read/Write | Write only | | Address | 0xB0000054 | Initial value | 0 | ## **Bit Assignments of R\_PAR1\_CONFIG** | Bit(s) | Name | Description | State/Range | |---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 31 - 26 | Reserved | - | 0 | | 25 | ioe | This bit inverts the data output enable signal. It is set if the output enable signal on the (optional) external driver is active low. | 0 = noninv<br>1 = inv | | 24 | iseli | This bit inverts the $\overline{\textbf{p1selectin}}$ signal. In manual mode, if $\overline{\textbf{seli}}$ in R_PAR1_CTRL_DATA is set to $\overline{\textbf{active}}$ (1), the $\overline{\textbf{p1selectin}}$ pin will be set to one if this bit is set to $\overline{\textbf{inv}}$ (1). | 0 = noninv<br>1 = inv | | 23 | iautofd | This bit inverts the $\overline{\textbf{p1autofd}}$ signal. In manual mode, if $\overline{\textbf{autofd}}$ in R_PAR1_CTRL_DATA is set to $\overline{\textbf{active}}$ (1), the $\overline{\textbf{p1autofd}}$ pin will be set to one if this bit is set to $\overline{\textbf{inv}}$ (1). | 0 = noninv<br>1 = inv | | 22 | istrb | This bit inverts the $\overline{p1strobe}$ signal. In manual mode, if $\underline{strb}$ in R_PAR1_CTRL_DATA is set to active (1), the $\overline{p1strobe}$ pin will be set to one if this bit is set to $\underline{inv}$ (1). | 0 = noninv<br>1 = inv | | 21 | iinit | This bit inverts the $\overline{\textbf{p1init}}$ signal. In manual mode, if $\overline{\textbf{init}}$ in R_PAR1_CTRL_DATA is set to $\overline{\textbf{active}}$ (1), the $\overline{\textbf{p1init}}$ pin will be set to one if this bit is set to $\overline{\textbf{inv}}$ (1). | 0 = non-invert<br>1 = invert | | 20 | iperr | This bit inverts the <b>p1perror</b> signal. If this bit is set to <b>inv</b> (1) and the <b>p1perror</b> signal is set to one, <b>perr</b> in R_PAR1_STATUS is set to <b>inactive</b> (0). | 0 = noninv<br>1 = inv | | 19 | iack | This bit inverts the $\overline{\textbf{p1ack}}$ signal. If this bit is set to $\overline{\textbf{inv}}$ (1) and the $\overline{\textbf{p1ack}}$ signal is set to one, $\overline{\textbf{ack}}$ in R_PAR1_STATUS is set to $\overline{\textbf{active}}$ (0). | 0 = noninv<br>1 = inv | | 18 | ibusy | This bit inverts the <b>p1busy</b> signal. If this bit is set to <b>inv</b> (1) and the <b>p1busy</b> signal is set to one, <b>busy</b> in R_PAR1_STATUS is set to <b>inactive</b> (0). | 0 = noninv<br>1 = inv | | 17 | ifault | This bit inverts the $\overline{\textbf{p1fault}}$ signal. Iff this bit is set to $\overline{\textbf{inv}}$ (1) and the $\overline{\textbf{p1fault}}$ signal is set to one, $\overline{\textbf{fault}}$ in R_PAR1_STATUS is set to $\overline{\textbf{active}}$ (0). | 0 = noninv<br>1 = inv | | 16 | isel | This bit inverts the <b>p1select</b> signal. If this bit is set to <b>inv</b> (1) and the <b>p1select</b> signal is set to one, <b>sel</b> in R_PAR1_STATUS is set to <b>inactive</b> (0). | 0 = noninv<br>1 = inv | | 15 - 12 | Reserved | - | 0 | | 11 | ext_mode | This bit enables the EPP read and write modes in parallel Port p1. (note 2) | 0 = disable<br>1 = enable | | 10 | Reserved | - | 0 | | 9 | dma | This bit enables the DMA operation for Parallel Port p1. | 0 = disable<br>1 = enable | #### **Bit Assignments of R\_PAR1\_CONFIG (continued)** | Bit(s) | Name | Description | State/Range | |--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | 8 | rle_in | When Parallel Port p1 is in ECP mode, this bit enables the expansion of RLE-compressed incoming data. | 0 = disable<br>1 = enable | | 7 | rle_out | When Parallel Port p1 is in ECP mode, this bit enables the RLE compression of outgoing data. | 0 = disable<br>1 = enable | | 6 | enable | This bit enables/resets Parallel Port p1. | 0 = reset<br>1 = on | | 5 | force | When <b>on</b> (1), this bit forces an immediate mode change in Parallel Port p1. When <b>off</b> (0), the mode changes at the next handshake. To detect a mode change, register R_PAR1_STATUS must be read. | 0 = off<br>1 = on | | 4 | ign_ack | When Parallel Port p1 is in Centronics (Compatibility) mode and this bit is set to <b>ignore</b> (1), the $\overline{p1ack}$ signal is ignored. (note 3) | 0 = wait<br>1 = ignore | | 3 | oe_ack | This bit controls whether data output is disabled after the <b>hold</b> time set in R_PAR1_DELAY has expired, or if data output is enabled until an ack is received. | | | | epp_addr_data | When Parallel Port p1 is in Centronics (Compatibility) mode, this bit determines whether the port waits, or does not wait, for acknowledgement from the peripheral. (note 4) | 0 = dont_wait<br>1 = wait_oe | | | | When Parallel Port p1 is in EPP mode, the bit indicates whether the byte contains data or an address. | 0 = epp_data<br>1 = epp_addr | | 2 - 0 | mode | The value of this field selects the current data transfer mode of Parallel Port p1. The OFE mode can be used to initiate an IFFE 1284 | 0 = manual<br>1 = centronics<br>2 = fastbyte<br>3 = nibble<br>4 = byte<br>5 = ecp_fwd<br>6 = ecp_rev<br>7 = off | | | | The OFF mode can be used to initiate an IEEE 1284 termination phase. In OFF mode the output signals of Parallel Port p1 are set as follows: p1selectin = active (0) (IEEE 1284 not active) p1autofd = inactive (1) p1strobe = inactive (1) p1init = inactive (1) (note 1) | 7 = off | | | | To operate in an EPP mode, <b>ext_mode in this register</b> must be set to <b>enable</b> . (note 2) | 0 = epp_rd<br>5 = epp_wr1<br>6 = epp_wr2<br>7 = epp_wr3 | **Note 1:** The values, in parentheses, for the physical output signals above are affected by the value of the inversion bits in $R_PAR1_CTRL_DATA$ . Note 2: The EPP mode is selected by the ext\_mode field and bits 2 to 0 of the mode field in register R\_PAR1\_CONFIG. The ext\_mode field is the mode on/off switch and bits 2 to 0 of the mode field choose the read or write mode. This is shown in the truth table below. | ext mode | mode | | | EPP Mode | |----------|-------|-------|-------|------------------| | ext_mode | bit 2 | bit 1 | bit 0 | EFF Mode | | 0 | - | - | - | EPP mode off | | 1 | 0 | 0 | 0 | EPP read mode | | 1 | 1 | 0 | 1 | EPP write mode 1 | | 1 | 1 | 1 | 0 | EPP write mode 2 | | 1 | 1 | 1 | 1 | EPP write mode 3 | - **Note 3:** To obtain the expected result when setting the **ign\_ack** bit to **ignore**, **oe\_ack** must be set to **dont\_wait**. - **Note 4:** To obtain the expected result when setting the **oe\_ack** bit to **wait\_oe**, **ign\_ack** must be set to **wait**. #### 18.10.13 R\_PAR1\_DELAY #### Parallel Port p1 Delay Register, General Characteristics | ID of register | R_PAR1_DELAY | Size | 32 bits | |------------------|--------------|---------------|------------| | Offset | 0x58 | Read/Write | Write only | | Register address | 0xB0000058 | Initial value | Unknown | #### Bit Assignments of R\_PAR1\_DELAY | Bit(s) | Name | Description | State/Range | |---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 31 - 24 | Reserved | - | 0 | | 23 - 21 | fine_hold | The value of this field applies fine adjustment to the hold time ( $T_{hold}$ ) of Parallel Port p1. (note 1) | 0 -7 | | 20 - 16 | hold | The value of this field determines the minimum hold time $(T_{hold})$ when Parallel Port p0 is in Centronics (Compatibility) mode. It is the period from the active to inactive transition of the $\overline{\textbf{p1strobe}}$ signal until $\textbf{p1d7}$ to $\textbf{p1d0}$ are no longer valid. If the $\textbf{oe\_ack}$ bit in R_PAR1_CONFIG is used, the data is valid until $\textbf{ack}$ arrives. (note 1) | 0 - 31<br>(20 ns to 5.1 μs) | | 15 - 13 | fine_strb | The value of these bits applies fine adjustment to the strobe time $(T_{strb})$ of Parallel Port p1. (note 2) | 0 - 7 | | 12 - 8 | strobe | The value of these bits determines the strobe time $(T_{strb})$ when Parallel Port p1 is in Centronics (Compatibility) mode. It is the period in which the $\overline{\textbf{p1strobe}}$ signal is active. (note 2) | 0 - 31<br>(20 ns to 5.1 μs) | | 7 - 5 | fine_setup | The value of these bits applies fine adjustment to the setup time $(T_{ub})$ of Parallel Port p1. (note 3) | 0 - 7 | | 4 - 0 | setup | The value of these bits determines the setup time $(T_{su})$ when Parallel Port p1 is in IBM Fastbyte, Centronics (Compatibility) and ECP forward modes. It is the period from the start of data output to the inactive to active transition of the $\overline{\textbf{p1strobe}}$ signal. (note 3) | 0 - 31<br>(10 ns to 5.0 μs) | **Note 1:** The formula for $T_{hold}$ is (hold x 160 + fine\_hold x 20 + 20) ns. **Note 2:** The formula for $T_{srtb}$ is (strobe x 160 + fine\_strb x 20 + 20) ns. Note 3: The formula for $T_{su}$ is (setup x 160 + fine\_setup x 20 + 10) ns. For example if setup is binary 00010 (0x2) and fine\_setup is binary 001 (0x1), then $T_{su}$ will be (2 x 160) + (1 x 20) + 10 = 350 ns. # 18.11 ATA Interface Registers #### 18.11.1 R\_ATA\_CTRL\_DATA #### ATA Control and Data Register, General Characteristics | ID of register | R_ATA_CTRL_DATA | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x40 | Read/Write | Write only | | Register address | 0xB0000040 | Initial value | Unknown | #### Bit Assignments of R\_ATA\_CTRL\_DATA | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 30 | sel | This field selects ATA bus 0 - 3. | 0 - 3 | | 29 | cs1 | This bit activates chip select 1 on the ATA bus. cs1 and cs0 should never be set to the same value, either to inactive (0) or active (1), at the same time. | 0 = inactive<br>1 = active | | 28 | cs0 | This bit activates chip select 0 on the ATA bus. cs0 and cs1 should never be set to the same value, either to inactive (0) or active (1), at the same time. | 0 = inactive<br>1 = active | | 27 - 25 | addr | This field gives the ATA bus device address. | 0 - 7 | | 24 | rw | This bit selects read or write. | 0 = write<br>1 = read | | 23 | src_dst | If this bit is set to <b>dma</b> (1), the source (write) or the destination (read) for data is the internal DMA. Otherwise the <b>data</b> field in this register is the source and the <b>data</b> field in "R_ATA_STATUS_DATA" is the destination. | 0 = register<br>1 = dma | | 22 | handsh | This bit selects PIO or DMA handshaking on the ATA bus.DMA handshaking can only be used for data transfers with ATA DMA commands. | 0 = pio<br>1 = dma | | 21 | multi | If this bit is set to <b>on</b> (1), transfers, each consisting of one PIO read and write or one DMA burst, will continue whenever there are data to be read or written. If the bit is not set ( <b>off</b> ), this register has to be written again to continue. Bit 18 ( <b>busy</b> ) in "R_ATA_STATUS_DATA" will be set <b>to yes</b> until "R_ATA_TRANSFER_CNT" reaches zero. | 0 = off<br>1 = on | | 20 | dma_size | This bit selects the size of the DMA transfers, 16 bits (word) or 8 bits (byte). Byte transfers are only needed for devices that use 8 bit transfers to/from the data register and devices that do not support DMA handshaking. | 0 = word<br>1 = byte | | 19 - 16 | Reserved | - | 0 | | 15 - 0 | data | The data in this field is written to the ATA unit if src_dst is set to register and rw is set to write. | | Note: This register is used to read and write data to and from ATA units. When writing, data is supplied by the data field in this register or by the internal DMA. When reading, data ends up in the data field in R\_ATA\_STATUS\_DATA register or in the internal DMA. Writing to the register starts a transfer. Before a new read or write is written to this register, **busy** in R\_ATA\_STATUS\_DATA should be read as cleared **no** (0). If not, the current transfer will be interrupted. ## 18.11.2 R\_ATA\_STATUS\_DATA #### ATA Status and Data Register, General Characteristics | ID of register | R_ATA_STATUS_DATA | Size | 32 bits | |------------------|-------------------|---------------|-----------| | Offset | 0x40 | Read/Write | Read only | | Register address | 0xB0000040 | Initial value | Unknown | ## Bit Assignments of R\_ATA\_STATUS\_DATA | Bit(s) | Name | Description | State/Range | |---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------| | 31 - 19 | Reserved | - | 0 | | 18 | busy | This bit indicates if the ATA interface is busy or not. If it is set to <b>yes</b> (1), when writing a command to "R_ATA_CTRL_DATA", the command in progress will be interrupted. When the multi bit in "R_ATA_CTRL_DATA" is set to <b>on</b> (1), this bit will remain set <b>yes</b> (1) until "R_ATA_TRANSFER_CNT" reaches zero. | 0 = no<br>1 = yes | | 17 | tr_rdy | This bit indicates if the transmitter is ready. When it is set (ready), it is possible to write new data to the data field in "R_ATA_CTRL_DATA". The bit is not valid when using the internal DMA. | 0 = busy<br>1 = ready | | 16 | dav | If this bit is set (data), there is new data available in the data field of this register. The bit is cleared when the register is read. It is not valid when using the internal DMA. | 0 = nodata<br>1 = data | | 15 - 0 | data | This field contains data read from the ATA unit if both src_dst is set to register and rw is set to read, in "R_ATA_CTRL_DATA". | | ## 18.11.3 R\_ATA\_CONFIG #### **ATA Configuration Register, General Characteristics** | ID of register | R_ATA_CONFIG | Size | 32 bits | |------------------|--------------|---------------|------------| | Offset | 0x44 | Read/Write | Write only | | Register address | 0xB0000044 | Initial value | Unknown | ## Bit Assignments of R\_ATA\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|------------|----------------------------------------------------------------|-------------------| | 31 - 26 | Reserved | - | 0 | | 25 | enable | This bit enables the ATA controller. | 0 = off<br>1 = on | | 24 - 20 | dma_strobe | This field determines the strobe time for DMA handshaking. | 0 - 31 | | 19 - 15 | dma_hold | This field determines the hold time for DMA handshaking. | 0 - 31 | | 14 - 10 | pio_setup | This field determines the setup time for PIO read and writes. | 0 - 31 | | 9 - 5 | pio_strobe | This field determines the strobe time for PIO read and writes. | 0 - 31 | | 4 - 0 | pio_hold | This field determines the hold time for PIO read and writes. | 0 - 31 | Note: Times are calculated as (r + 1)\*20ns where r is the register value for a specific time. ## 18.11.4 R\_ATA\_TRANSFER\_CNT #### **ATA Transfer Count Register, General Characteristics** | ID of register | R_ATA_TRANSFER_CNT | Size | 32 bits | |------------------|--------------------|---------------|------------| | Offset | 0x48 | Read/Write | Read/Write | | Register address | 0xB0000048 | Initial value | Unknown | ## Bit Assignments of R\_ATA\_TRANSFER\_CNT | Bit(s) | Name | Description | State/Range | |---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 17 | Reserved | - | 0 | | 16 - 0 | count | This counter is decremented each time a 16 bit word (or a byte if dma_size in "R_ATA_CTRL_DATA" is set to byte) is transferred to or from an ATA device. It is primarily used when transferring data using the internal DMA. When the counter reaches zero, DMA transfers are stopped and an EOP is generated. When multi in "R_ATA_CTRL_DATA" is set to on, busy in "R_ATA_STATUS_DATA" will remain set to yes until this counter reaches zero. | 0 - 131071 | # 18.12 SCSI Registers ## 18.12.1 R\_SCSI0\_CTRL #### SCSI-8 p0 and SCSI-W Control Register, General Characteristics | ID of register | R_SCSI0_CTRL | Size | 32 bits | |------------------|--------------|---------------|------------| | Offset | 0x44 | Read/Write | Write only | | Register address | 0xB0000044 | Initial value | Unknown | ## Bit Assignments of R\_SCSI0\_CTRL | Bit(s) | Name | Description | State/Range | |---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 31 | id_type | This bit decides whether software selectable SCSI ID or strapped SCSI ID shall be used. If it is set to <b>hardware</b> (0), external hardware straps must be used to determine SCSI ID. If it is set to <b>software</b> (1), the SCSI host controller ID is selected using software. This mode requires the availability of <b>pb4</b> , so <b>pb4</b> in General Port PB must be configured correctly. | 0 = hardware<br>1 = software | | 30 - 24 | sel_timeout | This field determines the selection timeout interval, expressed in units of 1/300s. The SCSI standard recommends a selection timeout interval of 250ms. | 1 - 127 | | 23 - 16 | synch_per | This field determines the data period used during synchronous data transfers, expressed in units of 10ns. It also determines the setup/hold time for data. The setup/hold time for data out, as well as the symmetry of the signal on $\overline{s0ack}$ are generated as half the data period., e.g. $10 \text{MHz} \rightarrow 100 \text{ns}$ period $\rightarrow 50 \text{ns}$ setup $/50 \text{ ns}$ hold. If the half period is not a multiple of 10ns, the hold time will be longer than the setup time, e.g. $20 \text{ MHz} \rightarrow 50 \text{ns}$ period $\rightarrow 20 \text{ns}$ setup $/30 \text{ns}$ hold. | 2 - 255 | | 15 | rst | This bit asserts the RST signal on the SCSI bus. The RST signal must be asserted for at least 25 $\mu s.$ | 0 = no<br>1 = yes | | 14 | atn | This bit asserts the ATN signal on the SCSI bus. When it is set to <b>yes</b> (1), it tells the target device that the initiator wants to send a message. It is normally only used in manual mode. | 0 = no<br>1 = yes | | 13 | Reserved | - | 0 | | 12 - 9 | my_id | This field determines the internal initiator id. It is used during arbitration and reselection. The highest bit is only used in wide mode. <b>my_id</b> is ignored if <b>id_type</b> is set to <b>hardware</b> (0). | 0 - 15 | | 8 | Reserved | - | 0 | | 7 - 4 | target_id | This field must be set to the id of the target device before starting an arbitration. The highest bit is only used in wide mode. | 0 - 15 | # Bit Assignments of R\_SCSI0\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 3 | fast_20 | This bit turns off the glitch eater circuitry on the soreq pin. This may be needed when in fast-20 mode, in order to tolerate the worst case duty cycle on soreq. Note that it is possible to run both normal and fast-20 mode with both settings. However, in fast-20 mode some pulses on soreq may be lost when this bit is set to no (0), i.e. the glitch eater circuitry is not turned off. | 0 = no<br>1 = yes | | 2 | bus_width | This bit determines the width of the data bus (16/8-bits). It must be set before a data transfer phase is initiated. | 0 = narrow<br>1 = wide | | 1 | synch | This bit selects wether synchronous or asynchronous handshake shall be used in a data transfer phase. It must be set before a data transfer phase is initiated. | 0 = asynch<br>1 = synch | | 0 | enable | This bit enables or disables the SCSI controller. If it is disabled (off) the SCSI controller is reset. | 0 = off<br>1 = on | ## 18.12.2 R\_SCSIO\_CMD\_DATA # SCSI-8 p0 and SCSI-W Command and Data Register, General Characteristics | ID of register | R_SCSI0_CMD_DATA | Size | 32 bits | |------------------|------------------|---------------|------------| | Offset | 0x40 | Read/Write | Write only | | Register address | 0xB0000040 | Initial value | Unknown | ## Bit Assignments of R\_SCSI0\_CMD\_DATA | Bit(s) | Name | Description | State/Range | |---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 27 | Reserved | - | 0 | | 26 | parity_in | This bit enables or disables parity detection on input data. | 0 = on<br>1 = off | | 25 | skip | If this bit is set ( <b>on</b> ), the bus free phase is entered directly when loosing arbitration. | 0 = off<br>1 = on | | 24 | clr_status | This bit clears the status register and interrupt condition. | 0 = nop<br>1 = yes | | 23 - 20 | asynch_setup | This field determines the setup time used for data during asynchronous handshake, in units of 10ns. SCSI-2 requires at least 55ns and SCSI-3 requires 49ns. Skew in external SCSI-buffers must also be taken into account but 60ns should normally be enough, i.e. asynch_setup = 6. | 1 - 15 | | 19 - 16 | command | This field is the command to start the SCSI sequencer. | 0 = full_din_1 1 = full_dout_1 2 = full_stat_1 3 = resel_din 4 = resel_dout 5 = resel_stat 6 = arb_only 8 = full_din_3 9 = full_dout_3 10 = full_stat_3 11 = man_data_in 12 = man_data_out 13 = man_rat | | 15 - 0 | data_out | This field contains output data used during manual transfers. Upper 8 bits are only used during wide transfers. | 0 - 65535 | ## 18.12.3 R\_SCSIO\_DATA #### SCSI-8 p0 and SCSI-W Data Register, General Characteristics | ID of register | R_SCSI0_DATA | Size | 16 bits | |------------------|--------------|---------------|------------| | Offset | 0x40 | Read/Write | Write only | | Register address | 0xB0000040 | Initial value | Unknown | #### Bit Assignments of R\_SCSI0\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_out | This field contains output data used during manual transfers. Upper 8 bits are only used during wide transfers. | 0 - 65535 | **Note:** This 16-bit register is part of the 32-bit register R\_SCSI0\_CMD\_DATA. ## 18.12.4 R\_SCSI0\_CMD #### SCSI-8 p0 and SCSI-W Command Register, General Characteristics | ID of register | R_SCSI0_CMD | Size | 8 bits | |------------------|-------------|---------------|------------| | Offset | 0x42 | Read/Write | Write only | | Register address | 0xB0000042 | Initial value | Unknown | #### Bit Assignments of R\_SCSI0\_CMD | Bit(s) | Name | Description | State/Range | |--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | asynch_setup | This field determines the setup time used for data during asynchronous handshake, in units of 10ns. SCSI-2 requires at least 55ns and SCSI-3 requires 49ns. Skew in external SCSI-buffers must also be taken into account but 60ns should normally be enough, i.e. asynch_setup = 6. | 1 - 15 | | 3 - 0 | command | This field is the command to start the SCSI sequencer. | 0 = full_din_1 1 = full_dout_1 2 = full_stat_1 3 = resel_din 4 = resel_dout 5 = resel_stat 6 = arb_only 8 = full_din_3 9 = full_dout_3 10 = full_stat_3 11 = man_data_in 12 = man_data_out 13 = man_rat | **Note:** This 8-bit register is part of the 32-bit register R\_SCSI0\_CMD\_DATA. ## 18.12.5 R\_SCSIO\_STATUS\_CTRL # SCSI-8 p0 and SCSI-W Status and Control Register, General Characteristics | ID of register | R_SCSI0_STATUS_CTRL | Size | 8 bits | |------------------|---------------------|---------------|------------| | Offset | 0x43 | Read/Write | Write only | | Register address | 0xB0000043 | Initial value | Unknown | ## Bit Assignments of R\_SCSI0\_STATUS\_CTRL | Bit(s) | Name | Description | State/Range | |--------|------------|-------------------------------------------------------------------------------------------|--------------------| | 7 - 3 | Reserved | - | 0 | | 2 | parity_in | This bit enables or disables parity detection on input data. | 0 = on<br>1 = off | | 1 | skip | If this bit is set (on), the bus free phase is entered directly when loosing arbitration. | 0 = off<br>1 = on | | 0 | clr_status | This bit clears the status register and interrupt condition. | 0 = nop<br>1 = yes | **Note:** This 8-bit register is part of the 32-bit register R\_SCSI0\_CMD\_DATA. ## 18.12.6 R\_SCSIO\_STATUS #### SCSI-8 p0 and SCSI-W Status Register, General Characteristics | ID of register | R_SCSI0_STATUS | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0x48 | Read/Write | Read only | | Register address | 0xB0000048 | Initial value | Unknown | ## Bit Assignments of R\_SCSI0\_STATUS | Bit(s) | Name | Description | State/Range | |---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 - 22 | Reserved | - | 0 | | 21 | parity_error | This is an optional bit to detect parity error during manual mode. It is only valid in manual mode when a REQ has been received. Normally the <b>seq_status</b> field is used to detect parity errors. | 0 - 1 | | 20 | bus_reset | This bit is set if a reset condition is detected on the bus. | 0 = no<br>1 = yes | | 19 | Reserved | - | 0 | | 18 - 15 | resel_target | This field contains the SCSI ID of the target that reselected us. | 0 - 15 | | 14 | resel | This bit is set if a target has reselected us. The targets id is in the <b>resel_target</b> field. | 0 = no<br>1 = yes | | 13 - 11 | curr_phase | This field gives the current SCSI phase. It is only valid in manual mode when a REQ has been received. | 0 = ph_undef<br>1 = ph_resel<br>2 = ph_command<br>3 = ph_status<br>4 = ph_data_out<br>5 = ph_data_in<br>6 = ph_msg_out<br>7 = ph_msg_in | #### Bit Assignments of R\_SCSI0\_STATUS (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 - 6 | last_seq_step | This field contains the last step that the sequencer was in, before it was stopped due to some unexpected event. | 0 = st_synch_dout 1 = st_synch_din_perr 2 = st_msg_1 3 = st_answer 4 = st_synch_dout_ack 5 = st_synch_din_ack_perr 6 = st_msg_2 7 = st_sdp_disc 8 = st_arbitrate 9 = st_asynch_din 10 = st_manual_req 11 = st_asynch_dout_end 12 = st_synch_din_ack 13 = st_synch_din 14 = st_iwr_good 15 = st_transfer_done 16 = st_wait_free_iwr_cc 18 = st_manual_din_prot 20 = st_wait_free_cc 21 = st_wait_free_disc 22 = st_msg_3 23 = st_iwr_cc 24 = st_bus_free 25 = st_asynch_dout 27 = st_iwr 28 = st_manual 29 = st_resel_req 30 = st_transf_cmd 31 = st_cc | | 5 | valid_status | If this bit is set, the <b>seq_status</b> field is valid, which also signals that there is a result from the executing of a command. | 0 = no<br>1 = yes | | 4 - 0 | seq_status | This field contains the result after a command has been executed. | 0 = info_seq_complete 1 = info_parity_error 2 = info_unhandled_msg_in 3 = info_unexp_ph_change 4 = info_arb_lost 5 = info_sel_timeout 6 = info_unexp_bf 7 = info_illegal_op 8 = info_rec_recvd 9 = info_reselected 10 = info_unhandled_status 11 = info_bus_reset 12 = info_illegal_bf 13 = info_bus_free | ## 18.12.7 R\_SCSIO\_DATA\_IN #### SCSI-8 p0 and SCSI\_W Data In Register, General Characteristics | ID of register | R_SCSI0_DATA_IN | Size | 16 bits | |------------------|-----------------|---------------|-----------| | Offset | 0x40 | Read/Write | Read only | | Register address | 0xB0000040 | Initial value | Unknown | ## Bit Assignments of R\_SCSI0\_DATA\_IN | Bit(s) | Name | Description | State/Range | |--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_in | This field contains data in during manual transfers. Only valid when the <b>seq_status</b> field in R_SCSI0_STATUS is set to <b>info_rec_recvd</b> and no new command has been started. The upper 8 bits are only valid in wide mode. | 0 - 65535 | ## 18.12.8 R\_SCSI1\_CTRL #### SCSI-8 p1 Control Register, General Characteristics | ID of register | R_SCSI1_CTRL | Size | 32 bits | |------------------|--------------|---------------|------------| | Offset | 0x54 | Read/Write | Write only | | Register address | 0xB0000054 | Initial value | Unknown | ## Bit Assignments of R\_SCSI1\_CTRL | Bit(s) | Name | Description | State/Range | |--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | 31 | id_type | This bit decides whether software selectable SCSI ID or strapped SCSI ID shall be used. If it is set to <b>hardware</b> (0), external hardware straps must be used to determine SCSI ID. If it is set to <b>software</b> (1), the SCSI host controller ID is selected using software. This mode requires the availability of <b>pb7</b> , so <b>pb7</b> in General Port PB must be configured correctly. | 0 = hardware<br>1 = software | | 30-24 | sel_timeout | This field determines the selection timeout interval, expressed in units of 1/300s. The SCSI standard recommends a selection timeout interval of 250ms. | 1 - 127 | | 23-16 | synch_per | This field determines the data period used during synchronous data transfers, expressed in units of 10ns. It also determines the setup/hold time for data. The setup/hold time for data out, as well as the symmetry of the signal on \$\overline{s1ack}\$ are generated as half the data period., e.g. 10MHz -> 100ns period -> 50ns setup / 50 ns hold. If the half period is not a multiple of 10ns, the hold time will be longer than the setup time, e.g. 20 MHz -> 50ns period -> 20ns setup / 30ns hold. | 2 - 255 | | 15 | rst | This bit asserts the RST signal on the SCSI bus. The RST signal must be asserted for at least 25 $\mu s.$ | 0 = no<br>1 = yes | | 14 | atn | This bit asserts the ATN signal on the SCSI bus. When it is set to yes (1), it tells the target device that the initiator wants to send a message. It is normally only used in manual mode. | 0 = no<br>1 = yes | | 13 | Reserved | - | 0 | | 12 - 9 | my_id | This field determines the internal initiator id. It is used during arbitration and reselection. Bit 12 of this register is not used. my_id is ignored if id_type is set to hardware (0). | 0 - 7 | | 8 | Reserved | - | 0 | | 7 - 4 | target_id | This field must be set to the id of the target device before starting an arbitration.Bit 7 of this register is not used. | 0 - 7 | | 3 | fast_20 | This bit turns off the glitch eater circuitry on the streq pin. This may be needed when in fast-20 mode, in order to tolerate the worst case duty cycle on streq. Note that it is possible to run both normal and fast-20 mode with both settings. However, in fast-20 mode some pulses on streq may be lost when this bit is set to no (0), i.e. the glitch eater circuitry is not turned off. | 0 = no<br>1 = yes | | 2 | Reserved | - | 0 | #### Bit Assignments of R\_SCSI1\_CTRL Continued | Bit(s) | Name | Description | State/Range | |--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 1 | synch | This bit selects wether synchronous or asynchronous handshake shall be used in a data transfer phase. It must be set before a data transfer phase is initiated. | 0 = asynch<br>1 = synch | | 0 | enable | This bit enables or disables the SCSI controller. If it is disabled (off) the SCSI controller is reset. | 0 = off<br>1 = on | ### 18.12.9 R\_SCSI1\_CMD\_DATA ### SCSI-8 p1 Command and Data Register, General Characteristics | ID of register | R_SCSI1_CMD_DATA | Size | 32 bits | |------------------|------------------|---------------|------------| | Offset | 0x50 | Read/Write | Write only | | Register address | 0xB0000050 | Initial value | Unknown | ### Bit Assignments of R\_SCSI1\_CMD\_DATA | Bit(s) | Name | Description | State/Range | |----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 1 - 27 | Reserved | - | 0 | | 26 | parity_in | This bit enables or disables parity detection on input data. | 0 = on<br>1 = off | | 25 | skip | If this bit is set ( <b>on</b> ), the bus free phase is entered directly when loosing arbitration. | 0 = off<br>1 = on | | 24 | clr_status | This bit clears the status register and interrupt condition. | 0 = nop<br>1 = yes | | 23 - 20 | asynch_setup | This field determines the setup time used for data during asynchronous handshake, in units of 10ns. SCSI-2 requires at least 55ns and SCSI-3 requires 49ns. Skew in external SCSI-buffers must also be taken into account but 60ns should normally be enough, i.e. asynch_setup = 6. | 1 - 15 | | 19 - 16 | command | This field is the command to start the SCSI sequencer. | 0 = full_din_1 1 = full_dout_1 2 = full_stat_1 3 = resel_din 4 = resel_dout 5 = resel_stat 6 = arb_only 8 = full_din_3 9 = full_dout_3 10 = full_stat_3 11 = man_data_in 12 = man_data_out 13 = man_rat | | 15 - 0 | data_out | This field contains output data used during manual transfers. Bits 15 - 8 of this field are not used by the SCSI interface. | 0 - 65535 | ### 18.12.10 R\_SCSI1\_DATA #### SCSI-8 p1 Data Register, General Characteristics | ID of register | R_SCSI1_DATA | Size | 16 bits | |------------------|--------------|---------------|------------| | Offset | 0x50 | Read/Write | Write only | | Register address | 0xB0000050 | Initial value | Unknown | #### Bit Assignments of R\_SCSI1\_DATA | Bit( | (s) | Name | Description | State/Range | |------|-----|----------|-----------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - | - 0 | data_out | This field contains output data used during manual transfers. Bits 15 - 8 of this field are not used by the SCSI interface. | 0 - 65535 | **Note:** This 16-bit register is part of the 32-bit register R\_SCSI1\_CMD\_DATA. ### 18.12.11 R\_SCSI1\_CMD #### SCSI-8 p1 Command Register, General Characteristics | ID of register | R_SCSI1_CMD | Size | 8 bits | |------------------|-------------|---------------|------------| | Offset | 0x52 | Read/Write | Write only | | Register address | 0xB0000052 | Initial value | Unknown | ### Bit Assignments of R\_SCSI1\_CMD | Bit(s) | Name | Description | State/Range | |--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | asynch_setup | This field determines the setup time used for data during asynchronous handshake, in units of 10ns. SCSI-2 requires at least 55ns and SCSI-3 requires 49ns. Skew in external SCSI-buffers must also be taken into account but 60ns should normally be enough, i.e. asynch_setup = 6. | 1 - 15 | | 3 - 0 | command | This field is the command to start the SCSI sequencer. | 0 = full_din_1 1 = full_dout_1 2 = full_stat_1 3 = resel_din 4 = resel_dout 5 = resel_stat 6 = arb_only 8 = full_din_3 9 = full_dout_3 10 = full_stat_3 11 = man_data_in 12 = man_data_out 13 = man_rat | **Note:** This 8-bit register is part of the 32-bit register R\_SCSI1\_CMD\_DATA. ### 18.12.12 R\_SCSI1\_STATUS\_CTRL #### SCSI-8 p1 Status and Control Register, General Characteristics | ID of register | R_SCSI1_STATUS_CTRL | Size | 8 bits | |------------------|---------------------|---------------|------------| | Offset | 0x53 | Read/Write | Write only | | Register address | 0xB0000053 | Initial value | Unknown | ### Bit Assignments of R\_SCSI1\_STATUS\_CTRL | Bit(s) | Name | Description | State/Range | |--------|------------|----------------------------------------------------------------------------------------------------|--------------------| | 7 - 3 | Reserved | - | 0 | | 2 | parity_in | This bit enables or disables parity detection on input data. | 0 = on<br>1 = off | | 1 | skip | If this bit is set ( <b>on</b> ), the bus free phase is entered directly when loosing arbitration. | 0 = off<br>1 = on | | 0 | clr_status | This bit clears the status register and interrupt condition. | 0 = nop<br>1 = yes | **Note:** This 8-bit register is part of the 32-bit register R\_SCSI1\_CMD\_DATA. ### 18.12.13 R\_SCSI1\_STATUS #### SCSI-8 p1 Status Register, General Characteristics | ID of register | R_SCSI1_STATUS | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0x58 | Read/Write | Read only | | Register address | 0xB0000058 | Initial value | Unknown | ### **Bit Assignments of R\_SCSI1\_STATUS** | Bit(s) | Name | Description | State/Range | |---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 - 22 | Reserved | - | 0 | | 21 | parity_error | This is an optional bit to detect parity error during manual mode. It is only valid in manual mode when a REQ has been received. Normally the <b>seq_status</b> field is used to detect parity errors. | 0 - 1 | | 20 | bus_reset | This bit is set if a reset condition is detected on the bus. | 0 = no<br>1 = yes | | 19 | Reserved | - | 0 | | 18 - 15 | resel_target | This field contains the SCSI ID of the target that reselected us. | 0 - 15 | | 14 | resel | This bit is set if a target has reselected us. The targets id is in the <b>resel_target</b> field. | 0 = no<br>1 = yes | | 13 - 11 | curr_phase | This field gives the current SCSI phase. It is only valid in manual mode when a REQ has been received. | 0 = ph_undef<br>1 = ph_resel<br>2 = ph_command<br>3 = ph_status<br>4 = ph_data_out<br>5 = ph_data_in<br>6 = ph_msg_out<br>7 = ph_msg_in | Bit Assignments of R\_SCSI1\_STATUS (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 - 6 | last_seq_step | This field contains the last step that the sequencer was in, before it was stopped due to some unexpected event. | 0 = st_synch_dout 1 = st_synch_din_perr 2 = st_msg_1 3 = st_answer 4 = st_synch_dout_ack 5 = st_synch_din_ack_perr 6 = st_msg_2 7 = st_sdp_disc 8 = st_arbitrate 9 = st_asynch_din 10 = st_manual_req 11 = st_asynch_dout_end 12 = st_synch_din_ack 13 = st_synch_din 14 = st_iwr_good 15 = st_transfer_done 16 = st_wait_free_sdp_disc 17 = st_wait_free_iwr_cc 18 = st_manual_din_prot 20 = st_wait_free_cc 21 = st_wait_free_disc 22 = st_msg_3 23 = st_iwr_cc 24 = st_bus_free 25 = st_asynch_dout 27 = st_iwr 28 = st_manual 29 = st_resel_req 30 = st_transf_cmd 31 = st_cc | | 5 | valid_status | If this bit is set, the <b>seq_status</b> field is valid, which also signals that there is a result from the executing of a command. | 0 = no<br>1 = yes | | 4 - 0 | seq_status | This field contains the result after a command has been executed. | 0 = info_seq_complete 1 = info_parity_error 2 = info_unhandled_msg_in 3 = info_unexp_ph_change 4 = info_arb_lost 5 = info_sel_timeout 6 = info_unexp_bf 7 = info_illegal_op 8 = info_rec_recvd 9 = info_reselected 10 = info_unhandled_status 11 = info_bus_reset 12 = info_illegal_bf 13 = info_bus_free | ### 18.12.14 R\_SCSI1\_DATA\_IN ### SCSI-8 p1 Data In Register, General Characteristics | ID of register | R_SCSI1_DATA_IN | Size | 16 bits | |------------------|-----------------|---------------|-----------| | Offset | 0x50 | Read/Write | Read only | | Register address | 0xB0000050 | Initial value | Unknown | # Bit Assignments of R\_SCSI1\_DATA\_IN | Bit(s) | Name | Description | State/Range | |--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_in | This field contains data in during manual transfers. Only valid when the <b>seq_status</b> field in R_SCSI1_STATUS is set to <b>info_rec_recvd</b> and no new command has been started. Only bits 7 -0 of this field are valid; bits 15 - 8 are ignored. | 0 - 65535 | # 18.13 Interrupt Mask and Status Registers ### 18.13.1 R\_IRQ\_MASKO\_RD #### IRQ Mask 0 Read Register, General Characteristics | ID of register | R_IRQ_MASK0_RD | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xC0 | Read/Write | Read only | | Register address | 0xB00000C0 | Initial value | Unknown | #### Bit Assignments of R\_IRQ\_MASK0\_RD | Bit(s) | Name | Description | State/Range | |--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 | nmi_pin | The interrupt from the external $\overline{\text{nmi}}$ pin is read in this field. It is cleared in the external unit connected to the pin. The interrupt has the vector number 0x21. | 0 = inactive<br>1 = active | | 30 | watchdog_nmi | The interrupt from the watchdog timer is read in this field. It is cleared by stopping or restarting the watchdog timer. The interrupt has the vector number 0x21. | 0 = inactive<br>1 = active | | 29 | sqe_test_error | This field contains the individually masked interrupt bit that is set when the <b>sqe_test_error</b> counter attains the value 128. It is cleared by reading the <b>sqe_test_error</b> field of register "R_PHY_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 28 | carrier_loss | This field contains the individually masked interrupt bit that is set when the <b>carrier_loss</b> counter attains the value 128. It is cleared by reading the <b>carrier_loss</b> field of register "R_PHY_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 27 | deferred | This field contains the individually masked interrupt bit that is set when the <b>deferred</b> counter attains the value 128. It is cleared by reading the <b>deferred</b> field of register "R_TR_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 26 | late_col | This field contains the individually masked interrupt bit that is set when the <code>late_col</code> counter attains the value 128. It is cleared by reading the <code>late_col</code> field of register "R_TR_COUNTERS". The interrupt has the vector number 0x27. | 1 = active<br>0 = inactive | | 25 | multiple_col | This field contains the individually masked interrupt bit that is set when the <b>multiple_col</b> counter attains the value 128. It is cleared by reading the <b>multiple_col</b> field of register "R_TR_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 24 | single_col | This field contains the individually masked interrupt bit that is set when the <b>single_col</b> counter attains the value 128. It is cleared by reading the <b>single_col</b> field of register "R_TR_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 23 | congestion | This field contains the individually masked interrupt bit that is set when the <b>congestion</b> counter attains the value 128. It is cleared by reading the <b>congestion</b> field of register "R_REC_COUNTERS". The interrupt has the vector number 0x27. (note 1) | 0 = inactive<br>1 = active | ### Bit Assignments of R\_IRQ\_MASK0\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 22 | oversize | This field contains the individually masked interrupt bit that is set when the <b>oversize</b> counter attains the value 128. It is cleared by reading the <b>oversize</b> field of register "R_REC_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 21 | alignment_error | This field contains the individually masked interrupt bit that is set when the <b>alignment_error</b> counter attains the value 128. It is cleared by reading the <b>alignment_error</b> field of register "R_REC_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 20 | crc_error | This field contains the individually masked interrupt bit that is set when the <b>crc_error</b> counter attains the value 128. It is cleared by reading the <b>crc_error</b> field of register "R_REC_COUNTERS". The interrupt has the vector number 0x27. | 0 = inactive<br>1 = active | | 19 | overrun | This field contains the individually masked interrupt bit that is set when the network receiver experiences a FIFO overrun condition (congestion error). It is cleared by reading the <b>congestion</b> field of register "R_REC_COUNTERS". The interrupt has the vector number 0x26. (note 1) | 0 = inactive<br>1 = active | | 18 | underrun | This field contains the individually masked interrupt bit that is set when the network transmitter experiences a FIFO underrun condition. It is cleared by setting the clr_error bit in register "R_NETWORK_TR_CTRL". The interrupt has the vector number 0x26. | 0 = inactive<br>1 = active | | 17 | excessive_col | This field contains the individually masked interrupt bit that is set when the network transmitter experiences collisions for 16 consecutive transmission attempts. It is set after the first collision if the no_retry field in network interface register "R_NETWORK_TR_CTRL" is set, and when the transmitter stops after the cancel field of "R_NETWORK_TR_CTRL" has been set. The interrupt is cleared by setting the clr_error bit in the "R_NETWORK_TR_CTRL" register. The interrupt has the vector number 0x26. | 0 = inactive<br>1 = active | | 16 | mdio | This field contains the individually masked interrupt bit from the <b>mdio</b> pin. It is generated when the pin is low and should be masked during normal data transfers over the interface. It is cleared in the external unit that is driving the pin. The interrupt has the vector number $0x26$ . | 0 = inactive<br>1 = active | | 15 | ata_drq3 | This field contains the individually masked interrupt bit that is set when a unit on ATA bus 3 requests a DMA transfer. It is cleared at the end of the DMA transfer. The interrupt has the vector number 0x24. | 0 = inactive<br>1 = active | | 14 | ata_drq2 | This field contains the individually masked interrupt bit that is set when a unit on ATA bus 2 requests a DMA transfer. It is cleared at the end of the DMA transfer. The interrupt has the vector number 0x24. | 0 = inactive<br>1 = active | Bit Assignments of R\_IRQ\_MASK0\_RD (continued) Bit Assignments of R\_IRQ\_MASK0\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 13 | ata_drq1 | This field contains the individually masked interrupt bit that is set when a unit on ATA bus 1 requests a DMA transfer. It is cleared at the end of the DMA transfer. The interrupt has the vector number 0x24. | 0 = inactive<br>1 = active | | 12 | ata_drq0 | This field contains the individually masked interrupt bit that is set when a unit on ATA bus 0 requests a DMA transfer. It is cleared at the end of the DMA transfer. The interrupt has the vector number 0x24. | 0 = inactive<br>1 = active | | 11 | par0_ecp_cmd | When Parallel Port p0 is in ECP mode, this field contains the individually masked interrupt bit that is set when an ECP command is received in at the port. It is cleared by reading the <b>ecp_cmd</b> field in the "R_PARO_STATUS_DATA" register. | 0 = inactive<br>1 = active | | | ata_irq3 | When ATA is in use, this field contains the individually masked interrupt bit that is set when a unit on ATA bus 3 requests an interrupt. It is cleared in the external unit on ATA bus 3. Both of these interrupts have the vector number 0x24. | | | | | (note 2) | | | 10 | par0_peri | When Parallel Port p0 is in use, this field contains the individually masked interrupt bit that is set by the peripheral connected to the port. It is cleared by acknowledging the <b>peri_int</b> bit in register "R_PARO_CTRL_DATA". | 0 = inactive<br>1 = active | | | ata_irq2 | When ATA is in use, this field contains the individually masked interrupt bit that is set when a unit on ATA bus 2 requests an interrupt. It is cleared in the external unit on ATA bus 2. | | | | | These two interrupts both have the vector number 0x24. (note 2) | | | 9 | par0_data | When Parallel Port p0 is in use, this field contains the individually masked interrupt bit that is set when input data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. The interrupt is cleared by reading the data field of register "R_PARO_STATUS_DATA". | 0 = inactive<br>1 = active | | | ata_irq1 | When ATA is in use, this field contains the individually masked interrupt bit that is set when a unit on ATA bus 1 requests an interrupt. It is cleared in the external unit on ATA bus 1. | | | | | These two interrupts both have the vector number $0x24$ . (note 2) | | Bit Assignments of R\_IRQ\_MASK0\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 8 | par0_ready | When Parallel Port par0 is in use, this field contains the individually masked interrupt bit that is set when the port is ready to get new data for transmission. The interrupt is cleared by writing new data to the <code>data</code> field of register "R_PAR0_CTRL_DATA" register. This bit should be masked off when the DMA is used for data transfers. | 0 = inactive<br>1 = active | | | ata_irq0 | When ATA is in use, this field contains the individually masked interrupt bit that is set when a unit on ATA bus 0 requests an interrupt. It is cleared in the external unit on ATA bus 0. | | | | mio | This interrupt is detected on the $\overline{\text{intio}}$ pin of the shared RAM interface. It is cleared by setting the i bit of the R_SHARED_RAM_CONFIG register. | | | | scsi0 | This interrupt is generated when SCSI controller 0 has finished a command or stopped due to some unexpected event. the interrupt cause can be read in the fields last_seq_step and seq_status in "R_SCSI0_STATUS". It is cleared by setting the clr_status field in "R_SCSI0_CMD_DATA" to yes. These four interrupts all have the vector number 0x24. | | | | | (note 2) | | | 7 | ata_dmaend | This field contains the individually masked interrupt bit that is set when the selected ATA unit releases its DMA request. It should be masked off except when an ATA DMA transfer has been started. The interrupt has the vector number 0x24. | 0 = inactive<br>1 = active | | 6 | Reserved | - | 0 | | 5 | irq_ext_vector_nr | This field contains the individually masked interrupt bit from the external interrupt pin ( $\overline{irq}$ ), when configured for an external vector number. This interrupt is cleared in the external unit connected to the $\overline{irq}$ pin. | 0 = inactive<br>1 = active | | 4 | irq_int_vector_nr | This field contains the individually masked interrupt bit from the external interrupt pin ( $irq$ ), when configured for the internally-generated vector number 0x2A. This interrupt is cleared in the external unit connected to the $irq$ pin. | 0 = inactive<br>1 = active | | 3 | ext_dma1 | This field contains the individually masked interrupt bit that is set when external DMA channel 1 is stopped. The interrupt should be masked, except when waiting for the completion of a transfer on external DMA channel 1. The interrupt has the internally-generated vector number 0x2D. | 0 = inactive<br>1 = active | | 2 | ext_dma0 | This field contains the individually masked interrupt bit that is set when external DMA channel 0 is stopped. The interrupt should be masked, except when waiting for the completion of a transfer on external DMA channel 0. The interrupt has the internally-generated vector number 0x2C. | 0 = inactive<br>1 = active | | Bit(s) | Name | Description | State/Range | |--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 1 | timer1 | This field contains the individually masked interrupt bit that is set whenever timer1 reaches its terminal count. The interrupt is cleared by setting the i1 bit in register R_TIMER_CTRL. The interrupt has the internally-generated vector number 0x23. | 0 = inactive<br>1 = active | | 0 | timer0 | This field contains the individually masked interrupt bit that is set whenever timer0 reaches its terminal count. The interrupt is cleared by setting the <b>i0</b> bit in register R_TIMER_CTRL. The interrupt has the internally-generated vector number 0x22. | 0 = inactive<br>1 = active | Note 1: Two similar interrupts are available - overrun and congestion, but usually only one should be enabled. The overrun interrupt should be used if software intervention is necessary when an overrun error occurs. The congestion interrupt should be used if an error count is the only action needed. Reading the **congestion** field of R\_REC\_COUNTERS will clear both the **congestion** field (bit 23) and the **overrun** field (bit 19) Note 2: Bits 11 to 8 are multiplexed between SCSI-8 Port p0, Parallel Port p0, ATA and the shared RAM interface. Register R\_GEN\_CONFIG is used to select the peripheral device in use. ### 18.13.2 R\_IRQ\_MASKO\_CLR #### IRQ Mask 0 Clear Register, General Characteristics | ID of register | R_IRQ_MASK0_CLR | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xC0 | Read/Write | Write only | | Register address | 0xB00000C0 | Initial value | Not applicable | ### Bit Assignments of R\_IRQ\_MASK0\_CLR | Bit(s) | Name | Description | State/Range | |--------|-----------------|----------------------------------------------------------------------------|--------------------| | 31 | Reserved | - | 0 | | 30 | Reserved | - | 0 | | 29 | sqe_test_error | This field is used to clear the <b>sqe_test_error</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 28 | carrier_loss | This field is used to clear the <b>carrier_loss</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 27 | deferred | This field is used to clear the <b>deferred</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 26 | late_col | This field is used to clear the late_col interrupt mask bit. | 0 = nop<br>1 = clr | | 25 | multiple_col | This field is used to clear the <b>multiple_col</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 24 | single_col | This field is used to clear the <b>single_col</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 23 | congestion | This field is used to clear the <b>congestion</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 22 | oversize | This field is used to clear the <b>oversize</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 21 | alignment_error | This field is used to clear the <b>alignment_error</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 20 | crc_error | This field is used to clear the <b>crc_error</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 19 | overrun | This field is used to clear the <b>overrun</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 18 | underrun | This field is used to clear the <b>underrun</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 17 | excessive_col | This field is used to clear the <b>excessive_col</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 16 | mdio | This field is used to clear the <b>mdio</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 15 | ata_drq3 | This field is used to clear the ata_drq3 interrupt mask bit. | 0 = nop<br>1 = clr | | 14 | ata_drq2 | This field is used to clear the ata_drq2 interrupt mask bit. | 0 = nop<br>1 = clr | | 13 | ata_drq1 | This field is used to clear the ata_drq1 interrupt mask bit. | 0 = nop<br>1 = clr | | 12 | ata_drq0 | This field is used to clear the ata_drq0 interrupt mask bit. | 0 = nop<br>1 = clr | ### Bit Assignments of R\_IRQ\_MASK0\_CLR (continued) | Bit(s) | Name | Description | State/Range | |--------|-------------------|---------------------------------------------------------------------------------------------------------------|--------------------| | 11 | par0_ecp_cmd | When Parallel Port p0 is in ECP mode, this field is used to clear the <b>par0_ecp_cmd</b> interrupt mask bit. | 0 = nop<br>1 = clr | | | ata_irq3 | When ATA is in use, this field is used to clear the <b>ata_irq3</b> interrupt mask bit. | | | 10 | par0_peri | When Parallel Port p0 is in use, this field is used to clear the <b>par0_peri</b> interrupt mask bit. | 0 = nop<br>1 = clr | | | ata_irq2 | When ATA is in use, this field is used to clear the <b>ata_irq2</b> interrupt mask bit. | | | 9 | par0_data | When Parallel Port p0 is in use, this field is used to clear the <b>par0_data</b> interrupt mask bit. | 0 = nop<br>1 = clr | | | ata_irq1 | When ATA is in use, this field is used to clear the <b>ata_irq1</b> interrupt mask bit. | | | 8 | par0_ready | When Parallel Port p0 is in use, this field is used to clear the par0_ready interrupt mask bit. | 0 = nop<br>1 = clr | | | ata_irq0 | When ATA is in use, this field is used to clear the <b>ata_irq0</b> interrupt mask bit. | | | | mio | When Shared RAM interface is in use, this field is used to clear the ${\bf mio}$ interrupt mask bit. | | | | scsi0 | When SCSI Port 0 is in use, this field is used to clear the <code>scsi0</code> interrupt mask bit. | | | 7 | ata_dmaend | This field is used to clear the <b>ata_dmaend</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 6 | Reserved | - | 0 | | 5 | irq_ext_vector_nr | This field is used to clear the <b>irq_ext_vector_nr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 4 | irq_int_vector_nr | This field is used to clear the <b>irq_int_vector_nr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 3 | ext_dma1 | This field is used to clear the <b>ext_dma1</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 2 | ext_dma0 | This field is used to clear the ${\it ext\_dma0}$ interrupt mask bit. | 0 = nop<br>1 = clr | | 1 | timer1 | This field is used to clear the <b>timer1</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 0 | timer0 | This field is used to clear the <b>timer2</b> interrupt mask bit. | 0 = nop<br>1 = clr | **Note:** In this register, only bits written with 1 are cleared. Bits written with 0 are not affected. ### 18.13.3 R\_IRQ\_READ0 #### IRQ Read 0 Register, General Characteristics | ID of register | R_IRQ_READ0 | Size | 32 bits | |------------------|-------------|---------------|-----------| | Offset | 0xC4 | Read/Write | Read only | | Register address | 0xB00000C4 | Initial value | Unknown | # Bit Assignments of R\_IRQ\_READ0 | Bit(s) | Name | Description | State/Range | |--------|-----------------|------------------------------------------------------------------------------------------------------------|----------------------------| | 31 | nmi_pin | This field is used to read the status of the interrupt at the external $\overline{nmi}$ pin. | 0 = inactive<br>1 = active | | 30 | watchdog_nmi | This field is used to read the status of the interrupt from the watchdog timer. | 0 = inactive<br>1 = active | | 29 | sqe_test_error | This field is used to read the status of the <b>sqe_test_error</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 28 | carrier_loss | This field is used to read the status of the carrier_loss interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 27 | deferred | This field is used to read the status of the <b>deferred</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 26 | late_col | This field is used to read the status of the late_col interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 25 | multiple_col | This field is used to read the status of the <b>multiple_col</b> interrupt prior to the individual mask. | 1 = active<br>0 = inactive | | 24 | single_col | This field is used to read the status of the single_col interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 23 | congestion | This field is used to read the status of the <b>congestion</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 22 | oversize | This field is used to read the status of the <b>oversize</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 21 | alignment_error | This field is used to read the status of the alignment_error interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 20 | crc_error | This field is used to read the status of the crc_error interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 19 | overrun | This field is used to read the status of the <b>overrun</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 18 | underrun | This field is used to read the status of the <b>underrun</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 17 | excessive_col | This field is used to read the status of the <b>excessive_col</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 16 | mdio | This field is used to read the status of the <b>mdio</b> interrupt prior to the individual mask. | 1 = active<br>0 = inactive | | 15 | ata_drq3 | This field is used to read the status of the ata_drq3 interrupt prior to the individual mask. | 1 = active<br>0 = inactive | | 14 | ata_drq2 | This field is used to read the status of the ata_drq2 interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 13 | ata_drq1 | This field is used to read the status of the ata_drq1 interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 12 | ata_drq0 | This field is used to read the status of the ata_drq0 interrupt prior to the individual mask. | 0 = inactive<br>1 = active | # Bit Assignments of R\_IRQ\_READ0 (continued) | Bit(s) | Name | Description | State/Range | |--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 11 | par0_ecp_cmd | When Parallel Port p0 is in ECP mode, this field is used to read the status of the <b>par0_ecp_cmd</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | | ata_irq3 | When ATA is in use, this field is used to read the status of the ata_irq3 interrupt prior to the individual mask. | | | 10 | par0_peri | When Parallel Port p0 is in use, this field is used to read the status of the <b>par0_peri</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | | ata_irq2 | When ATA is in use, this field is used to read the status of the ata_irq2 interrupt prior to the individual mask. | | | 9 | par0_data | When Parallel Port p0 is in use, this field is used to read the status of the <b>par0_data</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | | ata_irq1 | When ATA is in use, this field is used to read the status of the ata_irq1 interrupt prior to the individual mask. | | | 8 | par0_ready | When Parallel Port p0 is in use, this field is used to read the status of the <b>par0_ready</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | | ata_irq0 | When ATA is in use, this field is used to read the status of the <b>ata_irq0</b> interrupt prior to the individual mask. | | | | mio | This field is used to read the status of the <b>mio</b> interrupt prior to the individual mask. | | | | scsi0 | This field is used to read the status of the scsi0 interrupt prior to the individual mask. | | | 7 | ata_dmaend | This field is used to read the status of the <b>ata_dmaend</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 6 | Reserved | - | 0 | | 5 | irq_ext_vector_nr | This field is used to read the status of the <pre>irq_ext_vector_nr</pre> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 4 | irq_int_vector_nr | This field is used to read the status of the <pre>irq_int_vector_nr</pre> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 3 | ext_dma1 | This field is used to read the status of the <b>ext_dma1</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 2 | ext_dma0 | This field is used to read the status of the <b>ext_dma0</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 1 | timer1 | This field is used to read the status of the <b>timer1</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 0 | timer0 | This field is used to read the status of the <b>timer0</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | ### 18.13.4 R\_IRQ\_MASKO\_SET #### IRQ Mask 0 Set Register, General Characteristics | ID of register | R_IRQ_MASK0_SET | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xC4 | Read/Write | Write only | | Register address | 0xB00000C4 | Initial value | Not applicable | # Bit Assignments of R\_IRQ\_MASK0\_SET | Bit(s) | Name | Description | State/Range | |--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 31 | Reserved | - | 0 | | 30 | Reserved | - | 0 | | 29 | sqe_test_error | This field is used to set the individual mask bit for the <b>sqe_test_error</b> interrupt. The interrupt has the internally-generated vector number 0x27. | 0 = nop<br>1 = set | | 28 | carrier_loss | This field is used to set the individual mask bit for the <b>carrier_loss</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 27 | deferred | This field is used to set the individual mask bit for the <b>deferred</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 26 | late_col | This field is used to set the individual mask bit for the <b>late_col</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 25 | multiple_col | This field is used to set the individual mask bit for the <b>multiple_col</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 24 | single_col | This field is used to set the individual mask bit for the <b>single_col</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 23 | congestion | This field is used to set the individual mask bit for the <b>congestion</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 22 | oversize | This field is used to set the individual mask bit for the <b>oversize</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 21 | alignment_error | This field is used to set the individual mask bit for the <b>alignment_error</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 20 | crc_error | This field is used to set the individual mask bit for the <b>crc_error</b> interrupt. The interrupt has the vector number 0x27. | 0 = nop<br>1 = set | | 19 | overrun | This field is used to set the individual mask bit for the <b>overrun</b> interrupt. The interrupt has the vector number 0x26. | 0 = nop<br>1 = set | | 18 | underrun | This field is used to set the individual mask bit for the <b>underrun</b> interrupt. The interrupt has the vector number 0x26. | 0 = nop<br>1 = set | Bit Assignments of R\_IRQ\_MASK0\_SET (continued) Bit Assignments of R\_IRQ\_MASK0\_SET (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 17 | excessive_col | This field is used to set the individual mask bit for the <b>excessive_col</b> interrupt. The interrupt has the vector number 0x26. | 0 = nop<br>1 = set | | 16 | mdio | This field is used to set the individual mask bit for the <b>mdio</b> interrupt. The interrupt has the vector number 0x26. | 0 = nop<br>1 = set | | 15 | ata_drq3 | This field is used to set the individual mask bit for the ata_drq3 interrupt. The interrupt has the vector number 0x24. | 0 = nop<br>1 = set | | 14 | ata_drq2 | This field is used to set the individual mask bit for the ata_drq2 interrupt. The interrupt has the vector number 0x24. | 0 = nop<br>1 = set | | 13 | ata_drq1 | This field is used to set the individual mask bit for the ata_drq1 interrupt. The interrupt has the vector number 0x24. | 0 = nop<br>1 = set | | 12 | ata_drq0 | This field is used to set the individual mask bit for the ata_drq0 interrupt. The interrupt has the vector number 0x24. | 0 = nop<br>1 = set | | 11 | par0_ecp_cmd ata_irq3 | This field is used to set the individual mask bit for the par0_ecp_cmd interrupt. This field is used to set the individual mask bit for the ata_irq3 interrupt. Both interrupts have the vector number 0x24. | 0 = nop<br>1 = set | | 10 | par0_peri<br>ata_irq2 | This field is used to set the individual mask bit for the par0_peri interrupt. This field is used to set the individual mask bit for the ata_irq2 interrupt. Both interrupts have the vector number 0x24. | 0 = nop<br>1 = set | | 9 | par0_data ata_irq1 | This field is used to set the individual mask bit for the <pre>par0_data</pre> interrupt. This field is used to set the individual mask bit for the | 0 = nop<br>1 = set | | | | ata_irq1 interrupt. Both interrupts have the vector number 0x24. | | | Bit(s) | Name | Description | State/Range | |--------|------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------| | 8 | par0_ready | This field is used to set the individual mask bit for the <b>par0_ready</b> interrupt. | 0 = nop<br>1 = set | | | ata_irq0 | This field is used to set the individual mask bit for the ${\bf ata\_irq0} \ interrupt.$ | | | | mio | This field is used to set the individual mask bit for the <b>mio</b> interrupt. | | | | scsi0 | This field is used to set the individual mask bit for the $\mathbf{scsi0}$ interrupt. | | | | | These four interrupts all have the vector number 0x24. | | | 7 | ata_dmaend | This field is used to set the individual mask bit for the <b>ata_dmaend</b> interrupt. The interrupt has the vector number 0x24. | 0 = nop<br>1 = set | | 6 | Reserved | - | 0 | | 5 | irq_ext_vector_nr | This field is used to set the individual mask bit for the <pre>irq_ext_vector_nr</pre> interrupt. This interrupt has an external vector number. (note 1) | 0 = nop<br>1 = set | |---|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 4 | irq_int_vector_nr | This field is used to set the individual mask bit for the <pre>irq_int_vector_nr</pre> interrupt. The interrupt has the internally-generated vector number 0x24. (note 1) | 0 = nop<br>1 = set | | 3 | ext_dma1 | This field is used to set the individual mask bit for the <b>ext_dma1</b> interrupt. The interrupt has the vector number 0x2D. | 0 = nop<br>1 = set | | 2 | ext_dma0 | This field is used to set the individual mask bit for the <b>ext_dma0</b> interrupt. The interrupt has the vector number 0x2C. | 0 = nop<br>1 = set | | 1 | timer1 | This field is used to set the individual mask bit for the <b>timer1</b> interrupt. The interrupt has the vector number 0x23. | 0 = nop<br>1 = set | | 0 | timer0 | This field is used to set the individual mask bit for the <b>timer0</b> interrupt. The interrupt has the vector number 0x22. | 0 = nop<br>1 = set | **Note 1:** External interrupt with the external vector is enabled if the mask for **irq\_ext\_vector\_nr** is set and the mask for **irq\_int\_vector\_nr** is cleared. **Note 2:** In this register, only bits written with 1 are set. Bits written with 0 are not affected. ### 18.13.5 R\_IRQ\_MASK1\_RD #### IRQ Mask 1 Read Register, General Characteristics | ID of register | R_IRQ_MASK1_RD | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xC8 | Read/Write | Read only | | Register address | 0xB00000C8 | Initial value | Unknown | ### Bit Assignments of R\_IRQ\_MASK1\_RD | Bit(s) | Name | Description | State/Range | |--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 | sw_int7 | This field contains the interrupt bit that is set when field <b>sw_int7</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 30 | sw_int6 | This field contains the interrupt bit that is set when field <b>sw_int6</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 29 | sw_int5 | This field contains the interrupt bit that is set when field <b>sw_int5</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 28 | sw_int4 | This field contains the interrupt bit that is set when field <b>sw_int4</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 27 | sw_int3 | This field contains the interrupt bit that is set when field <b>sw_int3</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 26 | sw_int2 | This field contains the interrupt bit that is set when field <b>sw_int2</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 25 | sw_int1 | This field contains the interrupt bit that is set when field <b>sw_int1</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 24 | sw_int0 | This field contains the interrupt bit that is set when field <b>sw_int0</b> in register R_IRQ_MASK1_SET is set. The interrupt has the vector number 0x29. | 0 = inactive<br>1 = active | | 23-20 | Reserved | - | 0 | | 19 | par1_ecp_cmd | This field contains the individually masked interrupt bit that is set when Parallel Port p1 receives a command in ECP mode. The interrupt is cleared by reading the ecp_cmd field in register R_PAR1_STATUS_DATA. The interrupt has the vector number 0x25. | 0 = inactive<br>1 = active | | 18 | par1_peri | This field contains the individually masked interrupt bit for the <b>par1_peri</b> interrupt that is set by the peripheral connected to Parallel Port p1. The interrupt is cleared by acknowledging the <b>peri_int</b> bit in register R_PAR1_CTRL_DATA. The interrupt has the vector number 0x25. | 0 = inactive<br>1 = active | | 17 | par1_data | When Parallel Port p1 is in use, this field contains the individually masked interrupt bit that is set when input data is available on the port. When DMA is used for the data transfer, this interrupt indicates that at least one byte was received since the interrupt was last cleared. The interrupt is cleared by reading the <b>data</b> field of register R_PAR1_STATUS_DATA. The interrupt has the vector number 0x25. | 0 = inactive<br>1 = active | ### Bit Assignments of R\_IRQ\_MASK1\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 16 | par1_ready | When Parallel Port p1 is in use, this field contains the individually masked interrupt bit that is set when the port is ready to get new data for transmission. The interrupt is cleared by writing new data to the <b>data</b> field of register R_PAR1_CTRL_DATA. This bit should be masked off when the DMA is used for data transfers. The interrupt has the vector number 0x25. | 0 = inactive<br>1 = active | | | scsi1 | This interrupt is generated when SCSI controller 1 has finished a command or stopped due to some unexpected event. the interrupt cause can be read in the fields <code>last_seq_step</code> and <code>seq_status</code> in R_SCSI1_STATUS. It is cleared by setting the <code>clr_status</code> field in R_SCSI1_CMD_DATA to <code>yes</code> . (note 1) | | | 15 | ser3_ready | This field contains the individually masked interrupt bit that is set when Asynchronous or Synchronous Serial Port p3 is ready to get new data for transmission. The interrupt is cleared by writing new data to the <code>data_out</code> field of register <code>R_SERIAL3_CTRL</code> or to the <code>R_SERIAL3_TR_DATA</code> register. This bit should be masked off when the DMA is used for data transfers. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 14 | ser3_data | This field contains the individually masked interrupt bit that is set when input data is available at Asynchronous or Synchronous Serial Port p3. The interrupt is cleared by reading the data_in field of register R_SERIAL3_READ or the R_SERIAL3_REC_DATA register. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 13 | ser2_ready | This field contains the individually masked interrupt bit that is set when Asynchronous Serial Port p2 is ready to get new data for transmission. The interrupt is cleared by writing new data to the <b>data_out</b> field of register R_SERIAL2_CTRL or the R_SERIAL2_TR_DATA register. This bit should be masked off when the DMA is used for data transfers. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 12 | ser2_data | This field contains the individually masked interrupt bit that is set when input data is available at Asynchronous Serial Port p2. The interrupt is cleared by reading the data_in field of register R_SERIAL2_READ or the R_SERIAL2_REC_DATA register. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 11 | ser1_ready | This field contains the individually masked interrupt bit that is set when Asynchronous or Synchronous Serial Port p1 is ready to get new data for transmission. The interrupt is cleared by writing new data to the <code>data_out</code> field of register <code>R_SERIAL1_CTRL</code> or to the <code>R_SERIAL1_TR_DATA</code> register. This bit should be masked off when the DMA is used for data transfers. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | Bit Assignments of R\_IRQ\_MASK1\_RD (continued) Bit Assignments of R\_IRQ\_MASK1\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 10 | ser1_data | This field contains the individually masked interrupt bit that is set when input data is available at Asynchronous or Synchronous Serial Port p1. The interrupt is cleared by reading the <code>data_in</code> field of register R_SERIAL1_READ or the R_SERIAL1_REC_DATA register. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 9 | ser0_ready | This field contains the individually masked interrupt bit that is set when Asynchronous Serial Port p0 is ready to get new data for transmission. The interrupt is cleared by writing new data to the <b>data_out</b> field of register R_SERIALO_CTRL or to the R_SERIALO_TR_DATA register. This bit should be masked off when the DMA is used for data transfers. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 8 | ser0_data | This field contains the individually masked interrupt bit that is set when input data is available at Asynchronous Serial Port p0. The interrupt is cleared by reading the data_in field of register R_SERIALO_READ or the R_SERIALO_REC_DATA register. The interrupt has the vector number 0x28. | 0 = inactive<br>1 = active | | 7 | pa7 | This field contains the individually masked bit for the interrupt on pin <b>pa7</b> of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to <b>pa7</b> . The interrupt has the vector number 0x2B. | 0 = inactive<br>1 = active | | 6 | pa6 | This field contains the individually masked bit for the interrupt on pin <b>pa6</b> of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to <b>pa6</b> . The interrupt has the vector number 0x2B. | 0 = inactive<br>1 = active | | 5 | pa5 | This field contains the individually masked bit for the interrupt on pin <b>pa5</b> of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to <b>pa5</b> . The interrupt has the vector number 0x2B. | 0 = inactive<br>1 = active | | 4 | pa4 | This field contains the individually masked bit for the interrupt on pin <b>pa4</b> of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to <b>pa4</b> . The interrupt has the vector number 0x2B. | 0 = inactive<br>1 = active | | 3 | pa3 | This field contains the individually masked bit for the interrupt on pin <b>pa3</b> of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to <b>pa3</b> . The interrupt has the vector number 0x2B. | 0 = inactive<br>1 = active | | 2 | pa2 | This field contains the individually masked bit for the interrupt on pin <b>pa2</b> of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to <b>pa2</b> . The interrupt has the vector number 0x2B. | 0 = inactive<br>1 = active | | D:4/-\ | Name | Description | Ctata/Day | | Bit(s) | Name | Description | State/Range | | 1 | pa1 | This field contains the individually masked bit for the interrupt on pin pa1 of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to pa1. The interrupt has the vector number $0x2B$ . | 0 = inactive<br>1 = active | |---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 0 | pa0 | This field contains the individually masked bit for the interrupt on pin $\mathbf{pa0}$ of General Port PA, when the port is used for interrupt handling. The interrupt is cleared in the external unit connected to $\mathbf{pa0}$ . The interrupt has the vector number $0x2B$ . | 0 = inactive<br>1 = active | Note: Bit 16 is multiplexed between SCSI-8 Port p1 and Parallel Port p1. Register $R\_GEN\_CONFIG$ is used to select which peripheral device to use. ### 18.13.6 R\_IRQ\_MASK1\_CLR #### IRQ Mask 1 Clear Register, General Characteristics | ID of register | R_IRQ_MASK1_CLR | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xC8 | Read/Write | Write only | | Register address | 0xB00000C8 | Initial value | Not applicable | #### Bit Assignments of R\_IRQ\_MASK1\_CLR | Bit(s) | Name | Description | State/Range | |--------|--------------|-------------------------------------------------------------------------------------------------|--------------------| | 31 | sw_int7 | This field is used to clear the <b>sw_int7</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 30 | sw_int6 | This field is used to clear the <b>sw_int6</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 29 | sw_int5 | This field is used to clear the <b>sw_int5</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 28 | sw_int4 | This field is used to clear the <b>sw_int4</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 27 | sw_int3 | This field is used to clear the <b>sw_int3</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 26 | sw_int2 | This field is used to clear the <b>sw_int2</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 25 | sw_int1 | This field is used to clear the <b>sw_int1</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 24 | sw_int0 | This field is used to clear the <b>sw_int0</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 23-20 | Reserved | - | 0 | | 19 | par1_ecp_cmd | This field is used to clear the <b>par1_ecp_cmd</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 18 | par1_peri | This field is used to clear the <b>par1_peri</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 17 | par1_data | This field is used to clear the <b>par1_data</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 16 | par1_ready | When Parallel Port p1 is in use, this field is used to clear the par1_ready interrupt mask bit. | 0 = nop<br>1 = clr | | | scsi1 | When SCSI Port 1 is in use, this field is used to clear the <b>scsi1</b> interrupt mask bit. | | | 15 | ser3_ready | This field is used to clear the <b>ser3_ready</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 14 | ser3_data | This field is used to clear the <b>ser3_data</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 13 | ser2_ready | This field is used to clear the <b>ser2_ready</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 12 | ser2_data | This field is used to clear the <b>ser2_data</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 11 | ser1_ready | This field is used to clear the <b>ser1_ready</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 10 | ser1_data | This field is used to clear the <b>ser1_data</b> interrupt mask bit. | 0 = nop<br>1 = clr | #### Bit Assignments of R\_IRQ\_MASK1\_CLR (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|-----------------------------------------------------------------------|--------------------| | 9 | ser0_ready | This field is used to clear the <b>ser0_ready</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 8 | ser0_data | This field is used to clear the <b>ser0_data</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 7 | pa7 | This field is used to clear the <b>pa7</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 6 | pa6 | This field is used to clear the pa6 interrupt mask bit | 0 = nop<br>1 = clr | | 5 | pa5 | This field is used to clear the pa5 interrupt mask bit | 0 = nop<br>1 = clr | | 4 | pa4 | This field is used to clear the pa4 interrupt mask bit | 0 = nop<br>1 = clr | | 3 | pa3 | This field is used to clear the pa3 interrupt mask bit. | 0 = nop<br>1 = clr | | 2 | pa2 | This field is used to clear the pa2 interrupt mask bit. | 0 = nop<br>1 = clr | | 1 | pa1 | This field is used to clear the pa1 interrupt mask bit | 0 = nop<br>1 = clr | | 0 | pa0 | This field is used to clear the pa0 interrupt mask bit | 0 = nop<br>1 = clr | **Note:** In this register, only bits written with 1 are cleared. Bits written with 0 are not affected. ### 18.13.7 R\_IRQ\_READ1 #### **IRQ Read 1 Register, General Characteristics** | ID of register | R_IRQ_READ1 | Size | 32 bits | |------------------|-------------|---------------|-----------| | Offset | 0xCC | Read/Write | Read only | | Register address | 0xB00000CC | Initial value | Unknown | #### Bit Assignments of R\_IRQ\_READ1 | Bit(s) | Name | Description | State/Range | |---------|--------------|--------------------------------------------------------------------------------------------------------|----------------------------| | 31 | sw_int7 | This field is used to read the status of software-generated interrupt <b>sw_int7</b> . | 0 = inactive<br>1 = active | | 30 | sw_int6 | This field is used to read the status of software-generated interrupt <b>sw_int6</b> . | 0 = inactive<br>1 = active | | 29 | sw_int5 | This field is used to read the status of software-generated interrupt ${\bf sw\_int5}$ . | 0 = inactive<br>1 = active | | 28 | sw_int4 | This field is used to read the status of software-generated interrupt $\mathbf{sw\_int4}$ . | 0 = inactive<br>1 = active | | 27 | sw_int3 | This field is used to read the status of software-generated interrupt <b>sw_int3</b> . | 0 = inactive<br>1 = active | | 26 | sw_int2 | This field is used to read the status of software-generated interrupt <b>sw_int2</b> . | 0 = inactive<br>1 = active | | 25 | sw_int1 | This field is used to read the status of software-generated interrupt <b>sw_int1</b> . | 0 = inactive<br>1 = active | | 24 | sw_int0 | This field is used to read the status of software-generated interrupt <b>sw_int0</b> . | 0 = inactive<br>1 = active | | 23 - 20 | Reserved | - | 0 | | 19 | par1_ecp_cmd | This field is used to read the status of the par1_ecp_cmd interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 18 | par1_peri | This field is used to read the status of the par1_peri interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 17 | par1_data | This field is used to read the status of the par1_data interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 16 | par1_ready | This field is used to read the status of the <b>par1_ready</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | | scsi1 | This field is used to read the status of the scsi1 interrupt prior to the individual mask. | | | 15 | ser3_ready | This field is used to read the status of the <b>ser3_ready</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 14 | ser3_data | This field is used to read the status of the <b>ser3_data</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 13 | ser2_ready | This field is used to read the status of the ser2_ready interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 12 | ser2_data | This field is used to read the status of the ser2_data interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 11 | ser1_ready | This field is used to read the status of the ser1_ready interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 10 | ser1_data | This field is used to read the status of the <b>ser1_data</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | #### Bit Assignments of R\_IRQ\_READ1 (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 9 | ser0_ready | This field is used to read the status of the <b>ser0_ready</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 8 | ser0_data | This field is used to read the status of the <b>ser0_data</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 7 | pa7 | When General Port PA is used for interrupt handling, this field is used to read the status of interrupt <b>pa7</b> prior to the individual mask. | 0 = inactive<br>1 = active | | 6 | pa6 | This field is used to read the status of pin <b>pa6</b> prior to the individual mask. | 0 = inactive<br>1 = active | | 5 | pa5 | This field is used to read the status of pin ${\bf pa5}$ prior to the individual mask. | 0 = inactive<br>1 = active | | 4 | pa4 | This field is used to read the status of pin ${\bf pa4}$ prior to the individual mask. | 0 = inactive<br>1 = active | | 3 | pa3 | This field is used to read the status of pin ${\bf pa3}$ prior to the individual mask. | 0 = inactive<br>1 = active | | 2 | pa2 | This field is used to read the status of pin <b>pa2</b> prior to the individual mask. | 0 = inactive<br>1 = active | | 1 | pa1 | This field is used to read the status of pin <b>pa1</b> prior to the individual mask. | 0 = inactive<br>1 = active | | 0 | pa0 | This field is used to read the status of pin ${\bf pa0}$ prior to the individual mask. | 0 = inactive<br>1 = active | ### 18.13.8 R\_IRQ\_MASK1\_SET #### **IRQ Mask 1 Set Register, General Characteristics** | ID of register | R_IRQ_MASK1_SET | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xCC | Read/Write | Write only | | Register address | 0xB00000CC | Initial value | Not applicable | ### Bit Assignments of R\_IRQ\_MASK1\_SET | Bit(s) | Name | Description | State/Range | |---------|--------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 31 | sw_int7 | This field is used to set the individual mask bit for the <b>sw_int7</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 30 | sw_int6 | This field is used to set the individual mask bit for the <b>sw_int6</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 29 | sw_int5 | This field is used to set the individual mask bit for the <b>sw_int5</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 28 | sw_int4 | This field is used to set the individual mask bit for the <b>sw_int4</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 27 | sw_int3 | This field is used to set the individual mask bit for the <b>sw_int3</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 26 | sw_int2 | This field is used to set the individual mask bit for the <b>sw_int2</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 25 | sw_int1 | This field is used to set the individual mask bit for the <b>sw_int1</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 24 | sw_int0 | This field is used to set the individual mask bit for the <b>sw_int0</b> interrupt. The interrupt has the vector number 0x29. | 0 = nop<br>1 = set | | 23 - 20 | Reserved | - | 0 | | 19 | par1_ecp_cmd | This field is used to set the individual mask bit for the <b>par1_ecp_cmd</b> interrupt. The interrupt has the vector number 0x25. | 0 = nop<br>1 = set | | 18 | par1_peri | This field is used to set the individual mask bit for the <b>par1_peri</b> interrupt. The interrupt has the vector number 0x25. | 0 = nop<br>1 = set | | 17 | par1_data | This field is used to set the individual mask bit for the <b>par1_data</b> interrupt. The interrupt has the vector number 0x25. | 0 = nop<br>1 = set | | 16 | par1_ready | This field is used to set the individual mask bit for the <b>par1_ready</b> interrupt. The interrupt has the vector number 0x25. | 0 = nop<br>1 = set | | | scsi1 | This field is used to set the individual mask bit for the $\mathbf{scsi1}$ interrupt. The interrupt has the vector number $0x25$ . | | ### Bit Assignments of R\_IRQ\_MASK1\_SET (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------| | 15 | ser3_ready | This field is used to set the individual mask bit for the ser3_ready interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 14 | ser3_data | This field is used to set the individual mask bit for the <b>ser3_data</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 13 | ser2_ready | This field is used to set the individual mask bit for the <b>ser2_ready</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 12 | ser2_data | This field is used to set the individual mask bit for the <b>ser2_data</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 11 | ser1_ready | This field is used to set the individual mask bit for the <b>ser1_ready</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 10 | ser1_data | This field is used to set the individual mask bit for the <b>ser1_data</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 9 | ser0_ready | This field is used to set the individual mask bit for the <b>ser0_ready</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 8 | ser0_data | This field is used to set the individual mask bit for the <b>ser0_data</b> interrupt. The interrupt has the vector number 0x28. | 0 = nop<br>1 = set | | 7 | pa7 | This field is used to set the individual mask bit for the interrupt on pin <b>pa7</b> . The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 6 | pa6 | This field is used to set the individual mask bit for the interrupt on pin <b>pa6</b> . The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 5 | pa5 | This field is used to set the individual mask bit for the interrupt on pin pa5. The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 4 | pa4 | This field is used to set the individual mask bit for the interrupt on pin <b>pa4</b> . The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 3 | pa3 | This field is used to set the individual mask bit for the interrupt on pin <b>pa3</b> . The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 2 | pa2 | This field is used to set the individual mask bit for the interrupt on pin <b>pa2</b> . The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 1 | pa1 | This field is used to set the individual mask bit for the interrupt on pin pa1. The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | | 0 | pa0 | This field is used to set the individual mask bit for the interrupt on pin <b>pa0</b> . The interrupt has the vector number 0x2B. | 0 = nop<br>1 = set | **Note:** In this register, only bits written with 1 are set. Bits written with 0 are not affected. ### 18.13.9 R\_IRQ\_MASK2\_RD #### IRQ Mask 2 Read Register, General Characteristics | ID of register | R_IRQ_MASK2_RD | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xD0 | Read/Write | Read only | | Register address | 0xB00000D0 | Initial value | Unknown | ### Bit Assignments of R\_IRQ\_MASK2\_RD | Bit(s) | Name | Description | State/Range | |---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 24 | Reserved | - | 0 | | 23 | dma8_sub3_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 8, sub-channel 3. It is cleared by writing to the clr_descr field of R_DMA_CH8_SUB3_CLR_INTR. The interrupt has the vector number 0x38. | 0 = inactive<br>1 = active | | 22 | dma8_sub2_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 8, sub-channel 2. It is cleared by writing to the clr_descr field of R_DMA_CH8_SUB2_CLR_INTR. The interrupt has the vector number 0x38. | 0 = inactive<br>1 = active | | 21 | dma8_sub1_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 8, sub-channel 1. It is cleared by writing to the clr_descr field of R_DMA_CH8_SUB1_CLR_INTR. The interrupt has the vector number 0x38. | 0 = inactive<br>1 = active | | 20 | dma8_sub0_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 8, sub-channel 0. It is cleared by writing to the clr_descr field of R_DMA_CH8_SUB0_CLR_INTR. The interrupt has the vector number 0x38. | 0 = inactive<br>1 = active | | 19 | dma9_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 9. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH9_CLR_INTR. The interrupt has the number 0x39. | 0 = inactive<br>1 = active | | 18 | dma9_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 9. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH9_CLR_INTR. The interrupt has the vector number 0x39. | 0 = inactive<br>1 = active | | 17 | dma8_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 8. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH8_CLR_INTR. The interrupt has the vector number 0x38. | 0 = inactive<br>1 = active | | 16 | dma8_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 8. It is cleared by writing to the clr_descr field of R_DMA_CH8_CLR_INTR. The interrupt has the vector number 0x38. | 0 = inactive<br>1 = active | | 15 | dma7_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 7. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH7_CLR_INTR. The interrupt has the vector number 0x37. | 0 = inactive<br>1 = active | # Bit Assignments of R\_IRQ\_MASK2\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 14 | dma7_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 7. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH7_CLR_INTR. The interrupt has the vector number 0x37. | 0 = inactive<br>1 = active | | 13 | dma6_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 6. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH6_CLR_INTR. The interrupt has the vector number 0x36. | 0 = inactive<br>1 = active | | 12 | dma6_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 6. It is cleared by writing to the clr_descr field of R_DMA_CH6_CLR_INTR. The interrupt has the vector number 0x36. | 0 = inactive<br>1 = active | | 11 | dma5_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 5. It is cleared by writing to the clr_eop field of R_DMA_CH5_CLR_INTR. The interrupt has the vector number 0x35. | 0 = inactive<br>1 = active | | 10 | dma5_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 5. It is cleared by writing to the clr_descr field of R_DMA_CH5_CLR_INTR. The interrupt has the vector number 0x35. | 0 = inactive<br>1 = active | | 9 | dma4_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 4. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH4_CLR_INTR. The interrupt has the vector number 0x34. | 0 = inactive<br>1 = active | | 8 | dma4_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 4. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH4_CLR_INTR. The interrupt has the vector number 0x34. | 0 = inactive<br>1 = active | | 7 | dma3_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 3. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH3_CLR_INTR. The interrupt has the vector number 0x33. | 0 = inactive<br>1 = active | | 6 | dma3_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 3. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH3_CLR_INTR. The interrupt has the vector number 0x33. | 0 = inactive<br>1 = active | | 5 | dma2_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 2. It is cleared by writing to the clr_eop field of R_DMA_CH2_CLR_INTR. The interrupt has the vector number 0x32. | 0 = inactive<br>1 = active | | 4 | dma2_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 2. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH2_CLR_INTR. The interrupt has the vector number 0x32. | 0 = inactive<br>1 = active | # Bit Assignments of R\_IRQ\_MASK2\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 3 | dma1_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 1. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH1_CLR_INTR. The interrupt has the vector number 0x31. | 0 = inactive<br>1 = active | | 2 | dma1_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 1. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH1_CLR_INTR. The interrupt has the vector number 0x31. | 0 = inactive<br>1 = active | | 1 | dma0_eop | This field contains the individually masked end-of-packet interrupt bit for DMA channel 0. It is cleared by writing to the <b>clr_eop</b> field of R_DMA_CH0_CLR_INTR. The interrupt has the vector number 0x30. | 0 = inactive<br>1 = active | | 0 | dma0_descr | This field contains the individually masked descriptor interrupt bit for DMA channel 0. It is cleared by writing to the <b>clr_descr</b> field of R_DMA_CH0_CLR_INTR. The interrupt has the vector number 0x30. | 0 = inactive<br>1 = active | ### 18.13.10 R\_IRQ\_MASK2\_CLR #### IRQ Mask 2 Clear Register, General Characteristics | ID of register | R_IRQ_MASK2_CLR | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xD0 | Read/Write | Write only | | Register address | 0xB00000D0 | Initial value | Not applicable | # Bit Assignments of R\_IRQ\_MASK2\_CLR | Bit(s) | Name | Description | State/Range | |---------|-----------------|-----------------------------------------------------------------------|--------------------| | 31 - 24 | Reserved | - | 0 | | 23 | dma8_sub3_descr | This field is used to clear the dma8_sub3_descr interrupt mask bit. | 0 = nop<br>1 = clr | | 22 | dma8_sub2_descr | This field is used to clear the dma8_sub2_descr interrupt mask bit. | 0 = nop<br>1 = clr | | 21 | dma8_sub1_descr | This field is used to clear the dma8_sub1_descr interrupt mask bit. | 0 = nop<br>1 = clr | | 20 | dma8_sub0_descr | This field is used to clear the dma8_sub0_descr interrupt mask bit. | 0 = nop<br>1 = clr | | 19 | dma9_eop | This field is used to clear the <b>dma9_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 18 | dma9_descr | This field is used to clear the <b>dma9_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 17 | dma8_eop | This field is used to clear the <b>dma8_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 16 | dma8_descr | This field is used to clear the <b>dma8_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 15 | dma7_eop | This field is used to clear the <b>dma7_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 14 | dma7_descr | This field is used to clear the <b>dma7_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 13 | dma6_eop | This field is used to clear the <b>dma6_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 12 | dma6_descr | This field is used to clear the <b>dma6_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 11 | dma5_eop | This field is used to clear the <b>dma5_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 10 | dma5_descr | This field is used to clear the <b>dma5_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 9 | dma4_eop | This field is used to clear the <b>dma4_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 8 | dma4_descr | This field is used to clear the <b>dma4_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 7 | dma3_eop | This field is used to clear the <b>dma3_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 6 | dma3_descr | This field is used to clear the <b>dma3_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 5 | dma2_eop | This field is used to clear the <b>dma2_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 4 | dma2_descr | This field is used to clear the <b>dma2_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | ### Bit Assignments of R\_IRQ\_MASK2\_CLR (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|-----------------------------------------------------------------------|--------------------| | 3 | dma1_eop | This field is used to clear the <b>dma1_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 2 | dma1_descr | This field is used to clear the <b>dma1_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 1 | dma0_eop | This field is used to clear the <b>dma0_eop</b> interrupt mask bit. | 0 = nop<br>1 = clr | | 0 | dma0_descr | This field is used to clear the <b>dma0_descr</b> interrupt mask bit. | 0 = nop<br>1 = clr | **Note:** In this register, only bits written with 1 are cleared. Bits written with 0 are not affected. ### 18.13.11 R\_IRQ\_READ2 #### IRQ Read 2 Register, General Characteristics | ID of register | R_IRQ_READ2 | Size | 32 bits | |------------------|-------------|---------------|-----------| | Offset | 0xD4 | Read/Write | Read only | | Register address | 0xB00000D4 | Initial value | Unknown | ### Bit Assignments of R\_IRQ\_READ2 | Bit(s) | Name | Description | State/Range | |---------|-----------------|---------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 24 | Reserved | - | 0 | | 23 | dma8_sub3_descr | This field is used to read the status of the dma8_sub3_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 22 | dma8_sub2_descr | This field is used to read the status of the dma8_sub2_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 21 | dma8_sub1_descr | This field is used to read the status of the dma8_sub1_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 20 | dma8_sub0_descr | This field is used to read the status of the dma8_sub0_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 19 | dma9_eop | This field is used to read the status of the <b>dma9_eop</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 18 | dma9_descr | This field is used to read the status of the <b>dma9_des</b> cr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 17 | dma8_eop | This field is used to read the status of the <b>dma8_eop</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 16 | dma8_descr | This field is used to read the status of the <b>dma8_descr</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 15 | dma7_eop | This field is used to read the status of the <b>dma7_eop</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 14 | dma7_descr | This field is used to read the status of the <b>dma7_descr</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 13 | dma6_eop | This field is used to read the status of the dma6_eop interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 12 | dma6_descr | This field is used to read the status of the dma6_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 11 | dma5_eop | This field is used to read the status of the dma5_eop interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 10 | dma5_descr | This field is used to read the status of the dma5_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 9 | dma4_eop | This field is used to read the status of the dma4_eop interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 8 | dma4_descr | This field is used to read the status of the dma4_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | ### Bit Assignments of R\_IRQ\_READ2 (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|--------------------------------------------------------------------------------------------------------|----------------------------| | 7 | dma3_eop | This field is used to read the status of the <b>dma3_eop</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 6 | dma3_descr | This field is used to read the status of the <b>dma3_descr</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 5 | dma2_eop | This field is used to read the status of the dma2_eop interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 4 | dma2_descr | This field is used to read the status of the dma2_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 3 | dma1_eop | This field is used to read the status of the dma1_eop interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 2 | dma1_descr | This field is used to read the status of the dma1_descr interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 1 | dma0_eop | This field is used to read the status of the <b>dma0_eop</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | | 0 | dma0_descr | This field is used to read the status of the <b>dma0_descr</b> interrupt prior to the individual mask. | 0 = inactive<br>1 = active | ## 18.13.12 R\_IRQ\_MASK2\_SET #### IRQ Mask 2 Set Register, General Characteristics | ID of register | R_IRQ_MASK2_SET | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xD4 | Read/Write | Write only | | Register address | 0xB00000D4 | Initial value | Not applicable | # Bit Assignments of R\_IRQ\_MASK2\_SET | Bit(s) | Name | Description | State/Range | |--------|-----------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------| | 31-24 | Reserved | - | 0 | | 23 | dma8_sub3_descr | This field is used to set the individual mask bit for the dma8_sub3_descr interrupt. The interrupt has the vector number 0x38. | 0 = nop<br>1 = set | | 22 | dma8_sub2_descr | This field is used to set the individual mask bit for the dma8_sub2_descr interrupt. The interrupt has the vector number 0x38. | 0 = nop<br>1 = set | | 21 | dma8_sub1_descr | This field is used to set the individual mask bit for the dma8_sub1_descr interrupt. The interrupt has the vector number 0x38. | 0 = nop<br>1 = set | | 20 | dma8_sub0_descr | This field is used to set the individual mask bit for the dma8_sub0_descr interrupt. The interrupt has the vector number 0x38. | 0 = nop<br>1 = set | | 19 | dma9_eop | This field is used to set the individual mask bit for the <b>dma9_eop</b> interrupt. The interrupt has the vector number 0x39. | 0 = nop<br>1 = set | | 18 | dma9_descr | This field is used to set the individual mask bit for the dma9_descr interrupt. The interrupt has the vector number 0x39. | 0 = nop<br>1 = set | | 17 | dma8_eop | This field is used to set the individual mask bit for the dma8_eop interrupt. The interrupt has the vector number 0x38. | 0 = nop<br>1 = set | | 16 | dma8_descr | This field is used to set the individual mask bit for the <b>dma8_descr</b> interrupt. The interrupt has the vector number 0x38. | 0 = nop<br>1 = set | | 15 | dma7_eop | This field is used to set the individual mask bit for the <b>dma7_eop</b> interrupt. The interrupt has the vector number 0x37. | 0 = nop<br>1 = set | | 14 | dma7_descr | This field is used to set the individual mask bit for the dma7_descr interrupt. The interrupt has the vector number 0x37. | 0 = nop<br>1 = set | | 13 | dma6_eop | This field is used to set the individual mask bit for the dma6_eop interrupt. The interrupt has the vector number 0x36. | 0 = nop<br>1 = set | | 12 | dma6_descr | This field is used to set the individual mask bit for the <b>dma6_descr</b> interrupt. The interrupt has the vector number 0x36. | 0 = nop<br>1 = set | | 11 | dma5_eop | This field is used to set the individual mask bit for the <b>dma5_eop</b> interrupt. The interrupt has the vector number 0x35. | 0 = nop<br>1 = set | | 10 | dma5_descr | This field is used to set the individual mask bit for the dma5_descr interrupt. The interrupt has the vector number 0x35. | 0 = nop<br>1 = set | ## Bit Assignments of R\_IRQ\_MASK2\_SET (continued) | Bit(s) | Name | Description | State/Range | |--------|------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------| | 9 | dma4_eop | This field is used to set the individual mask bit for the <b>dma4_eop</b> interrupt. The interrupt has the vector number 0x34. | 0 = nop<br>1 = set | | 8 | dma4_descr | This field is used to set the individual mask bit for the dma4_descr interrupt. The interrupt has the vector number 0x34. | 0 = nop<br>1 = set | | 7 | dma3_eop | This field is used to set the individual mask bit for the dma3_eop interrupt. The interrupt has the vector number 0x33. | 0 = nop<br>1 = set | | 6 | dma3_descr | This field is used to set the individual mask bit for the dma3_descr interrupt. The interrupt has the vector number 0x33. | 0 = nop<br>1 = set | | 5 | dma2_eop | This field is used to set the individual mask bit for the dma2_eop interrupt. The interrupt has the vector number 0x32. | 0 = nop<br>1 = set | | 4 | dma2_descr | This field is used to set the individual mask bit for the dma2_descr interrupt. The interrupt has the vector number 0x32. | 0 = nop<br>1 = set | | 3 | dma1_eop | This field is used to set the individual mask bit for the dma1_eop interrupt. The interrupt has the vector number 0x31. | 0 = nop<br>1 = set | | 2 | dma1_descr | This field is used to set the individual mask bit for the dma1_descr interrupt. The interrupt has the vector number 0x31. | 0 = nop<br>1 = set | | 1 | dma0_eop | This field is used to set the individual mask bit for the dma0_eop interrupt. The interrupt has the vector number 0x30. | 0 = nop<br>1 = set | | 0 | dma0_descr | This field is used to set the individual mask bit for the dma0_descr interrupt. The interrupt has the vector number 0x30. | 0 = nop<br>1 = set | **Note:** In this register, only bits written with 1 are set. Bits written with 0 are not affected. ## 18.13.13 R\_VECT\_MASK\_RD ## **Vector Mask Read Register, General Characteristics** | ID of register | R_VECT_MASK_RD | Size | 32 bits | |------------------|----------------|---------------|-----------| | Offset | 0xD8 | Read/Write | Read only | | Register address | 0xB00000D8 | Initial value | Unknown | # Bit Assignments of R\_VECT\_MASK\_RD | Bit(s) | Name | Description | State/Range | |---------|----------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 | usb | This field contains the composed interrupt bit for the USB after the vector mask. The vector number is 0x3F. | 0 = inactive<br>1 = active | | 30 - 26 | Reserved | - | 0 | | 25 | dma9 | This field contains the composed interrupt bit for DMA channel 9 after the vector mask. The vector number is 0x39. | 0 = inactive<br>1 = active | | 24 | dma8 | This field contains the composed interrupt bit for DMA channel 8 after the vector mask. The vector number is $0x38$ . | 0 = inactive<br>1 = active | | 23 | dma7 | This field contains the composed interrupt bit for DMA channel 7 after the vector mask. The vector number is 0x37. | 0 = inactive<br>1 = active | | 22 | dma6 | This field contains the composed interrupt bit for DMA channel 6 after the vector mask. The vector number is 0x36. | 0 = inactive<br>1 = active | | 21 | dma5 | This field contains the composed interrupt bit for DMA channel 5 after the vector mask. The vector number is 0x35. | 0 = inactive<br>1 = active | | 20 | dma4 | This field contains the composed interrupt bit for DMA channel 4 after the vector mask. The vector number is 0x34. | 0 = inactive<br>1 = active | | 19 | dma3 | This field contains the composed interrupt bit for DMA channel 3 after the vector mask. The vector number is $0x33$ . | 0 = inactive<br>1 = active | | 18 | dma2 | This field contains the composed interrupt bit for DMA channel 2 after the vector mask. The vector number is 0x32. | 0 = inactive<br>1 = active | | 17 | dma1 | This field contains the composed interrupt bit for DMA channel 1 after the vector mask. The vector number is $0x31$ . | 0 = inactive<br>1 = active | | 16 | dma0 | This field contains the composed interrupt bit for DMA channel 0 after the vector mask. The vector number is $0x30$ . | 0 = inactive<br>1 = active | | 15 - 14 | Reserved | - | 0 | | 13 | ext_dma1 | This field contains the composed interrupt bit for external DMA channel 1 after the vector mask. The vector number is 0x2D. | 0 = inactive<br>1 = active | | 12 | ext_dma0 | This field contains the composed interrupt bit for external DMA channel 0 after the vector mask. The vector number is 0x2C. | 0 = inactive<br>1 = active | | 11 | pa | This field contains the composed interrupt bit for General Port PA after the vector mask. The vector number is 0x2B. | 0 = inactive<br>1 = active | # Bit Assignments of R\_VECT\_MASK\_RD (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 10 | irq_intnr | This field contains the composed interrupt bit for the $\overline{\textbf{irq}}$ pin after the vector mask. The vector number is 0x2A. | 0 = inactive<br>1 = active | | 9 | SW | This field contains the composed interrupt bit for the software generated interrupts after the vector mask. The vector number is 0x29. | 0 = inactive<br>1 = active | | 8 | serial | This field contains the composed interrupt bit for the asynchronous and synchronous serial ports after the vector mask. The vector number is 0x28. | 0 = inactive<br>1 = active | | 7 | snmp | This field contains the composed interrupt bit for Ethernet error and statistics counters after the vector mask. The vector number is 0x27. | 0 = inactive<br>1 = active | | 6 | network | This field contains the composed interrupt bit for the network interface after the vector mask. The vector number is 0x26. | 0 = inactive<br>1 = active | | 5 | scsi1<br>par1 | This field contains the composed interrupt bit for SCSI-8 Port p1 or Parallel Port p1 after the vector mask. The vector number is 0x25. | 0 = inactive<br>1 = active | | 4 | scsi0<br>par0<br>ata<br>mio | This field contains the composed interrupt bit for SCSI-8 Port p0, SCSI-W Port, Parallel Port p0, the ATA Port or the Shared RAM Port after the vector mask. The vector number is 0x24. | 0 = inactive<br>1 = active | | 3 | timer1 | This field contains the composed interrupt bit for timer 1 after the vector mask. The vector number is $0x23$ . | 0 = inactive<br>1 = active | | 2 | timer0 | This field contains the composed interrupt bit for timer 0 after the vector mask. The vector number is $0x22$ . | 0 = inactive<br>1 = active | | 1 | nmi | This field contains the composed interrupt bit for the NMI. The vector number is $0x21$ . | 0 = inactive<br>1 = active | | 0 | some | This bit is set if any of the interrupts (except NMI but including $\overline{irq}$ with an external vector number), are active after the individual and vector masks. | 0 = inactive<br>1 = active | ## 18.13.14 R\_VECT\_MASK\_CLR ## **Vector Mask Clear Register, General Characteristics** | ID of register | R_VECT_MASK_CLR | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xD8 | Read/Write | Write only | | Register address | 0xB00000D8 | Initial value | Not applicable | # Bit Assignments of R\_VECT\_MASK\_CLR | Bit(s) | Name | Description | State/Range | |---------|-----------|--------------------------------------------------------------------------------------------------------|--------------------| | 31 | usb | This field clears the vector mask bit for the USB, vector number 0x3F. | 0 = nop<br>1 = clr | | 30 - 26 | Reserved | - | 0 | | 25 | dma9 | This field clears the vector mask bit for DMA channel 9, vector number $0x39$ . | 0 = nop<br>1 = clr | | 24 | dma8 | This field clears the vector mask bit for DMA channel 8, vector number $0x38$ . | 0 = nop<br>1 = clr | | 23 | dma7 | This field clears the vector mask bit for DMA channel 7, vector number $0x37$ . | 0 = nop<br>1 = clr | | 22 | dma6 | This field clears the vector mask bit for DMA channel 6, vector number 0x36. | 0 = nop<br>1 = clr | | 21 | dma5 | This field clears the vector mask bit for DMA channel 5, vector number $0x35$ . | 0 = nop<br>1 = clr | | 20 | dma4 | This field clears the vector mask bit for DMA channel 4, vector number $0x34$ . | 0 = nop<br>1 = clr | | 19 | dma3 | This field clears the vector mask bit for DMA channel 3, vector number 0x33. | 0 = nop<br>1 = clr | | 18 | dma2 | This field clears the vector mask bit for DMA channel 2, vector number 0x32. | 0 = nop<br>1 = clr | | 17 | dma1 | This field clears the vector mask bit for DMA channel 1, vector number $0x31$ . | 0 = nop<br>1 = clr | | 16 | dma0 | This field clears the vector mask bit for DMA channel 0, vector number $0x30$ . | 0 = nop<br>1 = clr | | 15 - 14 | Reserved | - | 0 | | 13 | ext_dma1 | This field clears the vector mask bit for external DMA channel 1, vector number 0x2D. | 0 = nop<br>1 = clr | | 12 | ext_dma0 | This field clears the vector mask bit for external DMA channel 0, vector number 0x2C. | 0 = nop<br>1 = clr | | 11 | pa | This field clears the vector mask bit for General Port PA, vector number 0x2B. | 0 = nop<br>1 = clr | | 10 | irq_intnr | This field clears the vector mask bit for the $\overline{\textbf{irq}}$ pin, vector number 0x2A. | 0 = nop<br>1 = clr | | 9 | SW | This field clears the vector mask bit for the software generated interrupts, vector number 0x29. | 0 = nop<br>1 = clr | | 8 | serial | This field clears the vector mask bit for the asynchronous serial ports, vector number 0x28. | 0 = nop<br>1 = clr | | 7 | snmp | This field clears the vector mask bit for Ethernet errors and statistics counters, vector number 0x27. | 0 = nop<br>1 = clr | | 6 | network | This field clears the vector mask bit for the network interface, vector number 0x26. | 0 = nop<br>1 = clr | ## Bit Assignments of R\_VECT\_MASK\_CLR (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 5 | scsi1<br>par1 | This field clears the vector mask bit for SCSI-8 Port p1 or Parallel Port p1, vector number 0x25. | 0 = nop<br>1 = clr | | 4 | scsi0<br>par0<br>ata<br>mio | This field clears the vector mask bit for SCSI-8 Port p0, SCSI-W Port, Parallel Port p0, the ATA Port or the shared RAM Port. Vector number 0x24. | 0 = nop<br>1 = clr | | 3 | timer1 | This field clears the vector mask bit for timer 1, vector number 0x23. | 0 = nop<br>1 = clr | | 2 | timer0 | This field clears the vector mask bit for timer 0, vector number 0x22. | 0 = nop<br>1 = clr | | 1 - 0 | Reserved | - | 0 | **Note:** In this register, only bits written with 1 are cleared. Bits written with 0 are not affected. ## 18.13.15 R\_VECT\_READ #### **Vector Read Register, General Characteristics** | ID of register | R_VECT_READ | Size | 32 bits | |------------------|-------------|---------------|-----------| | Offset | 0xDC | Read/Write | Read only | | Register address | 0xB00000DC | Initial value | Unknown | #### Bit Assignments of R\_VECT\_READ | Bit(s) | Name | Description | State/Range | |---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 | usb | This field is used to read the status of the composed interrupt bit for the USB prior to the vector mask but after the individual mask. Vector number 0x3F. | 0 = inactive<br>1 = active | | 30 - 26 | Reserved | - | 0 | | 25 | dma9 | This field is used to read the status of the composed interrupt bit for DMA channel 9 prior to the vector mask but after the individual mask. Vector number 0x39. | 0 = inactive<br>1 = active | | 24 | dma8 | This field is used to read the status of the composed interrupt bit for DMA channel 8 prior to the vector mask but after the individual mask. Vector number 0x38. | 0 = inactive<br>1 = active | | 23 | dma7 | This field is used to read the status of the composed interrupt bit for DMA channel 7 prior to the vector mask but after the individual mask. Vector number 0x37. | 0 = inactive<br>1 = active | | 22 | dma6 | This field is used to read the status of the composed interrupt bit for DMA channel 6 prior to the vector mask but after the individual mask. Vector number 0x36. | 0 = inactive<br>1 = active | | 21 | dma5 | This field is used to read the status of the composed interrupt bit for DMA channel 5 prior to the vector mask but after the individual mask. Vector number 0x35. | 0 = inactive<br>1 = active | | 20 | dma4 | This field is used to read the status of the composed interrupt bit for DMA channel 4 prior to the vector mask but after the individual mask. Vector number 0x34. | 0 = inactive<br>1 = active | | 19 | dma3 | This field is used to read the status of the composed interrupt bit for DMA channel 3 prior to the vector mask but after the individual mask. Vector number 0x33. | 0 = inactive<br>1 = active | | 18 | dma2 | This field is used to read the status of the composed interrupt bit for DMA channel 2 prior to the vector mask but after the individual mask. Vector number 0x32. | 0 = inactive<br>1 = active | | 17 | dma1 | This field is used to read the status of the composed interrupt bit for DMA channel 1 prior to the vector mask but after the individual mask. Vector number 0x31. | 0 = inactive<br>1 = active | | 16 | dma0 | This field is used to read the status of the composed interrupt bit for DMA channel 0 prior to the vector mask but after the individual mask. Vector number 0x30. | 0 = inactive<br>1 = active | | 15 - 14 | Reserved | - | 0 | | 13 | ext_dma1 | This field is used to read the status of the composed interrupt bit for external DMA channel 1 prior to the vector mask but after the individual mask. Vector number 0x2D. | 0 = inactive<br>1 = active | | 12 | ext_dma0 | This field is used to read the status of the composed interrupt bit for external DMA channel 0 prior to the vector mask but after the individual mask. Vector number 0x2C. | 0 = inactive<br>1 = active | # Bit Assignments of R\_VECT\_READ (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 11 | pa | This field is used to read the status of the composed interrupt bit for General Port PA prior to the vector mask but after the individual mask. Vector number 0x2B. | 0 = inactive<br>1 = active | | 10 | irq_intnr | This field is used to read the status of the composed interrupt bit for the $\overline{irq}$ pin prior to the vector mask but after the individual mask. Vector number 0x2A. | 0 = inactive<br>1 = active | | 9 | sw | This field is used to read the status of the composed interrupt bit for the software generated interrupts prior to the vector mask but after the individual mask. Vector number 0x29. | 0 = inactive<br>1 = active | | 8 | serial | This field is used to read the status of the composed interrupt bit for the asynchronous serial ports prior to the vector mask but after the individual mask. Vector number 0x28. | 0 = inactive<br>1 = active | | 7 | snmp | This field is used to read the status of the composed interrupt bit for Ethernet error and statistics counters prior to the vector mask but after the individual mask. Vector number 0x27. | 0 = inactive<br>1 = active | | 6 | network | This field is used to read the status of the composed interrupt bit for the network interface prior to the vector mask but after the individual mask. Vector number 0x26. | 0 = inactive<br>1 = active | | 5 | scsi1<br>par1 | This field is used to read the status of the composed interrupt bit for SCSI-8 Port p1 or Parallel Port p1 prior to the vector mask but after the individual mask. Vector number 0x25. | 0 = inactive<br>1 = active | | 4 | scsi0<br>par0<br>ata<br>mio | This field is used to read the status of the composed interrupt bit for SCSI-8 Port p0, SCSI-W Port, Parallel Port p0, the ATA Port or the shared RAM Port prior to the vector mask but after the individual mask. Vector number 0x24. | 0 = inactive<br>1 = active | | 3 | timer1 | This field is used to read the status of the composed interrupt bit for timer 1 prior to the vector mask but after the individual mask. Vector number 0x23. | 0 = inactive<br>1 = active | | 2 | timer0 | This field is used to read the composed interrupt bit for timer 0 prior to the vector mask but after the individual mask. Vector number 0x22. | 0 = inactive<br>1 = active | | 1 | nmi | This field is used to read the status of the composed interrupt bit for the NMI. Vector number 0x21. | 0 = inactive<br>1 = active | | 0 | some | This field is used to read the status of the composed interrupt bit for any of the interrupts (except NMI but including $\overline{irq}$ with an external vector number), that are active after the individual and vector masks. | 0 = inactive<br>1 = active | ## 18.13.16 R\_VECT\_MASK\_SET #### **Vector Mask Set Register, General Characteristics** | ID of register | R_VECT_MASK_SET | Size | 32 bits | |------------------|-----------------|---------------|----------------| | Offset | 0xDC | Read/Write | Write only | | Register address | 0xB00000DC | Initial value | Not applicable | # Bit Assignments of R\_VECT\_MASK\_SET | Bit(s) | Name | Description | State/Range | |---------|-----------|------------------------------------------------------------------------------------------------------------------------------|--------------------| | 31 | usb | This field is used to set the vector mask bit for the USB interrupt. Vector number 0x3F. | 0 = nop<br>1 = set | | 30 - 26 | Reserved | - | 0 | | 25 | dma9 | This field is used to set the vector mask bit for the DMA channel 9 interrupt. Vector number 0x39. | 0 = nop<br>1 = set | | 24 | dma8 | This field is used to set the vector mask bit for the DMA channel 8 interrupt. Vector number 0x38. | 0 = nop<br>1 = set | | 23 | dma7 | This field is used to set the vector mask bit for the DMA channel 7 interrupt. Vector number 0x37. | 0 = nop<br>1 = set | | 22 | dma6 | This field is used to set the vector mask bit for the DMA channel 6 interrupt. Vector number 0x36. | 0 = nop<br>1 = set | | 21 | dma5 | This field is used to set the vector mask bit for the DMA channel 5 interrupt. Vector number 0x35. | 0 = nop<br>1 = set | | 20 | dma4 | This field is used to set the vector mask bit for the DMA channel 4 interrupt. Vector number 0x34. | 0 = nop<br>1 = set | | 19 | dma3 | This field is used to set the vector mask bit for the DMA channel 3 interrupt. Vector number 0x33. | 0 = nop<br>1 = set | | 18 | dma2 | This field is used to set the vector mask bit for the DMA channel 2 interrupt. Vector number 0x32. | 0 = nop<br>1 = set | | 17 | dma1 | This field is used to set the vector mask bit for the DMA channel 1 interrupt. Vector number 0x31. | 0 = nop<br>1 = set | | 16 | dma0 | This field is used to set the vector mask bit for the DMA channel 0 interrupt. Vector number 0x30. | 0 = nop<br>1 = set | | 15 - 14 | Reserved | - | 0 | | 13 | ext_dma1 | This field is used to set the vector mask bit for the external DMA channel 1 interrupt. Vector number 0x2D. | 0 = nop<br>1 = set | | 12 | ext_dma0 | This field is used to set the vector mask bit for the external DMA channel 0 interrupt. Vector number 0x2C. | 0 = nop<br>1 = set | | 11 | pa | This field is used to set the vector mask bit for the General Port PA interrupt. Vector number 0x2B. | 0 = nop<br>1 = set | | 10 | irq_intnr | This field is used to set the vector mask bit for the $\overline{irq}$ pin interrupt. Vector number 0x2A. | 0 = nop<br>1 = set | | 9 | SW | This field is used to set the vector mask bit for the software generated interrupt. Vector number 0x29. | 0 = nop<br>1 = set | | 8 | serial | This field is used to set the vector mask bit for the asynchronous serial ports interrupt. Vector number 0x28. | 0 = nop<br>1 = set | | 7 | snmp | This field is used to set the vector mask bit for the Ethernet errors and statistics counters interrupt. Vector number 0x27. | 0 = nop<br>1 = set | | 6 | network | This field is used to set the vector mask bit for the network interface interrupt. Vector number 0x26. | 0 = nop<br>1 = set | #### Bit Assignments of R\_VECT\_MASK\_SET (continued) | Bit(s) | Name | Description | State/Range | |--------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 5 | scsi1<br>par1 | This field is used to set the vector mask bit for the SCSI-8 Port p1 or Parallel Port p1 interrupt. Vector number 0x25. | 0 = nop<br>1 = set | | 4 | scsi0<br>par0<br>ata<br>mio | This field is used to set the vector mask bit for the SCSI-8 Port p0, SCSI-W Port, Parallel Port p0, ATA Port or Shared RAM Port interrupt. Vector number 0x24. | 0 = nop<br>1 = set | | 3 | timer1 | This field is used to set the vector mask bit for the timer 1 interrupt. Vector number $0 \times 23$ . | 0 = nop<br>1 = set | | 2 | timer0 | This field is used to set the vector mask bit for the timer 0 interrupt. Vector number $0x22$ . | 0 = nop<br>1 = set | | 1 | Reserved | - | 0 | | 0 | Reserved | + | 0 | **Note:** In this register, only bits written with 1 are set. Bits written with 0 are not affected. # 18.14 DMA Registers #### 18.14.1 R\_SET\_EOP #### **Set End-of-Packet Register, General Characteristics** | ID of register | R_SET_EOP | Size | 32 bits | |------------------|------------|---------------|----------------| | Offset | 0x3C | Read/Write | Write only | | Register address | 0xB000003C | Initial value | Not applicable | #### Bit Assignments of R\_SET\_EOP | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------------------------------------------|----------------| | 31 - 4 | Reserved | - | | | 3 | ch9_eop | Setting this bit to <b>set</b> (1) forces an EOP for DMA channel 9. | 0=nop<br>1=set | | 2 | ch7_eop | Setting this bit to <b>set</b> (1) forces an EOP for DMA channel 7. | 0=nop<br>1=set | | 1 | ch5_eop | Setting this bit to <b>set</b> (1) forces an EOP for DMA channel 5. | 0=nop<br>1=set | | 0 | ch3_eop | Setting this bit to set (1) forces an EOP for DMA channel 3. | 0=nop<br>1=set | **Note:** Fields set to **set** (1) force an EOP in the DMA channel, the field values are not saved. Fields set to 0 are not affected. ## 18.14.2 R\_DMA\_CH0\_HWSW # DMA Channel 0 Hardware/Software Data Buffer Length Register, General Characteristics | ID of register | R_DMA_CH0_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x100 | Read/Write | Read/Write | | Register address | 0xB0000100 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH0\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . ## 18.14.3 R\_DMA\_CHO\_DESCR #### **DMA Channel 0 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH0_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x10C | Read/Write | Read/Write | | Register address | 0xB000010C | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH0\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | ## 18.14.4 R\_DMA\_CHO\_NEXT ## **DMA Channel 0 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH0_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x104 | Read/Write | Read/Write | | Register address | 0xB0000104 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH0\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | ## 18.14.5 R\_DMA\_CH0\_BUF #### **DMA Channel 0 Buffer Register, General Characteristics** | ID of register | R_DMA_CH0_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x108 | Read/Write | Read/Write | | Register address | 0xB0000108 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH0\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | ## 18.14.6 R\_DMA\_CHO\_FIRST ## **DMA Channel 0 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH0_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1A0 | Read/Write | Read/Write | | Register address | 0xB00001A0 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH0\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | ## 18.14.7 R\_DMA\_CH0\_CMD #### **DMA Channel 0 Command Register, General Characteristics** | ID of register | R_DMA_CH0_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1D0 | Read/Write | Read/Write | | Register address | 0xB00001D0 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH0\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: This command holds the DMA channel in its current state. start: This command tells the DMA channel to start processing the list at R_DMA_CH0_FIRST. restart: Restart tells the DMA channel to restart after end-of-list has been reached. continue: This command tells the DMA channel to continue after a successful hold command. reset: This command resets the DMA channel and its FIFOs. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | ## 18.14.8 R\_DMA\_CHO\_CLR\_INTR #### **DMA Channel 0 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH0_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1D1 | Read/Write | Write only | | Register address | 0xB00001D1 | Initial value | Not applicable | # Bit Assignments of R\_DMA\_CH0\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. ## 18.14.9 R\_DMA\_CH0\_STATUS #### **DMA Channel 0 Status Register, General Characteristics** | ID of register | R_DMA_CH0_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1D2 | Read/Write | Read only | | Register address | 0xB00001D2 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH0\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 0 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | ## 18.14.10 R\_DMA\_CH1\_HWSW # **DMA Channel 1 Hardware/Software Data Buffer Length Register, General Characteristics** | ID of register | R_DMA_CH1_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x110 | Read/Write | Read/Write | | Register address | 0xB0000110 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH1\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . ## 18.14.11 R\_DMA\_CH1\_DESCR #### **DMA Channel 1 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH1_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x11C | Read/Write | Read/Write | | Register address | 0xB000011C | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH1\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor of the DMA channel, and is updated just before a new descriptor is read. When DMA stops due to an end-of-list, <b>descr</b> is not updated allowing it to be restarted later. | | ## 18.14.12 R\_DMA\_CH1\_NEXT #### **DMA Channel 1 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH1_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x114 | Read/Write | Read/Write | | Register address | 0xB0000114 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH1\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | ## 18.14.13 R\_DMA\_CH1\_BUF #### **DMA Channel 1 Buffer Register, General Characteristics** | ID of register | R_DMA_CH1_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x118 | Read/Write | Read/Write | | Register address | 0xB0000118 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH1\_BUF | Bit( | (s) | Name | Description | State/Range | |------|-----|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - | - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | ## 18.14.14 R\_DMA\_CH1\_FIRST #### **DMA Channel 1 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH1_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1A4 | Read/Write | Read/Write | | Register address | 0xB00001A4 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH1\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | ## 18.14.15 R\_DMA\_CH1\_CMD #### **DMA Channel 1 Command Register, General Characteristics** | ID of register | R_DMA_CH1_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1D4 | Read/Write | Read/Write | | Register address | 0xB00001D4 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH1\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH1_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH1_DESCR. start: Start processing list at R_DMA_CH1_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH1_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | ## 18.14.16 R\_DMA\_CH1\_CLR\_INTR #### **DMA Channel 1 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH1_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1D5 | Read/Write | Write only | | Register address | 0xB00001D5 | Initial value | Not applicable | # Bit Assignments of R\_DMA\_CH1\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. ## 18.14.17 R\_DMA\_CH1\_STATUS #### **DMA Channel 1 Status Register, General Characteristics** | ID of register | R_DMA_CH1_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1D6 | Read/Write | Read only | | Register address | 0xB00001D6 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH1\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 1 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | ## 18.14.18 R\_DMA\_CH2\_HWSW #### DMA Channel 2 Hardware/Software Data Buffer Length Register, General Characteristics | ID of register | R_DMA_CH2_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x120 | Read/Write | Read/Write | | Register address | 0xB0000120 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH2\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . ## 18.14.19 R\_DMA\_CH2\_DESCR #### **DMA Channel 2 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH2_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x12C | Read/Write | Read/Write | | Register address | 0xB000012C | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH2\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | ## 18.14.20 R\_DMA\_CH2\_NEXT ## **DMA Channel 2 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH2_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x124 | Read/Write | Read/Write | | Register address | 0xB0000124 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH2\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | ## 18.14.21 R\_DMA\_CH2\_BUF #### **DMA Channel 2 Buffer Register, General Characteristics** | ID of register | R_DMA_CH2_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x128 | Read/Write | Read/Write | | Register address | 0xB0000128 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH2\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | ## 18.14.22 R\_DMA\_CH2\_FIRST #### **DMA Channel 2 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH2_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1A8 | Read/Write | Read/Write | | Register address | 0xB00001A8 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH2\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | ## 18.14.23 R\_DMA\_CH2\_CMD #### **DMA Channel 2 Command Register, General Characteristics** | ID of register | R_DMA_CH2_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1D8 | Read/Write | Read/Write | | Register address | 0xB00001D8 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH2\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH2_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH2_DESCR. start: Start processing list at R_DMA_CH2_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH2_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | ## 18.14.24 R\_DMA\_CH2\_CLR\_INTR #### **DMA Channel 2 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH2_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1D9 | Read/Write | Write only | | Register address | 0xB00001D9 | Initial value | Not applicable | #### Bit Assignments of R\_DMA\_CH2\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. ## 18.14.25 R\_DMA\_CH2\_STATUS #### **DMA Channel 2 Status Register, General Characteristics** | ID of register | R_DMA_CH2_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1DA | Read/Write | Read only | | Register address | 0xB00001DA | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH2\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 2 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | ## 18.14.26 R\_DMA\_CH3\_HWSW # DMA Channel 3 Hardware/Software Data Buffer Length Register, General Characteristics | ID of register | R_DMA_CH3_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x130 | Read/Write | Read/Write | | Register address | 0xB0000130 | Initial value | Unknown | ## Bit Assignments of R\_DMA\_CH3\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.27 R\_DMA\_CH3\_DESCR #### **DMA Channel 3 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH3_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x13C | Read/Write | Read/Write | | Register address | 0xB000013C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH3\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.28 R\_DMA\_CH3\_NEXT #### **DMA Channel 3 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH3_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x134 | Read/Write | Read/Write | | Register address | 0xB0000134 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH3\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.29 R\_DMA\_CH3\_BUF #### **DMA Channel 3 Buffer Register, General Characteristics** | ID of register | R_DMA_CH3_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x138 | Read/Write | Read/Write | | Register address | 0xB0000138 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH3\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.30 R\_DMA\_CH3\_FIRST #### **DMA Channel 3 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH3_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1AC | Read/Write | Read/Write | | Register address | 0xB00001AC | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH3\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.31 R\_DMA\_CH3\_CMD #### **DMA Channel 3 Command Register, General Characteristics** | ID of register | R_DMA_CH3_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1DC | Read/Write | Read/Write | | Register address | 0xB00001DC | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH3\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH3_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH3_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH3_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | # 18.14.32 R\_DMA\_CH3\_CLR\_INTR #### **DMA Channel 3 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH3_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1DD | Read/Write | Write only | | Register address | 0xB00001DD | Initial value | Not applicable | #### Bit Assignments of R\_DMA\_CH3\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.33 R\_DMA\_CH3\_STATUS #### **DMA Channel 3 Status Register, General Characteristics** | ID of register | R_DMA_CH3_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1DE | Read/Write | Read only | | Register address | 0xB00001DE | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH3\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 3 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.14.34 R\_DMA\_CH4\_HWSW #### DMA Channel 4 Hardware/Software Data Buffer Length Register, General Characteristics | ID of register | R_DMA_CH4_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x140 | Read/Write | Read/Write | | Register address | 0xB0000140 | Initial value | Unknown | #### Bit Assignments of R\_DMA\_CH4\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.35 R\_DMA\_CH4\_DESCR # **DMA Channel 4 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH4_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x14C | Read/Write | Read/Write | | Register address | 0xB000014C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH4\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.36 R\_DMA\_CH4\_NEXT #### **DMA Channel 4 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH4_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x144 | Read/Write | Read/Write | | Register address | 0xB0000144 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH4\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.37 R\_DMA\_CH4\_BUF #### **DMA Channel 4 Buffer Register, General Characteristics** | ID of register | R_DMA_CH4_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x148 | Read/Write | Read/Write | | Register address | 0xB0000148 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH4\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.38 R\_DMA\_CH4\_FIRST # **DMA Channel 4 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH4_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1B0 | Read/Write | Read/Write | | Register address | 0xB00001B0 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH4\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.39 R\_DMA\_CH4\_CMD #### **DMA Channel 4 Command Register, General Characteristics** | ID of register | R_DMA_CH4_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1E0 | Read/Write | Read/Write | | Register address | 0xB00001E0 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH4\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2-0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH4_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH4_DESCR. start: Start processing list at R_DMA_CH4_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH4_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | # 18.14.40 R\_DMA\_CH4\_CLR\_INTR #### **DMA Channel 4 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH4_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1E1 | Read/Write | Write only | | Register address | 0xB00001E1 | Initial value | Not applicable | #### Bit Assignments of R\_DMA\_CH4\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.41 R\_DMA\_CH4\_STATUS #### **DMA Channel 4 Status Register, General Characteristics** | ID of register | R_DMA_CH4_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1E2 | Read/Write | Read only | | Register address | 0xB00001E2 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH4\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 4 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.14.42 R\_DMA\_CH5\_HWSW # **DMA Channel 5 Hardware/Software Data Buffer Length Register, General Characteristics** | ID of register | R_DMA_CH5_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x150 | Read/Write | Read/Write | | Register address | 0xB0000150 | Initial value | Unknown | #### Bit Assignments of R\_DMA\_CH5\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.43 R\_DMA\_CH5\_DESCR #### **DMA Channel 5 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH5_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x15C | Read/Write | Read/Write | | Register address | 0xB000015C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH5\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.44 R\_DMA\_CH5\_NEXT #### **DMA Channel 5 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH5_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x154 | Read/Write | Read/Write | | Register address | 0xB0000154 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH5\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.45 R\_DMA\_CH5\_BUF #### **DMA Channel 5 Buffer Register, General Characteristics** | ID of register | R_DMA_CH5_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x158 | Read/Write | Read/Write | | Register address | 0xB0000158 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH5\_BUF | Bit( | (s) | Name | Description | State/Range | |------|-----|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - | - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.46 R\_DMA\_CH5\_FIRST # **DMA Channel 5 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH5_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1B4 | Read/Write | Read/Write | | Register address | 0xB00001B4 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH5\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.47 R\_DMA\_CH5\_CMD #### **DMA Channel 5 Command Register, General Characteristics** | ID of register | R_DMA_CH5_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1E4 | Read/Write | Read/Write | | Register address | 0xB00001E4 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH5\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH5_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH5_DESCR. start: Start processing list at R_DMA_CH5_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH5_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re- read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | # 18.14.48 R\_DMA\_CH5\_CLR\_INTR #### **DMA Channel 5 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH5_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1E5 | Read/Write | Write only | | Register address | 0xB00001E5 | Initial value | Not applicable | #### Bit Assignments of R\_DMA\_CH5\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.49 R\_DMA\_CH5\_STATUS #### **DMA Channel 5 Status Register, General Characteristics** | ID of register | R_DMA_CH5_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1E6 | Read/Write | Read only | | Register address | 0xB00001E6 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH5\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 5 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.14.50 R\_DMA\_CH6\_HWSW #### DMA Channel 6 Hardware/Software Data Buffer Length Register, General Characteristics | ID of register | R_DMA_CH6_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x160 | Read/Write | Read/Write | | Register address | 0xB0000160 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH6\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.51 R\_DMA\_CH6\_DESCR # **DMA Channel 6 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH6_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x16C | Read/Write | Read/Write | | Register address | 0xB000016C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH6\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.52 R\_DMA\_CH6\_NEXT #### **DMA Channel 6 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH6_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x164 | Read/Write | Read/Write | | Register address | 0xB0000164 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH6\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.53 R\_DMA\_CH6\_BUF #### **DMA Channel 6 Buffer Register, General Characteristics** | ID of register | R_DMA_CH6_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x168 | Read/Write | Read/Write | | Register address | 0xB0000168 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH6\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.54 R\_DMA\_CH6\_FIRST # **DMA Channel 6 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH6_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1B8 | Read/Write | Read/Write | | Register address | 0xB00001B8 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH6\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.55 R\_DMA\_CH6\_CMD #### **DMA Channel 6 Command Register, General Characteristics** | ID of register | R_DMA_CH6_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1E8 | Read/Write | Read/Write | | Register address | 0xB00001E8 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | #### Bit Assignments of R\_DMA\_CH6\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH6_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH6_DESCR. start: Start processing list at R_DMA_CH6_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH6_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | # 18.14.56 R\_DMA\_CH6\_CLR\_INTR #### **DMA Channel 6 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH6_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1E9 | Read/Write | Write only | | Register address | 0xB00001E9 | Initial value | Not applicable | #### Bit Assignments of R\_DMA\_CH6\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.57 R\_DMA\_CH6\_STATUS #### **DMA Channel 6 Status Register, General Characteristics** | ID of register | R_DMA_CH6_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1EA | Read/Write | Read only | | Register address | 0xB00001EA | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH6\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 6 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.14.58 R\_DMA\_CH7\_HWSW #### DMA Channel 7 Hardware/Software Data Buffer Length Register, General Characteristics | ID of register | R_DMA_CH7_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x170 | Read/Write | Read/Write | | Register address | 0xB0000170 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH7\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.59 R\_DMA\_CH7\_DESCR # **DMA Channel 7 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH7_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x17C | Read/Write | Read/Write | | Register address | 0xB000017C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH7\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.60 R\_DMA\_CH7\_NEXT # **DMA Channel 7 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH7_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x174 | Read/Write | Read/Write | | Register address | 0xB0000174 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH7\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.61 R\_DMA\_CH7\_BUF #### **DMA Channel 7 Buffer Register, General Characteristics** | ID of register | R_DMA_CH7_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x178 | Read/Write | Read/Write | | Register address | 0xB0000178 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH7\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.62 R\_DMA\_CH7\_FIRST #### **DMA Channel 7 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH7_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1BC | Read/Write | Read/Write | | Register address | 0xB00001BC | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH7\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.63 R\_DMA\_CH7\_CMD ### **DMA Channel 7 Command Register, General Characteristics** | ID of register | R_DMA_CH7_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1EC | Read/Write | Read/Write | | Register address | 0xB00001EC | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | ### Bit Assignments of R\_DMA\_CH7\_CMD | 7 - 3 Reserve<br>2 - 0 cmd | ed | - | 0 | |----------------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 2 - 0 cmd | | | | | | | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH7_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH7_DESCR. start: Start processing list at R_DMA_CH7_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH7_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re- read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command wompletes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | # 18.14.64 R\_DMA\_CH7\_CLR\_INTR ### **DMA Channel 7 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH7_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1ED | Read/Write | Write only | | Register address | 0xB00001ED | Initial value | Not applicable | ### Bit Assignments of R\_DMA\_CH7\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.65 R\_DMA\_CH7\_STATUS ### **DMA Channel 7 Status Register, General Characteristics** | ID of register | R_DMA_CH7_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1EE | Read/Write | Read only | | Register address | 0xB00001EE | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH7\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 7 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.14.66 R\_DMA\_CH8\_HWSW # **DMA Channel 8 Hardware/Software Data Buffer Length Register, General Characteristics** | ID of register | R_DMA_CH8_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x180 | Read/Write | Read/Write | | Register address | 0xB0000180 | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.67 R\_DMA\_CH8\_DESCR ### **DMA Channel 8 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH8_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x18C | Read/Write | Read/Write | | Register address | 0xB000018C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.68 R\_DMA\_CH8\_NEXT ### **DMA Channel 8 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH8_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x184 | Read/Write | Read/Write | | Register address | 0xB0000184 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.69 R\_DMA\_CH8\_BUF ### **DMA Channel 8 Buffer Register, General Characteristics** | ID of register | R_DMA_CH8_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x188 | Read/Write | Read/Write | | Register address | 0xB0000188 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.70 R\_DMA\_CH8\_FIRST # **DMA Channel 8 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH8_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1C0 | Read/Write | Read/Write | | Register address | 0xB00001C0 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.71 R\_DMA\_CH8\_CMD ### **DMA Channel 8 Command Register, General Characteristics** | ID of register | R_DMA_CH8_CMD | Size | 8 bits | |------------------|---------------|---------------|----------------------------------------------------------------------| | Offset | 0x1F0 | Read/Write | Read/Write | | Register address | 0xB00001F0 | Initial value | Bits 7 to 3 are<br>unknown. Bits 2 to<br>0 are set to 0 at<br>reset. | ### Bit Assignments of R\_DMA\_CH8\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | | Reserved | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH8_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH8_DESCR. start: Start processing list at R_DMA_CH8_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH8_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | | | | restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH8_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re- read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held | | # 18.14.72 R\_DMA\_CH8\_CLR\_INTR ### **DMA Channel 8 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH8_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1F1 | Read/Write | Write only | | Register address | 0xB00001F1 | Initial value | Not applicable | ### Bit Assignments of R\_DMA\_CH8\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to <b>do</b> (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.73 R\_DMA\_CH8\_STATUS ### **DMA Channel 8 Status Register, General Characteristics** | ID of register | R_DMA_CH8_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1F2 | Read/Write | Read only | | Register address | 0xB00001F2 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 8 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.14.74 R\_DMA\_CH8\_SUB # **DMA Channel 8 Subchannel Descriptor Register, General Characteristics** | ID of register | R_DMA_CH8_SUB | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x18C | Read/Write | Read/Write | | Register address | 0xB000018C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB | Bit(s) | Name | Description | State/Range | |--------|------|------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | sub | This register gives the pointer to the current SB descriptor, and is shared between all subchannels. | | # 18.14.75 R\_DMA\_CH8\_NEP # **DMA Channel 8 Next Endpoint Descriptor Register, General Characteristics** | ID of register | R_DMA_CH8_NEP | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x1C0 | Read/Write | Read/Write | | Register address | 0xB00001C0 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_NEP | Bit(s) | Name | Description | State/Range | |--------|------|-------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | nep | This register gives the pointer to the next endpoint descriptor. Endpoint descriptors must be 32-bit aligned for correct operation. | | # 18.14.76 R\_DMA\_CH8\_SUB0\_EP # DMA Channel 8 Subchannel 0 Endpoint Descriptor Register, General Characteristics | ID of register | R_DMA_CH8_SUB0_EP | Size | 32 bits | |------------------|-------------------|---------------|------------| | Offset | 0x1C8 | Read/Write | Read/Write | | Register address | 0xB00001C8 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB0\_EP | Bit(s) | Name | Description | State/Range | |--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | ер | This register gives the pointer to current endpoint descriptor for the subchannel. Endpoint descriptors must be 32-bit aligned for correct operation. | | # 18.14.77 R\_DMA\_CH8\_SUB0\_CMD # DMA Channel 8 Subchannel 0 Command Register, General Characteristics | ID of register | R_DMA_CH8_SUB0_CMD | Size | 8 bits | |------------------|--------------------|---------------|------------| | Offset | 0x1D3 | Read/Write | Read/Write | | Register address | 0xB00001D3 | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_SUB0\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 7 - 1 | Reserved | - | 0 | | 0 | cmd | This is the subchannel command register. start: Starts the subchannel, but nothing will happen until the USB interface tells the subchannel what to do. There is no need to reset the FIFO before starting a subchannel | 0 = stop<br>1 = start | | | | since the DMA controller will reset the FIFO when changing to a new subchannel. stop: Stop the subchannel. However, the subchannel will finish current activities before stopping. | | # 18.14.78 R\_DMA\_CH8\_SUB0\_CLR\_INTR # DMA Channel 8 Subchannel 0 Clear Interrupt Register, General Characteristics | ID of register | R_DMA_CH8_SUB0_CLR_INTR | Size | 8 bits | |------------------|-------------------------|---------------|------------| | Offset | 0x1E3 | Read/Write | Write only | | Register address | 0xB00001E3 | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_SUB0\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|------------------------------------------------------------------------------------------------|--------------------| | 7 - 1 | Reserved | - | 0 | | 0 | clr_descr | Setting this bit to <b>do</b> (1) clears the DMA channel 8, subchannel 0 descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to ${f do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.79 R\_DMA\_CH8\_SUB1\_EP # DMA Channel 8 Subchannel 1 Endpoint Register, General Characteristics | ID of register | R_DMA_CH8_SUB1_EP | Size | 32 bits | |------------------|-------------------|---------------|------------| | Offset | 0x1CC | Read/Write | Read/Write | | Register address | 0xB00001CC | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB1\_EP | E | Bit(s) | Name | Description | State/Range | |---|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 3 | 31 - 0 | ер | This register gives the pointer to current endpoint descriptor for the subchannel. Endpoint descriptors must be 32-bit aligned for correct operation. | | # 18.14.80 R\_DMA\_CH8\_SUB1\_CMD # DMA Channel 8 Subchannel 1 Command Register, General Characteristics | ID of register | R_DMA_CH8_SUB1_CMD | Size | 8 bits | |------------------|--------------------|---------------|------------| | Offset | 0x1D7 | Read/Write | Read/Write | | Register address | 0xB00001D7 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB1\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 7 - 1 | Reserved | - | 0 | | 0 | cmd | This is the subchannel command register. start: Starts the subchannel, but nothing will happen until the USB tells the subchannel what to do. There is no need to reset the FIFO before starting a subchannel since the DMA controller will reset the FIFO when changing to a new subchannel. | 0 = stop<br>1 = start | | | | <b>stop</b> : Stop the subchannel. However, the subchannel will finish current activities before stopping. | | # 18.14.81 R\_DMA\_CH8\_SUB1\_CLR\_INTR # DMA Channel 8 Subchannel 1 Clear Interrupt Register, General Characteristics | ID of register | R_DMA_CH8_SUB1_CLR_INTR | Size | 8 bits | |------------------|-------------------------|---------------|------------| | Offset | 0x1E7 | Read/Write | Write only | | Register address | 0xB00001E7 | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_SUB1\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|------------------------------------------------------------------------------------------------|--------------------| | 7 - 1 | Reserved | - | 0 | | 0 | clr_descr | Setting this bit to <b>do</b> (1) clears the dma channel 8, subchannel 1 descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to ${f do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.82 R\_DMA\_CH8\_SUB2\_EP # DMA Channel 8 Subchannel 2 Endpoint Register, General Characteristics | ID of register | R_DMA_CH8_SUB2_EP | Size | 32 bits | |------------------|-------------------|---------------|------------| | Offset | 0x1F8 | Read/Write | Read/Write | | Register address | 0xB00001F8 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB2\_EP | Bit(s) | Name | Description | State/Range | |--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | ер | This register gives the pointer to current endpoint descriptor for the subchannel. Endpoint descriptors must be 32-bit aligned for correct operation. | | # 18.14.83 R\_DMA\_CH8\_SUB2\_CMD # DMA Channel 8 Subchannel 2 Command Register, General Characteristics | ID of register | R_DMA_CH8_SUB2_CMD | Size | 8 bits | |------------------|--------------------|---------------|------------| | Offset | 0x1DB | Read/Write | Read/Write | | Register address | 0xB00001DB | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_SUB2\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 7 - 1 | Reserved | - | 0 | | 0 | cmd | This is the subchannel command register. start: Starts the subchannel, but nothing will happen until the USB tells the subchannel what to do. There is no need to reset the FIFO before starting a subchannel since the DMA controller will reset the FIFO when changing to a new subchannel. | 0 = stop<br>1 = start | | | | <b>stop</b> : Stop the subchannel. However, the subchannel will finish current activities before stopping. | | # 18.14.84 R\_DMA\_CH8\_SUB2\_CLR\_INTR # DMA Channel 8 Subchannel 2 Clear Interrupt Register, General Characteristics | ID of register | R_DMA_CH8_SUB2_CLR_INTR | Size | 8 bits | |------------------|-------------------------|---------------|------------| | Offset | 0x1EB | Read/Write | Write only | | Register address | 0xB00001EB | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_SUB2\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|------------------------------------------------------------------------------------------------|--------------------| | 7 - 1 | Reserved | - | 0 | | 0 | clr_descr | Setting this bit to <b>do</b> (1) clears the dma channel 8, subchannel 2 descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to ${f do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.85 R\_DMA\_CH8\_SUB3\_EP # **DMA Channel 8 Subchannel 3 Endpoint Register, General Characteristics** | ID of register | R_DMA_CH8_SUB3_EP | Size | 32 bits | |------------------|-------------------|---------------|------------| | Offset | 0x1FC | Read/Write | Read/Write | | Register address | 0xB00001FC | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB3\_EP | Bit(s) | Name | Description | State/Range | |--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | ер | This register gives the pointer to current endpoint descriptor for the subchannel. Endpoint descriptors must be 32-bit aligned for correct operation. | | # 18.14.86 R\_DMA\_CH8\_SUB3\_CMD # DMA Channel 8 Subchannel 3 Command Register, General Characteristics | ID of register | R_DMA_CH8_SUB3_CMD | Size | 8 bits | |------------------|--------------------|---------------|------------| | Offset | 0x1DF | Read/Write | Read/Write | | Register address | 0xB00001DF | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH8\_SUB3\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 7 - 1 | Reserved | - | 0 | | 0 | cmd | This is the subchannel command register. start: Starts the subchannel, but nothing will happen until the USB tells the subchannel what to do. There is no need to reset the FIFO before starting a subchannel since the DMA controller will reset the FIFO when changing to a new subchannel. | 0 = stop<br>1 = start | | | | <b>stop</b> : Stop the subchannel. However, the subchannel will finish current activities before stopping. | | # 18.14.87 R\_DMA\_CH8\_SUB3\_CLR\_INTR # DMA Channel 8 Subchannel 3 Clear Interrupt Register, General Characteristics | ID of register | R_DMA_CH8_SUB3_CLR_INTR | Size | 8 bits | |------------------|-------------------------|---------------|------------| | Offset | 0x1EF | Read/Write | Write only | | Register address | 0xB00001EF | Initial value | Unknown | ### Bit Assignments of R\_DMA\_CH8\_SUB3\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|------------------------------------------------------------------------------------------------|--------------------| | 7 - 1 | Reserved | - | 0 | | 0 | clr_descr | Setting this bit to <b>do</b> (1) clears the dma channel 8, subchannel 3 descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to ${f do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.88 R\_DMA\_CH9\_HWSW # **DMA Channel 9 Hardware/Software Data Buffer Length Register, General Characteristics** | ID of register | R_DMA_CH9_HWSW | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x190 | Read/Write | Read/Write | | Register address | 0xB0000190 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH9\_HWSW | Bit(s) | Name | Description | State/Range | |---------|------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 16 | hw | This field gives the current number of bytes left in the DMA buffer (note). <b>hw</b> is updated each time DMA accesses the DMA buffer. | 0 - 65535 | | 15 - 0 | SW | This field gives the total length in bytes of the DMA buffer (note). <b>sw</b> is updated when a new descriptor is read by the DMA channel. | 0 - 65535 | **Note:** If all bits are 0, the length is $2^{16}$ . # 18.14.89 R\_DMA\_CH9\_DESCR ### **DMA Channel 9 Current Descriptor Register, General Characteristics** | ID of register | R_DMA_CH9_DESCR | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x19C | Read/Write | Read/Write | | Register address | 0xB000019C | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH9\_DESCR | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | descr | This field gives the pointer to the current descriptor for<br>the DMA channel, and is updated just before a new<br>descriptor is read. When DMA stops due to an end-of-<br>list, <b>descr</b> is not updated allowing it to be restarted later. | | # 18.14.90 R\_DMA\_CH9\_NEXT ### **DMA Channel 9 Next Descriptor Register, General Characteristics** | ID of register | R_DMA_CH9_NEXT | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x194 | Read/Write | Read/Write | | Register address | 0xB0000194 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH9\_NEXT | Bit(s) | Name | Description | State/Range | |--------|------|----------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | next | This field gives the pointer to the next descriptor, and is updated when a new descriptor is read. | | # 18.14.91 R\_DMA\_CH9\_BUF ### **DMA Channel 9 Buffer Register, General Characteristics** | ID of register | R_DMA_CH9_BUF | Size | 32 bits | |------------------|---------------|---------------|------------| | Offset | 0x198 | Read/Write | Read/Write | | Register address | 0xB0000198 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH9\_BUF | Bit(s) | Name | Description | State/Range | |--------|------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | buf | This field gives the pointer to next position in the buffer DMA will access. It is updated as DMA accesses data in the buffer. | | # 18.14.92 R\_DMA\_CH9\_FIRST # **DMA Channel 9 First Descriptor Register, General Characteristics** | ID of register | R_DMA_CH9_FIRST | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x1C4 | Read/Write | Read/Write | | Register address | 0xB00001C4 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH9\_FIRST | Bit(s) | Name | Description | State/Range | |--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | first | This field gives the pointer to the first descriptor in the packet currently processed by the DMA channel, and must be updated by software before starting the DMA channel. It is updated by DMA after it has accessed the packet for the last time, and before DMA advances to the next packet in the list. <b>first</b> is set to zero by the DMA channel when end-of-list is reached. | | # 18.14.93 R\_DMA\_CH9\_CMD ### **DMA Channel 9 Command Register, General Characteristics** | ID of register | R_DMA_CH9_CMD | Size | 8 bits | |------------------|---------------|---------------|-------------------------------------------------------------| | Offset | 0x1F4 | Read/Write | Read/Write | | Register address | 0xB00001F4 | Initial value | Bits 7 to 3 are unknown. Bits 2 to 0 are set to 0 at reset. | ### Bit Assignments of R\_DMA\_CH9\_CMD | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 7 - 3 | Reserved | - | 0 | | 2 - 0 | cmd | This is the command register to control DMA operation. When a command is completed, the DMA channel clears this register (i.e. cmd is set to hold (0)) and stops. hold: Hold the DMA channel in its current state. The hold command is completed immediately. Note that the hold command will fail if the DMA channel has completed the previous command before the hold command is given. An unsuccessful hold command is indicated by: (1) If the DMA channel reached end-of-list, R_DMA_CH9_FIRST is zero. (2) If the DMA channel received stop-from-io, the stop bit is set in the descriptor at R_DMA_CH9_DESCR. start: Start processing list at R_DMA_CH9_FIRST. This command completes at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. restart: Restart after end-of-list has been reached. The DMA channel re-reads the descriptor at R_DMA_CH9_DESCR, and if the eol-bit is no longer set, it immediately follows the next link in the re-read descriptor ignoring the wait, intr, and eop bits. This command is completed at end-of-list (1), stop-from-io (2), or a reset command (3). If the DMA channel is already running this command is ignored. continue: Continue after a successful hold command. If the hold command was unsuccessful, the continue command will be interpreted as a restart command. The continue command completes when the command held by the hold command has completed. | 0 = hold<br>1 = start<br>3 = restart<br>3 = continue<br>4 = reset | # 18.14.94 R\_DMA\_CH9\_CLR\_INTR ### **DMA Channel 9 Clear Interrupt Register, General Characteristics** | ID of register | R_DMA_CH9_CLR_INTR | Size | 8 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x1F5 | Read/Write | Write only | | Register address | 0xB00001F5 | Initial value | Not applicable | #### Bit Assignments of R\_DMA\_CH9\_CLR\_INTR | Bit(s) | Name | Description | State/Range | |--------|-----------|-------------------------------------------------------------------|--------------------| | 7 - 2 | Reserved | - | 0 | | 1 | clr_eop | Setting this bit to ${f do}$ (1) clears the eop interrupt. | 0 = dont<br>1 = do | | 0 | clr_descr | Setting this bit to ${f do}$ (1) clears the descriptor interrupt. | 0 = dont<br>1 = do | **Note:** Interrupts corresponding to fields set to $\mathbf{do}$ (1) are cleared, their field values are not saved. Fields set to 0 are not affected. # 18.14.95 R\_DMA\_CH9\_STATUS ### **DMA Channel 9 Status Register, General Characteristics** | ID of register | R_DMA_CH9_STATUS | Size | 8 bits | |------------------|------------------|---------------|-----------| | Offset | 0x1F6 | Read/Write | Read only | | Register address | 0xB00001F6 | Initial value | Unknown | # Bit Assignments of R\_DMA\_CH9\_STATUS | Bit(s) | Name | Description | State/Range | |--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 | Reserved | - | 0 | | 6 - 0 | avail | This field shows the number of bytes in the DMA channel 9 FIFO. If there is more than one packet in the FIFO, <b>avail</b> reflects the first packet put into the FIFO. | 0 - 64 | # 18.15 Test Mode Registers # 18.15.1 R\_TEST\_MODE #### **Test Mode Register, General Characteristics** | ID of register | R_TEST_MODE | Size | 32 bits | |------------------|-------------|---------------|------------| | Offset | 0xFC | Read/Write | Write only | | Register address | 0xB00000FC | Initial value | 1 | ### Bit Assignments of R\_TEST\_MODE | Bit(s) | Name | Description | State/Range | |---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 31 - 20 | Reserved | - | 0 | | 19 | single_step | This field is used to enable and disable single step. | 0 = off<br>1 = on | | 18 | step_wr | This field is used to enable and disable single step break on memory write cycles. | 0 = off<br>1 = on | | 17 | step_rd | This field is used to enable and disable single step break on memory data read cycles. | 0 = off<br>1 = on | | 16 | step_fetch | This field is used to enable and disable single step break on instruction fetch cycles. | 0 = off<br>1 = on | | 15 - 13 | Reserved | - | 0 | | 12 | mmu_test | This field is used to enable and disable the MMU test mode. In MMU test mode, the bus fault output to the CPU/cache is always zero. | 0 = off<br>1 = on | | 11 | usb_test | This field is used to enable and disable the USB test mode. | 0 = off<br>1 = on | | 10 | scsi_timer_test | This field is used to enable and disable the SCSI arbitration timer test mode. | 0 = off<br>1 = on | | 9 | backoff | This field is used to enable and disable the network transmitter backoff test mode. During loopback mode, this bit also enables the <b>col</b> signal. | 0 = off<br>1 = on | | 8 | snmp_test | This field is used to enable and disable the test mode for the Ethernet error and statistics counters. | 0 = off<br>1 = on | | 7 | snmp_inc | Ethernet error and statistics counter test mode increment clock. When <b>snmp_test</b> is set to on, a 0->1 transition makes all Ethernet error and statistics counters count up by one. | 0 = dont<br>1 = do | | 6 | ser_loop | Select loopback for the serial ports. Note that the loopback test only works if the <b>baudrate</b> bit in this register is set to <b>off</b> (0). This field controls the synchronous serial port loopback as well. | 0 = off<br>1 = on | | 5 | baudrate | This field is used to enable and disable the baudrate select test mode. When set, the selected baudrate clocks are output on the asynchronous and synchronous serial port $\overline{rts}$ and $txd$ pins. The baudrate clocks are 20 ns long positive pulses. | 0 = off<br>1 = on | ### **Bit Assignments of R\_TEST\_MODE (continued)** | Bit(s) | Name | Description | State/Range | |--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | 4 - 3 | timer | Timer clock divider test bits. The clock divider consists of a prescaler and four cascaded 4-bit counters. The test modes break up the carry between the 4-bit counters. off: Normal operation. even: Counters 0 and 2 have 50 MHZ input. Carry from counters 0 to 1 and from 2 to 3 is connected normally. odd: Counters 0, 1 and 3 have input from the prescaler (14.75 MHz). Carry from counters 2 to 3 is connected normally. all: All 4-bit counters have 50 MHz input. | 0 = off<br>1 = even<br>2 = odd<br>3 = all | | 2 | cache_test | This field is used to enable and disable the cache memory test mode. If the cache memory test mode is enabled, and the cache is enabled in the <b>cache_enable</b> field below, all memory accesses are treated as cacheable and cache hits (i.e. 8 kbyte RAM cache). | 0 = normal<br>1 = test | | 1 | tag_test | This field is used to enable and disable the cache tag memory test mode. It is used primarily for initializing and production tests. In this mode, it is possible to write to the cache's tag memory. DMA accesses are not allowed in this mode. if (addr[31] == 0){ TM.tag[addr[12:5]] = addr[30:13]; TM.dirty[addr[12:5]] = addr[0]; } | 0 = normal<br>1 = test | | 0 | cache_enable | This field is used to enable and disable the cache. If the cache is disabled, all memory accesses are treated as non-cacheable accesses and, as a result, bypass the cache. | 0 = disable<br>1 = enable | # 18.15.2 R\_SINGLE\_STEP ### **Single Step Register, General Characteristics** | ID of register | R_SINGLE_STEP | Size | 8 bits | |------------------|---------------|---------------|------------| | Offset | 0xFE | Read/Write | Write only | | Register address | 0xB00000FE | Initial value | 0 | # Bit Assignments of R\_SINGLE\_STEP | Bit(s) | Name | Description | State/Range | |--------|-------------|-----------------------------------------------------------------------------------------|-------------------| | 7 - 4 | Reserved | - | 0 | | 3 | single_step | This field is used to enable and disable single step. | 0 = off<br>1 = on | | 2 | step_wr | This field is used to enable and disable single step break on memory write cycles. | 0 = off<br>1 = on | | 1 | step_rd | This field is used to enable and disable single step break on memory data read cycles. | 0 = off<br>1 = on | | 0 | step_fetch | This field is used to enable and disable single step break on instruction fetch cycles. | 0 = off<br>1 = on | **Note:** This 8-bit wide register is part of the R\_TEST\_MODE register. # 18.16 Universal Serial Bus Interface Control Registers Note: The initial values for all USB registers except R\_USB\_REVISION below are unknown until USB is enabled in R\_GEN\_CONFIG. #### 18.16.1 R\_USB\_REVISION #### **USB Revision Register, General Characteristics** | ID of register | R_USB_REVISION | Size | 8 bits | |------------------|----------------|---------------|---------------------| | Offset | 0x200 | Read/Write | Read only | | Register address | 0xB0000200 | Initial value | 0x10 or 0x11 (note) | #### Bit Assignments of R\_USB\_REVISION | В | it(s) | Name | Description | State/Range | |---|-------|-------|----------------------------------------------------------------------|----------------------| | 7 | - 4 | major | This field holds the major ETRAX 100LX USB internal revision number. | 1 | | 3 | - 0 | minor | This field holds the minor ETRAX 100LX USB internal revision number. | 0 = v3<br>1 = v1, v2 | Note: In revision 1 or 2 (v1,v2) of the ETRAX 100LX, this register shows a value of 0x11. In revision 3 (v3) of the ETRAX 100LX, this register reads 0x10. The USB version supported in both these cases is USB specification 1.1. The ETRAX 100LX v1 has part number 17511, v2 has part number 17854, and v3 has part number 18816. ## 18.16.2 R\_USB\_COMMAND ## **USB Command Register, General Characteristics** | ID of register | R_USB_COMMAND | Size | 8 bits | |------------------|---------------|---------------|------------| | Offset | 0x201 | Read/Write | Read/Write | | Register address | 0xB0000201 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_COMMAND | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | 7 - 6 | port_sel | This field selects which port the <b>port_cmd</b> field is to be applied on. | 0 = nop<br>1 = port1<br>2 = port2<br>3 = both | | 5 - 4 | port_cmd | This field is the request to be sent to the port. Note that if either v2 or v3 of the ETRAX 100LX is used, port_cmd disable must be issued by using the register R_USB_PORT1_DISABLE for port 1 and R_USB_PORT2_DISABLE for port 2 instead of using R_USB_COMMAND. | 0 = reset<br>1 = disable<br>2 = suspend<br>3 = resume | | 3 | busy | This field is read only. It signals that the USB interface is busy executing the last given command. Any written value will be ignored. | 0 = no<br>1 = yes | | 2 - 0 | ctrl_cmd | This is the controller command. | 0 = nop<br>1 = reset<br>2 = deconfig<br>3 = host_config<br>4 = dev_config<br>5 = host_reset<br>6 = host_run<br>7 = host_stop | **Note:** This register is used in host mode. ## 18.16.3 R\_USB\_COMMAND\_DEV ## **USB Command Device Register, General Characteristics** | ID of register | R_USB_COMMAND_DEV | Size | 8 bits | |------------------|-------------------|---------------|------------| | Offset | 0x201 | Read/Write | Read/Write | | Register address | 0xB0000201 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_COMMAND\_DEV | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | 7 - 6 | port_sel | This field selects which port the <b>port_cmd</b> field is applied on. It is not necessary to remember which port was configured in R_GEN_CONFIG. Use <b>any</b> (3) to command a port and <b>nop</b> (0) to not command a port. | 0 = nop<br>3 = any | | 5 - 4 | port_cmd | This field is the request to send to the port. | 0 = active<br>1 = passive<br>2 = nop<br>3 = wakeup | | 3 | busy | This field is read only. It signals that the USB interface is busy executing the last given command. Any written value will be ignored. | 0 = no<br>1 = yes | | 2 - 0 | ctrl_cmd | This is the controller command. | 0 = nop<br>1 = reset<br>2 = deconfig<br>3 = host_config<br>4 = dev_config<br>5 = dev_active<br>6 = dev_passive<br>7 = dev_nop | **Note:** This register is used in device mode. ## 18.16.4 R\_USB\_STATUS ## **USB Status Register, General Characteristics** | ID of register | R_USB_STATUS | Size | 8 bits | |------------------|--------------|---------------|-----------| | Offset | 0x202 | Read/Write | Read only | | Register address | 0xB0000202 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_STATUS | Bit(s) | Name | Description | State/Range | |--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 7 - 6 | Reserved | - | 0 | | 5 | ourun | This field indicates that an overrun or underrun condition occurred. The bit is cleared by a read from R_USB_EPID_ATTN. | 0 = no<br>1 = yes | | 4 | perror | This field indicates that there was something wrong with the contents of a DMA descriptor, or that an invalid EPID was used. The bit is cleared by a read from R_USB_EPID_ATTN. | 0 = no<br>1 = yes | | 3 | device_mode | This field indicates that the USB interface operates in device mode. | 0 = no<br>1 = yes | | 2 | host_mode | This field indicates that the USB interface operates in host mode. | 0 = no<br>1 = yes | | 1 | started | In host mode, this field shows that the controller has been started. In device mode, it shows that the device is active. | 0 = no<br>1 = yes | | 0 | running | In host, mode this bit indicates that the host is running. In device mode, it is always ${f no}$ (0). | 0 = no<br>1 = yes | ## 18.16.5 R\_USB\_IRQ\_MASK\_SET #### **USB IRQ Mask Set Register, General Characteristics** | ID of register | R_USB_IRQ_MASK_SET | Size | 16 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x204 | Read/Write | Write only | | Register address | 0xB0000204 | Initial value | Not applicable | ## Bit Assignments of R\_USB\_IRQ\_MASK\_SET | Bit(s) | Name | Description | State/Range | |---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 15 - 14 | Reserved | - | 0 | | 13 | iso_eof | This field sets the mask bit for the $iso\_eof$ interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 12 | intr_eof | This field sets the mask bit for the <code>intr_eof</code> interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number $0x3E$ . | 0 = nop<br>1 = set | | 11 | iso_eot | This field sets the mask bit for the $iso\_eot$ interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number $0x3E$ . | 0 = nop<br>1 = set | | 10 | intr_eot | This field sets the mask bit for the <code>intr_eot</code> interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number $0x3E$ . | 0 = nop<br>1 = set | | 9 | ctl_eot | This field sets the mask bit for the $ctl\_eot$ interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number $0x3F$ . | 0 = nop<br>1 = set | | 8 | bulk_eot | This field sets the mask bit for the <code>bulk_eot</code> interrupt. The interrupt is cleared when the <code>R_USB_EPID_ATTN</code> register is read. The interrupt has the vector number <code>0x3F</code> . | 0 = nop<br>1 = set | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field sets the mask bit for the <code>epid_attn</code> interrupt. The interrupt is cleared when register R_USB_EPID_ATTN is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 2 | sof | This field sets the mask bit for the <b>sof</b> interrupt. The interrupt is cleared when register R_USB_FM_NUMBER is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 1 | port_status | This field sets the mask bit for the <b>port_status</b> interrupt. The interrupt is cleared after changed port status registers R_USB_RH_PORT_STATUS_1 and R_USB_RH_PORT_STATUS_2 have been read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 0 | ctl_status | This field sets the mask bit for the <b>ctl_status</b> interrupt. The interrupt is cleared when register R_USB_STATUS is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | **Note 1:** The masks for interrupts corresponding to fields set to (1) are set, their field values are not saved. Fields set to **nop** (0) are not affected. **Note 2:** This register is used in host mode. ## 18.16.6 R\_USB\_IRQ\_MASK\_READ #### **USB IRQ Mask Read Register, General Characteristics** | ID of register | R_USB_IRQ_MASK_READ | Size | 16 bits | |------------------|---------------------|---------------|-----------| | Offset | 0x204 | Read/Write | Read only | | Register address | 0xB0000204 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_IRQ\_MASK\_READ | Bit(s) | Name | Description | State/Range | |--------|-------------|-----------------------------------------------------------------------------------------------|-------------------------| | 15-14 | Reserved | - | 0 | | 13 | iso_eof | This field shows the status of the <b>iso_eof</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 12 | intr_eof | This field shows the status of the <code>intr_eof</code> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 11 | iso_eot | This field shows the status of the <b>iso_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 10 | intr_eot | This field shows the status of the <b>intr_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 9 | ctl_eot | This field shows the status of the <b>ctl_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 8 | bulk_eot | This field shows the status of the ${\bf bulk\_eot}$ interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field shows the status of the ${\bf epid\_attn}$ interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 2 | sof | This field shows the status of the <b>sof</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 1 | port_status | This field shows the status of the <b>port_status</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 0 | ctl_status | This field shows the status of the ${\it ctl\_status}$ interrupt after the individual mask. | 0 = no_pend<br>1 = pend | **Note:** This register is used in host mode. ## 18.16.7 R\_USB\_IRQ\_MASK\_CLR #### **USB IRQ Mask Clear Register, General Characteristics** | ID of register | R_USB_IRQ_MASK_CLR | Size | 16 bits | |------------------|--------------------|---------------|----------------| | Offset | 0x206 | Read/Write | Write only | | Register address | 0xB0000206 | Initial value | Not applicable | ## Bit Assignments of R\_USB\_IRQ\_MASK\_CLR | Bit(s) | Name | Description | State/Range | |---------|-------------|-------------------------------------------------------------------------|--------------------| | 15 - 14 | Reserved | - | 0 | | 13 | iso_eof | This field clears the mask bit of the <b>iso_eof</b> interrupt. | 0 = nop<br>1 = clr | | 12 | intr_eof | This field clears the mask bit of the <code>intr_eof</code> interrupt. | 0 = nop<br>1 = clr | | 11 | iso_eot | This field clears the mask bit of the <b>iso_eot</b> interrupt. | 0 = nop<br>1 = clr | | 10 | intr_eot | This field clears the mask bit of the intr_eot interrupt. | 0 = nop<br>1 = clr | | 9 | ctl_eot | This field clears the mask bit of the ctl_eot interrupt. | 0 = nop<br>1 = clr | | 8 | bulk_eot | This field clears the mask bit of the <b>bulk_eot</b> interrupt. | 0 = nop<br>1 = clr | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field clears the mask bit of the <code>epid_attn</code> interrupt. | 0 = nop<br>1 = clr | | 2 | sof | This field clears the mask bit of the <b>sof</b> interrupt. | 0 = nop<br>1 = clr | | 1 | port_status | This field clears the mask bit of the <b>port_status</b> interrupt. | 0 = nop<br>1 = clr | | 0 | ctl_status | This field clears the mask bit of the ctl_status interrupt. | 0 = nop<br>1 = clr | - **Note 1:** The masks for interrupts corresponding to fields set to **clr** (1) are cleared, their field values are not saved. Fields set to **nop** (0) are not affected. - **Note 2:** This register is used in host mode. ## 18.16.8 R\_USB\_IRQ\_READ ## **USB IRQ Read Register, General Characteristics** | ID of register | R_USB_IRQ_READ | Size | 16 bits | |------------------|----------------|---------------|-----------| | Offset | 0x206 | Read/Write | Read only | | Register address | 0xB0000206 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_IRQ\_READ | Bit(s) | Name | Description | State/Range | |---------|-------------|--------------------------------------------------------------------------------------------------|-------------------------| | 15 - 14 | Reserved | - | 0 | | 13 | iso_eof | This field shows the status of the <b>iso_eof</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 12 | intr_eof | This field shows the status of the <code>intr_eof</code> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 11 | iso_eot | This field shows the status of the <b>iso_eot</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 10 | intr_eot | This field shows the status of the <code>intr_eot</code> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 9 | ctl_eot | This field shows the status of the ${\it ctl\_eot}$ interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 8 | bulk_eot | This field shows the status of the <b>bulk_eot</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field shows the status of the <b>epid_attn</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 2 | sof | This field shows the status of the ${\bf sof}$ interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 1 | port_status | This field shows the status of the <b>port_status</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 0 | ctl_status | This field shows the status of the <b>ctl_status</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | **Note:** This register is used in host mode. ## 18.16.9 R\_USB\_IRQ\_MASK\_SET\_DEV #### **USB IRQ Mask Set Device Register, General Characteristics** | ID of register | R_USB_IRQ_MASK_SET_DEV | Size | 16 bits | |------------------|------------------------|---------------|----------------| | Offset | 0x204 | Read/Write | Write only | | Register address | 0xB0000204 | Initial value | Not applicable | ## Bit Assignments of R\_USB\_IRQ\_MASK\_SET\_DEV | Bit(s) | Name | Description | State/Range | |---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 15 - 13 | Reserved | r- | 0 | | 12 | out_eot | This field sets the mask bit for the <code>out_eot</code> interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 11 | ep3_in_eot | This field sets the mask bit for the <code>ep3_in_eot</code> interrupt. The interrupt is cleared when the <code>R_USB_EPID_ATTN</code> register is read. The interrupt has the vector number <code>0x3F</code> . | 0 = nop<br>1 = set | | 10 | ep2_in_eot | This field sets the mask bit for the <b>ep2_in_eot</b> interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 9 | ep1_in_eot | This field sets the mask bit for the <b>ep1_in_eot</b> interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 8 | ep0_in_eot | This field sets the mask bit for the <b>ep0_in_eot</b> interrupt. The interrupt is cleared when the R_USB_EPID_ATTN register is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field sets the mask bit for the <code>epid_attn</code> interrupt. The interrupt is cleared when register R_USB_EPID_ATTN is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 2 | sof | This field sets the mask bit for the <b>sof</b> interrupt. The interrupt is cleared when R_USB_FM_NUMBER_DEV is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 1 | port_status | This field sets the mask bit for the <b>port_status</b> interrupt. The interrupt is cleared after the R_USB_RH_PORT_STATUS_1 and R_USB_RH_PORT_STATUS_2 registers have been read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | | 0 | ctl_status | This field sets the mask bit for the <b>ctl_status</b> interrupt. The interrupt is cleared when R_USB_STATUS is read. The interrupt has the vector number 0x3F. | 0 = nop<br>1 = set | **Note 1:** The masks for interrupts corresponding to fields set to (1) are set, their field values are not saved. Fields set to **nop** (0) are not affected. **Note 2:** This register is used in device mode. ## 18.16.10 R\_USB\_IRQ\_MASK\_READ\_DEV ## **USB IRQ Mask Read Device Register, General Characteristics** | ID of register | R_USB_IRQ_MASK_READ_DEV | Size | 16 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x204 | Read/Write | Read only | | Register address | 0xB0000204 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_IRQ\_MASK\_READ\_DEV | Bit(s) | Name | Description | State/Range | |---------|-------------|------------------------------------------------------------------------------------------------|-------------------------| | 15 - 13 | Reserved | - | 0 | | 12 | out_eot | This field shows the status of the <b>out_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 11 | ep3_in_eot | This field shows the status of the <b>ep3_in_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 10 | ep2_in_eot | This field shows the status of the <b>ep2_in_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 9 | ep1_in_eot | This field shows the status of the <b>ep1_in_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 8 | ep0_in_eot | This field shows the status of the <b>ep0_in_eot</b> interrupt after the individual mask. | 0 = no_pend<br>1 = pend | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field shows the status of the ${\bf epid\_attn}$ interrupt after to the individual mask. | 0 = no_pend<br>1 = pend | | 2 | sof | This field shows the status of the <b>sof</b> interrupt after to the individual mask. | 0 = no_pend<br>1 = pend | | 1 | port_status | This field shows the status of the <b>port_status</b> interrupt after to the individual mask. | 0 = no_pend<br>1 = pend | | 0 | ctl_status | This field shows the status of the ${\it ctl\_status}$ interrupt after to the individual mask. | 0 = no_pend<br>1 = pend | **Note:** This register is used in device mode. ## 18.16.11 R\_USB\_IRQ\_MASK\_CLR\_DEV #### **USB IRQ Mask Clear Device Register, General Characteristics** | ID of register | R_USB_IRQ_MASK_CLR_DEV | Size | 16 bits | |------------------|------------------------|---------------|----------------| | Offset | 0x206 | Read/Write | Write only | | Register address | 0xB0000206 | Initial value | Not applicable | ## Bit Assignments of R\_USB\_IRQ\_MASK\_CLR\_DEV | Bit(s) | Name | Description | State/Range | |---------|-------------|----------------------------------------------------------------------------------|--------------------| | 15 - 13 | Reserved | ie. | 0 | | 12 | out_eot | This field clears the interrupt mask bit for the <b>out_eot</b> interrupt. | 0 = nop<br>1 = clr | | 11 | ep3_in_eot | This field clears the interrupt mask bit for the ${\bf ep3\_in\_eot}$ interrupt. | 0 = nop<br>1 = clr | | 10 | ep2_in_eot | This field clears the interrupt mask bit for the ${\bf ep2\_in\_eot}$ interrupt. | 0 = nop<br>1 = clr | | 9 | ep1_in_eot | This field clears the interrupt mask bit for the ${\bf ep1\_in\_eot}$ interrupt. | 0 = nop<br>1 = clr | | 8 | ep0_in_eot | This field clears the interrupt mask bit for the ${\bf ep0\_in\_eot}$ interrupt. | 0 = nop<br>1 = clr | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field clears the interrupt mask bit for the ${\bf epid\_attn}$ interrupt. | 0 = nop<br>1 = clr | | 2 | sof | This field clears the interrupt mask bit for the <b>sof</b> interrupt. | 0 = nop<br>1 = clr | | 1 | port_status | This field clears the interrupt mask bit for the ${\bf port\_status}$ interrupt. | 0 = nop<br>1 = clr | | 0 | ctl_status | This field clears the interrupt mask bit for the ctl_status interrupt. | 0 = nop<br>1 = clr | - **Note 1:** The masks for interrupts corresponding to fields set to **clr** (1) are cleared, their field values are not saved. Fields set to **nop** (0) are not affected. - **Note 2:** This register is used in device mode. ## 18.16.12 R\_USB\_IRQ\_READ\_DEV ## **USB IRQ Read Device Register, General Characteristics** | ID of register | R_USB_IRQ_READ_DEV | Size | 16 bits | |------------------|--------------------|---------------|-----------| | Offset | 0x206 | Read/Write | Read only | | Register address | 0xB0000206 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_IRQ\_READ\_DEV | Bit(s) | Name | Description | State/Range | |---------|-------------|------------------------------------------------------------------------------------------------|-------------------------| | 15 - 13 | Reserved | - | 0 | | 12 | out_eot | This field shows the status for the ${\bf out\_eot}$ interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 11 | ep3_in_eot | This field shows the status for the <b>ep3_in_eot</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 10 | ep2_in_eot | This field shows the status for the <b>ep2_in_eot</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 9 | ep1_in_eot | This field shows the status for the <b>ep1_in_eot</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 8 | ep0_in_eot | This field shows the status for the <b>ep0_in_eot</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 7 - 4 | Reserved | - | 0 | | 3 | epid_attn | This field shows the status for the <b>epid_attn</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 2 | sof | This field shows the status for the <b>sof</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 1 | port_status | This field shows the status for the <b>port_status</b> interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | | 0 | ctl_status | This field shows the status for the ctl_status interrupt prior to the individual mask. | 0 = no_pend<br>1 = pend | **Note:** This register is used in device mode. ## 18.16.13 R\_USB\_FM\_NUMBER ## **USB Frame Number Register, General Characteristics** | ID of register | R_USB_FM_NUMBER | Size | 32 bits | |------------------|-----------------|---------------|------------| | Offset | 0x20C | Read/Write | Read/Write | | Register address | 0xB000020C | Initial value | 0x00000000 | ## Bit Assignments of R\_USB\_FM\_NUMBER | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | value | This register holds the value of the current USB frame number. It is cleared on USB controller reset. | | **Note:** This register is used in host mode. #### 18.16.14 R\_USB\_FM\_NUMBER\_DEV #### **USB Frame Number Device Register, General Characteristics** | ID of register | R_USB_FM_NUMBER_DEV | Size | 32 bits | |------------------|---------------------|---------------|------------| | Offset | 0x20C | Read/Write | Read/Write | | Register address | 0xB000020C | Initial value | 0x00000000 | #### Bit Assignments of R\_USB\_FM\_NUMBER\_DEV | Bit(s) | Name | Description | State/Range | |---------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 31 | sign | If sign is equal to <b>early</b> (0), the host frame is <b>deviation</b> bits shorter than the standard USB frame size. If sign is equal to <b>late</b> (1), the host frame is <b>deviation</b> bits longer the standard USB frame size. | 0 = early<br>1 = late | | 30 - 24 | deviation | | 0 - 127 | | 23 - 11 | Reserved | ie. | 0 | | 10 - 0 | fm_number | This field gives the latest received <b>sof</b> number. | 0 - 1023 | - **Note 1:** This register is used in device mode to read the value of the current USB frame, and is cleared on USB controller reset. - **Note 2:** In device mode, software has to update the register R\_USB\_FM\_INTERVAL if the **sof** IRQ must follow the SOF packet. By using the fields **sign** and **deviation** in R\_USB\_FM\_NUMBER\_DEV, software can decide how R\_USB\_FM\_INTERVAL should be updated. ## 18.16.15 R\_USB\_FM\_INTERVAL #### **USB Frame Interval Register, General Characteristics** | ID of register | R_USB_FM_INTERVAL | Size | 16 bits | |------------------|-------------------|---------------|------------| | Offset | 0x210 | Read/Write | Read/Write | | Register address | 0xB0000210 | Initial value | 0x2EDF | #### Bit Assignments of R\_USB\_FM\_INTERVAL | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 14 | Reserved | - | 0 | | 13 - 6 | fixed | This field gives the upper eight bits of the frame interval. These bits are read only. | 187 | | 5 - 0 | adj | This field gives the lower six bits of the frame interval. These bits can be written to in order to adjust the frame interval if needed. The standard says that the frame interval must not deviate from the nominal 12000 bit times by more than 15 bit times. Host controller software must not adjust the frame interval by more than one bit time over six frames, and only one bit time in each adjustment. | 0 - 63 | #### **Note:** This register contains a 14 bit value defining the bit time interval in a frame (i.e. the distance between two sofs). The frame timer counts from this value down to zero. The value is reloaded into the R\_USB\_FM\_REMAINING register at each start of frame. The value in this register is the frame length minus one. ## 18.16.16 R\_USB\_FM\_REMAINING ## **USB Frame Remaining Register, General Characteristics** | ID of register | R_USB_FM_REMAINING | Size | 16 bits | |------------------|--------------------|---------------|-----------| | Offset | 0x212 | Read/Write | Read only | | Register address | 0xB0000212 | Initial value | 0x0000 | ## Bit Assignments of R\_USB\_FM\_REMAINING | Bit(s) | Name | Description | State/Range | |---------|----------|-----------------------------------------------------------------------------|-------------| | 15 - 14 | Reserved | - | 0 | | 13 - 0 | value | This register shows the remaining number of bit times in the current frame. | | ## 18.16.17 R\_USB\_FM\_PSTART ## **USB Frame Periodic Start Register, General Characteristics** | ID of register | R_USB_FM_PSTART | Size | 16 bits | |------------------|-----------------|---------------|------------| | Offset | 0x214 | Read/Write | Read/Write | | Register address | 0xB0000214 | Initial value | 0x0000 | ## Bit Assignments of R\_USB\_FM\_PSTART | Bit(s) | Name | Description | State/Range | |---------|----------|-----------------------------------------------|-------------| | 15 - 14 | Reserved | - | 0 | | 13 - 0 | value | This register gives the periodic start point. | | **Note:** This register is used in host mode. ## 18.16.18 R\_USB\_RH\_STATUS ## **USB Root Hub Status Register, General Characteristics** | ID of register | R_USB_RH_STATUS | Size | 8 bits | |------------------|-----------------|---------------|-----------| | Offset | 0x203 | Read/Write | Read only | | Register address | 0xB0000203 | Initial value | Undefined | ## Bit Assignments of R\_USB\_RH\_STATUS | Bit(s) | Name | Description | State/Range | |--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | 7 | babble2 | This bit is set if there is a babbling device detected on USB Port p2. It is reset by reading R_USB_RH_PORT_STATUS_2. | 0 = no<br>1 = yes | | 6 | babble1 | This bit is set if there is a babbling device detected on USB Port p1. It is reset by reading R_USB_RH_PORT_STATUS_1. | 0 = no<br>1 = yes | | 5 - 4 | bus1 | This field shows the bus state of port 1 as sampled at the EOF2 time in the frame, and is used for diagnostic purposes. If port 1 is not configured, then this field is undefined. | 0 = SE0<br>1 = Diff0<br>1 = Diff1<br>3 = SE1 | | 3 - 2 | bus2 | This field shows the bus state of port 2 as sampled at the EOF2 time in the frame, and is used for diagnostic purposes. If port 2 is not configured, then this field is undefined. | 0 = SE0<br>1 = Diff0<br>1 = Diff1<br>3 = SE1 | | 1 - 0 | nports | This field shows the number of root port hubs. It is controlled by the USB bits in R_GEN_CONFIG. It is only possible to read two values: 1 and 2. If no ports are configured, the USB interface will be turned off, rending the values undefined. | 1 - 2 | ## 18.16.19 R\_USB\_RH\_PORT\_STATUS\_1 #### **USB Root Hub Port Status 1 Register, General Characteristics** | ID of register | R_USB_RH_PORT_STATUS_1 | Size | 16 bits | |------------------|------------------------|---------------|-----------| | Offset | 0x218 | Read/Write | Read only | | Register address | 0xB0000218 | Initial value | 0x0000 | #### Bit Assignments of R\_USB\_RH\_PORT\_STATUS\_1 | Bit(s) | Name | Description | State/Range | |---------|-------------|---------------------------------------------------------------------------------------------------------------------------|---------------------| | 15 - 10 | Reserved | - | 0 | | 9 | speed | This field shows the speed of the connected device. <b>full</b> (0) = Full speed device <b>low</b> (1) = Low speed device | 0 = full<br>1 = low | | 8 | power | This field is not implemented in hardware, and is always read as zero. | 0 = no | | 7 - 5 | Reserved | - | 0 | | 4 | reset | This field is set during the reset sequence of this port | 0 = no<br>1 = yes | | 3 | overcurrent | This field is not implemented in hardware, and is always read as zero. | 0 = no | | 2 | suspended | This field tells whether or not the connected device is suspended. | 0 = no | | 1 | enabled | This field shows the status of whether the port is enabled or disabled for USB traffic. | 0 = no<br>1 = yes | | 0 | connected | This field shows if there is a device connected to this port. | 0 = no<br>1 = yes | #### Note: This register is compatible with the **wPortStatus** field of the **get\_status** command to the USB hubs (These terms relate to the Universal Serial Bus specification Rev 1.1). Two bits of **wPortStatus** are not implemented in hardware and must be implemented in software. These are the **overcurrent** and **power** fields. The reading of R\_USB\_RH\_PORT\_STATUS\_1, together with R\_USB\_RH\_PORT\_STATUS\_2, clears the root hub status change interrupt condition. #### 18.16.20 R\_USB\_RH\_PORT\_STATUS\_2 #### **USB Root Hub Port Status 2 Register, General Characteristics** | ID of register | R_USB_RH_PORT_STATUS_2 | Size | 16 bits | |------------------|------------------------|---------------|-----------| | Offset | 0x21A | Read/Write | Read only | | Register address | 0xB000021A | Initial value | 0x0000 | #### Bit Assignments of R\_USB\_RH\_PORT\_STATUS\_2 | Bit(s) | Name | Description | State/Range | |---------|-------------|---------------------------------------------------------------------------------------------------------------------------|---------------------| | 15 - 10 | Reserved | - | 0 | | 9 | speed | This field shows the speed of the connected device. <b>full</b> (0) = Full speed device <b>low</b> (1) = Low speed device | 0 = full<br>1 = low | | 8 | power | This field is not implemented in hardware, and is always read as zero. | 0 = no | | 7 - 5 | Reserved | - | 0 | | 4 | reset | This field is set during the reset sequence of this port | 0 = no<br>1 = yes | | 3 | overcurrent | This field is not implemented in hardware, and is always read as zero. | 0 = no | | 2 | suspended | This field tells whether or not the connected device is suspended. | 0 = no<br>1 = yes | | 1 | enabled | This field shows the status of whether the port is enabled or disabled for USB traffic. | 0 = no<br>1 = yes | | 0 | connected | This field shows if there is a device connected to this port. | 0 = no<br>1 = yes | #### Note: This register is compatible with the **wPortStatus** field of the **get\_status** command to the USB hubs (These terms relate to the Universal Serial Bus specification Rev 1.1). Two bits of **wPortStatus** are not implemented in hardware and must be implemented in software. These are the **overcurrent** and **power** fields. The reading of R\_USB\_RH\_PORT\_STATUS\_2, together with R\_USB\_RH\_PORT\_STATUS\_1, clears the root hub status change interrupt condition. ## 18.16.21 R\_USB\_EPT\_INDEX ## **USB End Point Table Index Register, General Characteristics** | ID of register | R_USB_EPT_INDEX | Size | 8 bits | |------------------|-----------------|---------------|------------| | Offset | 0x208 | Read/Write | Read/Write | | Register address | 0xB0000208 | Initial value | 0x00 | ## Bit Assignments of R\_USB\_EPT\_INDEX | Bit(s) | Name | Description | State/Range | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 5 | Reserved | - | 0 | | 4 - 0 | value | The index into the endpoint lookup table to be used when reading and writing to the R_USB_EPT_DATA register. The endpoint lookup table contains 32 endpoint entries, each pointing at an endpoint on a device on the USB. The table is indexed by the endpoint ID (EPID) number in the USB DMA descriptors. | 0 - 31 | ## 18.16.22 R\_USB\_EPT\_DATA #### **USB End Point Table Data Register, General Characteristics** | ID of register | R_USB_EPT_DATA | Size | 32 bits | |------------------|----------------|---------------|------------| | Offset | 0x21C | Read/Write | Read/Write | | Register address | 0xB000021C | Initial value | 0x00000000 | #### Bit Assignments of R\_USB\_EPT\_DATA | Bit(s) | Name | Description | State/Range | |---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------| | 31 | valid | This field indicates the validity of this table entry. | 0 = no<br>1 = yes | | 30 | hold | This field is used to tell software to stay off of this entry. Hardware will use this entry for more transactions. This field may be cleared by software when traffic for this endpoint is stopped. | 0 = no<br>1 = yes | | 29 - 28 | error_count_in | This field is the transaction error counter for IN transactions. Even though this field is writable, it should only be set to zero by software. | 0 - 3 | | 27 | t_in | This is the data toggle bit for IN transactions. | 0 - 1 | | 26 | low_speed | This field marks the endpoint as a low speed endpoint. This puts some protocol restrictions on what software can do with the endpoint. See the USB specification rev 1.1 for more information on low speed devices. | 0 = no<br>1 = yes | | 25 - 24 | port | This field indicates the expected port where upstream traffic for this device is due to occur. Downstream traffic goes to both ports. | 0 = any<br>1 = p1<br>2 = p2<br>3 = undef | | 23 - 22 | error_code | This field indicates what kind of error caused the endpoint to be disabled. A stall is not really a protocol error. It merely says that the endpoint gave a stall response. A bus_error is when two devices respond to a transaction request. This condition has to be resolved by software. buffer_error indicates a DMA overrun or underrun. | 0 = no_error<br>1 = stall<br>2 = bus_error<br>3 = buffer_error | | 21 | t_out | This is the toggle bit for OUT and SETUP transactions. | 0 - 1 | | 20 - 19 | error_count_out | This is the transaction error counter for OUT and SETUP transactions. Even though this field is writable, it should only be set to zero by software. | 0 - 3 | | 18 | Reserved | - | 0 | | 17 - 11 | max_len | This is the max packet length for normal (i.e. not isochronous) data packets. | 1 - 64 | | 10 - 7 | ер | This field gives the endpoint number. | 0 - 15 | | 6 - 0 | dev | This field gives the configured device address. | 0 - 127 | **Note:** This is the general endpoint table data register. It is used for host mode normal transfers. For isochronous transfers in host mode see R\_USB\_EPT\_DATA\_ISO. For device mode, see R\_USB\_EPT\_DATA\_DEV. All these registers have the same address. ## 18.16.23 R\_USB\_EPT\_DATA\_ISO ## USB End Point Table Data Isochronous Register, General Characteristics | ID of register | R_USB_EPT_DATA_ISO | Size | 32 bits | |------------------|--------------------|---------------|------------| | Offset | 0x21C | Read/Write | Read/Write | | Register address | 0xB000021C | Initial value | 0x00000000 | ## Bit Assignments of R\_USB\_EPT\_DATA\_ISO | Bit(s) | Name | Description | State/Range | |---------|------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 31 | valid | This field indicates the validity of this table entry. | 0 = no<br>1 = yes | | 30 - 26 | Reserved | - | 0 | | 25 - 24 | port | This field indicates the expected port where upstream traffic for this device is due to occur. Downstream traffic goes to both ports. | 0 = any<br>1 = p1<br>2 = p2<br>3 = undef | | 23 - 22 | error_code | This field indicates what kind of error caused the endpoint to be disabled. (note 2) | 0 = no_error<br>2 = bus_error<br>3 = buffer_error | | 21 | Reserved | - | 0 | | 20 - 11 | max_len | This field is the max packet length for isochronous data packets. | 1 - 1023 | | 10 - 7 | ep | This field gives the endpoint number. | | | 6 - 0 | dev | This field gives the configured device address. | | **Note 1:** This register is used for host mode isochronous endpoints. ## 18.16.24 R\_USB\_EPT\_DATA\_DEV ## **USB End Point Table Data Device Register, General Characteristics** | ID of register | R_USB_EPT_DATA_DEV | Size | 32 bits | |------------------|--------------------|---------------|------------| | Offset | 0x21C | Read/Write | Read/Write | | Register address | 0xB000021C | Initial value | 0x00000000 | ## Bit Assignments of R\_USB\_EPT\_DATA\_DEV | Bit(s) | Name | Description | State/Range | |---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------| | 31 | valid | This field indicates the validity of this table entry. | 0 = no<br>1 = yes | | 30 | hold | This field is used to tell software to stay off of this entry. Hardware will use it for more transactions. | 0 = no<br>1 = yes | | 29 | stall | This field stalls this endpoint. The device will respond with a stall-packet to all requests from the host for this endpoint. | 0 = no<br>1 = yes | | 28 | iso_resp | This field is only used for isochronous endpoints. If this field is <b>quiet</b> (0), do not send a broken packet in case DMA is unable to deliver data. If <b>iso_resp</b> is <b>yes</b> (1), start to send packet; if data is unavailable, send an abort. | 0 = quiet<br>1 = yes | | 27 | ctrl | This field indicates that this is a control endpoint. | 0 = no<br>1 = yes | | 26 | iso | This field tells whether or not the endpoint is isochronous. | 0 = no<br>1 = yes | | 25 - 24 | Reserved | - | 0 | | 23 | Reserved | - | 0 | | 22 | Reserved | - | 0 | | 21 | t | This is the toggle bit for device mode. | 0 - 1 | | 20 - 11 | max_len | This field is the max packet length for this endpoint. Note that there are constraints in the protocol on the max packet length. | 1 - 1023 | | 10 - 7 | ep | This field gives the endpoint number. | 0 - 15 | | 6 - 0 | dev | This field gives the configured device address. | 0 - 127 | **Note:** This register is used in device mode. ## 18.16.25 R\_USB\_EPID\_ATTN ## **USB End Point ID Attention Register, General Characteristics** | ID of register | R_USB_EPID_ATTN | Size | 32 bits | |------------------|-----------------|---------------|-----------| | Offset | 0x224 | Read/Write | Read only | | Register address | 0xB0000224 | Initial value | 0 | ## Bit Assignments of R\_USB\_EPID\_ATTN | Bit(s) | Name | Description | State/Range | |--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 31 - 0 | value | This register indicates which entries in the endpoint table have new information for software. Reading this register clears the ourun, perror, iso_eof, intr_eof, iso_eot, intr_eot, ctl_eot, bulk_eot, epid_attn, sof, port_status, ctl_status, out_eot, ep3_in_eot, ep3_in_e | | ## 18.16.26 R\_USB\_PORT1\_DISABLE ## **USB Port1 Disable Register, General Characteristics** | ID of register | R_USB_PORT1_DISABLE | Size | 8 bits | |------------------|---------------------|---------------|------------| | Offset | 0x6A | Read/Write | Write only | | Register address | 0xB000006A | Initial value | Unknown | ## Bit Assignments of R\_USB\_PORT1\_DISABLE | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 7 - 1 | Reserved | - | 0 | | 0 | disable | This register is used to force USB Port p1 to do a disconnect in order to emulate a port disable. To disable a port, software sets R_USB_PORT1_DISABLE to yes (0), and waits for R_USB_RH_PORT_STATUS_1 to show enabled = no (0). | 0 = yes<br>1 = no | **Note:** This register is only defined for the ETRAX 100LX v2 and v3. ## 18.16.27 R\_USB\_PORT2\_DISABLE ## **USB Port2 Disable Register, General Characteristics** | ID of register | R_USB_PORT2_DISABLE | Size | 8 bits | |------------------|---------------------|---------------|------------| | Offset | 0x52 | Read/Write | Write only | | Register address | 0xB0000052 | Initial value | Unknown | ## Bit Assignments of R\_USB\_PORT2\_DISABLE | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 7 - 1 | Reserved | - | 0 | | 0 | disable | This register is used to force USB Port p2 to do a disconnect in order to emulate a port disable. To disable a port, software sets R_USB_PORT2_DISABLE to yes (0), and waits for R_USB_RH_PORT_STATUS_2 to show enabled = $\mathbf{no}$ (0). | 0 = yes<br>1 = no | **Note:** This register is only defined for the ETRAX 100LX v2 and v3. ## 18.17 MMU Registers ## 18.17.1 R\_MMU\_CONFIG ### MMU Configuration Register, General Characteristics. | ID of register | R_MMU_CONFIG | Size | 32 bits | |----------------|--------------|---------------|------------| | Offset | 0x240 | Read/Write | Write only | | Address | 0xB0000240 | Initial value | 0 | ## Bit Assignments of R\_MMU\_CONFIG | Bit(s) | Name | Description | State/Range | |---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | 31 | mmu_enable | This field enables or disables the MMU. | 0 = disable<br>1 = enable | | 30 - 19 | Reserved | - | 0 | | 18 | inv_excp | This field enables and disables the MMU invalid page exception. When <code>inv_excp</code> is enabled, a matching TLB entry with the <code>valid</code> bit cleared generates an invalid page exception. When <code>inv_excp</code> is disabled, a TLB entry with the <code>valid</code> bit cleared is treated as a miss exception. <code>inv_excp</code> should be enabled only when the <code>valid</code> bit is used for functions such as reference counting. | 0 = disable<br>1 = enable | | 17 | acc_excp | This bit enables and disables the protection of kernel pages during the user mode. When acc_excp is disabled, the kernel bit in the TLB entry is ignored and cannot generate an access violation exception. All kernel pages can then be referenced in user mode as well. | 0 = disable<br>1 = enable | | 16 | we_excp | This bit enables and disables the write protection of pages for which the we bit in the TLB entry is disabled. When we_excp is disabled, the we bit in the TLB entry is ignored and cannot generate a write error exception. All pages are thus write enabled. | 0 = disable<br>1 = enable | | 15 | seg_f | In kernel mode, this field selects linear segment or page mapping for segment f. | 0 = page<br>1 = seg | | 14 | seg_e | In kernel mode, this field selects linear segment or page mapping for segment e. | 0 = page<br>1 = seg | | 13 | seg_d | In kernel mode, this field selects linear segment or page mapping for segment d. | 0 = page<br>1 = seg | | 12 | seg_c | In kernel mode, this field selects linear segment or page mapping for segment c. | 0 = page<br>1 = seg | | 11 | seg_b | In kernel mode, this field selects linear segment or page mapping for segment b. | 0 = page<br>1 = seg | | 10 | seg_a | In kernel mode, this field selects linear segment or page mapping for segment a. | 0 = page<br>1 = seg | | 9 | seg_9 | In kernel mode, this field selects linear segment or page mapping for segment 9. | 0 = page<br>1 = seg | | 8 | seg_8 | In kernel mode, this field selects linear segment or page mapping for segment 8. | 0 = page<br>1 = seg | #### **Bit Assignments of R\_MMU\_CONFIG (continued)** | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------|---------------------| | 7 | seg_7 | In kernel mode, this field selects linear segment or page mapping for segment 7. | 0 = page<br>1 = seg | | 6 | seg_6 | In kernel mode, this field selects linear segment or page mapping for segment 6. | 0 = page<br>1 = seg | | 5 | seg_5 | In kernel mode, this field selects linear segment or page mapping for segment 5. | 0 = page<br>1 = seg | | 4 | seg_4 | In kernel mode, this field selects linear segment or page mapping for segment $4$ . | 0 = page<br>1 = seg | | 3 | seg_3 | In kernel mode, this field selects linear segment or page mapping for segment 3. | 0 = page<br>1 = seg | | 2 | seg_2 | In kernel mode, this field selects linear segment or page mapping for segment 2. | 0 = page<br>1 = seg | | 1 | seg_1 | In kernel mode, this field selects linear segment or page mapping for segment 1. | 0 = page<br>1 = seg | | 0 | seg_0 | In kernel mode, this field selects linear segment or page mapping for segment 0. | 0 = page<br>1 = seg | ## 18.17.2 R\_MMU\_KSEG ## **MMU Kernel Segment Register, General Characteristics** | ID of register | R_MMU_KSEG | Size | 16 bits | |----------------|------------|---------------|------------| | Offset | 0x240 | Read/Write | Write only | | Address | 0xB0000240 | Initial value | 0 | ## Bit Assignments of R\_MMU\_KSEG | Bit(s) | Name | Description | State/Range | |--------|-------|-------------------------------------------------------------------------------------------------|---------------------| | 15 | seg_f | In kernel mode, this field selects linear segment or page mapping for segment f. | 0 = page<br>1 = seg | | 14 | seg_e | In kernel mode, this field selects linear segment or page mapping for segment e. | 0 = page<br>1 = seg | | 13 | seg_d | In kernel mode, this field selects linear segment or page mapping for segment d. | 0 = page<br>1 = seg | | 12 | seg_c | In kernel mode, this field selects linear segment or page mapping for segment c. | 0 = page<br>1 = seg | | 11 | seg_b | In kernel mode, this field selects linear segment or page mapping for segment b. | 0 = page<br>1 = seg | | 10 | seg_a | In kernel mode, this field selects linear segment or page mapping for segment a. | 0 = page<br>1 = seg | | 9 | seg_9 | In kernel mode, this field selects linear segment or page mapping for segment 9. | 0 = page<br>1 = seg | | 8 | seg_8 | In kernel mode, this field selects linear segment or page mapping for segment 8. | 0 = page<br>1 = seg | | 7 | seg_7 | In kernel mode, this field selects linear segment or page mapping for segment 7. | 0 = page<br>1 = seg | | 6 | seg_6 | In kernel mode, this field selects linear segment or page mapping for segment 6. | 0 = page<br>1 = seg | | 5 | seg_5 | In kernel mode, this field selects linear segment or page mapping for segment 5. | 0 = page<br>1 = seg | | 4 | seg_4 | In kernel mode, this field selects linear segment or page mapping for segment 4. | 0 = page<br>1 = seg | | 3 | seg_3 | In kernel mode, this field selects linear segment or page mapping for segment 3. | 0 = page<br>1 = seg | | 2 | seg_2 | In kernel mode, this field selects linear segment or page mapping for segment 2. | 0 = page<br>1 = seg | | 1 | seg_1 | In kernel mode, this field selects linear segment or page mapping for segment 1. | 0 = page<br>1 = seg | | 0 | seg_0 | In kernel mode, this field selects linear segment or page mapping for segment $\boldsymbol{0}.$ | 0 = page<br>1 = seg | **Note:** R\_MMU\_KSEG is a 16-bit register that is part of configuration register R\_MMU\_CONFIG. ## 18.17.3 R\_MMU\_CTRL ## **MMU Control Register, General Characteristics** | ID of register | R_MMU_CTRL | Size | 8 bits | |----------------|------------|---------------|------------| | Offset | 0x242 | Read/Write | Write only | | Address | 0xB0000242 | Initial value | 0 | ## Bit Assignments of R\_MMU\_CTRL | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | 7 - 3 | Reserved | - | 0 | | 2 | inv_excp | This field enables and disables the MMU invalid page exception. When <code>inv_excp</code> is enabled, a matching TLB entry with the <code>valid</code> bit cleared generates an invalid page exception. When <code>inv_excp</code> is disabled, a TLB entry with the <code>valid</code> bit cleared is treated as a miss exception. <code>inv_excp</code> should be enabled only when the <code>valid</code> bit is used for functions such as reference counting. | 0 = disable<br>1 = enable | | 1 | acc_excp | This field enables and disables the protection of kernel pages during the user mode. When acc_excp is disabled, the kernel bit in the TLB entry is ignored and cannot generate an access violation exception. All kernel pages can then be referenced in user mode as well. | 0 = disable<br>1 = enable | | 0 | we_excp | This field enables and disables the write protection of pages for which the we bit in the TLB entry is disabled. When we_excp is disabled, the we bit in the TLB entry is ignored and cannot generate a write error exception. All pages are thus write enabled. | 0 = disable<br>1 = enable | **Note:** R\_MMU\_CTRL is a byte (8-bit) register that is part of configuration register R\_MMU\_CONFIG. ## 18.17.4 R\_MMU\_ENABLE ## **MMU Enable Register, General Characteristics** | ID of register | R_MMU_ENABLE | Size | 8 bits | |----------------|--------------|---------------|------------| | Offset | 0x243 | Read/Write | Write only | | Address | 0xB0000243 | Initial value | 0 | ## Bit Assignments of R\_MMU\_ENABLE | Bit(s) | Name | Description | State/Range | |--------|------------|---------------------------------------|---------------------------| | 7 | mmu_enable | This bit enables or disables the MMU. | 0 = disable<br>1 = enable | | 6 - 0 | Reserved | - | 0 | **Note:** $R\_MMU\_ENABLE$ is a byte (8-bit) register that is part of configuration register $R\_MMU\_CONFIG.$ ## 18.17.5 R\_MMU\_KBASE\_LO ## **MMU Kernel Base Low Register, General Characteristics** | ID of register | R_MMU_KBASE_LO | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x244 | Read/Write | Write only | | Address | 0xB0000244 | Initial value | Unknown | ## Bit Assignments of R\_MMU\_KBASE\_LO | Bit(s) | Name | Description | State/Range | |---------|--------|-----------------------------------------------------------------|-------------| | 31 - 28 | base_7 | The value of these field selects the kernel base for segment 7. | 0 - 15 | | 27 - 24 | base_6 | The value of these field selects the kernel base for segment 6. | 0 - 15 | | 23 - 20 | base_5 | The value of these field selects the kernel base for segment 5. | 0 - 15 | | 19 - 16 | base_4 | The value of these field selects the kernel base for segment 4. | 0 - 15 | | 15 - 12 | base_3 | The value of these field selects the kernel base for segment 3. | 0 - 15 | | 11 - 8 | base_2 | The value of these field selects the kernel base for segment 2. | 0 - 15 | | 7 - 4 | base_1 | The value of these field selects the kernel base for segment 1. | 0 - 15 | | 3 - 0 | base_0 | The value of these field selects the kernel base for segment 0. | 0 - 15 | ## 18.17.6 R\_MMU\_KBASE\_HI ## **MMU Kernel Base High Register, General Characteristics** | ID of register | R_MMU_KBASE_HI | Size | 32 bits | |----------------|----------------|---------------|------------| | Offset | 0x248 | Read/Write | Write only | | Address | 0xB0000248 | Initial value | Unknown | ## Bit Assignments of R\_MMU\_KBASE\_HI | Bit(s) | Name | Description | State/Range | |---------|--------|-----------------------------------------------------------------|-------------| | 31 - 28 | base_f | The value of these field selects the kernel base for segment f. | 0 - 15 | | 27 - 24 | base_e | The value of these field selects the kernel base for segment e. | 0 - 15 | | 23 - 20 | base_d | The value of these field selects the kernel base for segment d. | 0 - 15 | | 19 - 16 | base_c | The value of these field selects the kernel base for segment c. | 0 - 15 | | 15 - 12 | base_b | The value of these field selects the kernel base for segment b. | 0 - 15 | | 11 - 8 | base_a | The value of these field selects the kernel base for segment a. | 0 - 15 | | 7 - 4 | base_9 | The value of these field selects the kernel base for segment 9. | 0 - 15 | | 3 - 0 | base_8 | The value of these field selects the kernel base for segment 8. | 0 - 15 | ## 18.17.7 R\_MMU\_CONTEXT ## **MMU Context Register, General Characteristics** | ID of register | R_MMU_CONTEXT | Size | 8 bits | |----------------|---------------|---------------|------------| | Offset | 0x24C | Read/Write | Read/Write | | Address | 0xB000024C | Initial value | Unknown | ## Bit Assignments of R\_MMU\_CONTEXT | Bit(s) | Name | Description | State/Range | |--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 6 | Reserved | - | 0 | | 5 - 0 | page_id | The value of this field is the page identification of the current context. A page can only be referenced if the <code>page_id</code> field in this register matches the <code>page_id</code> field in the TLB entry, unless the <code>global</code> bit in the TLB entry is set. | 0 - 63 | ## 18.17.8 R\_MMU\_CAUSE #### **MMU Cause Register, General Characteristics** | ID of register | R_MMU_CAUSE | Size | 32 bits | |----------------|-------------|---------------|-----------| | Offset | 0x250 | Read/Write | Read only | | Address | 0xB0000250 | Initial value | Unknown | #### Bit Assignments of R\_MMU\_CAUSE | Bit(s) | Name | Description | State/Range | |---------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | 31 - 13 | vpn | This field represents a virtual page number. When an MMU exception occurs, this field is updated with the <b>vpn</b> of the referenced address that generated the exception. | | | 12 | miss_excp | This field indicates the occurrence of a miss exception. When set, the field signifies that the referenced address did not match any TLB entry. A valid entry must be loaded by software. | 0 = no<br>1 = yes | | 11 | inv_excp | This field indicates the occurrence of an invalid page exception. When set, the field signifies that reference was made to a page with matching <b>vpn</b> and <b>page_id</b> fields in the TLB, but the <b>valid</b> bit in the TLB entry was cleared. The <b>inv_excp</b> bit can be used for reference counting. | 0 = no<br>1 = yes | | 10 | acc_excp | This field indicates the occurrence of an access violation exception. When set, the field signifies that a reference from user mode was made to a page with the <b>kernel</b> bit set in the TLB entry. This is used to protect mapped kernel pages from user mode references. | 0 = no<br>1 = yes | | 9 | we_excp | This field indicates the occurrence of a write error exception. When set, the field signifies that during a write operation, reference was made to a page for which the we bit in the TLB entry was cleared. This exception can be used for both write protection and dirty checks. | 0 = no<br>1 = yes | | 8 | wr_rd | This field is updated when a memory management exception occurs. It indicates whether the exception was caused by a write or read access. | 0 = read<br>1 = write | | 7 - 6 | Reserved | ie. | 0 | | 5 - 0 | page_id | This field represents a page identification. The field is updated when an MMU exception occurs, and holds the content of the <code>page_id</code> in <code>R_MMU_CONTEXT</code> . | 0 - 63 | #### Note: This register is also used to store the contents of $R\_TLB\_HI$ , and its contents are destroyed when writing to $R\_TLB\_HI$ . Register $R\_MMU\_CAUSE$ is updated when an MMU exception occurs, identifying the cause of the exception. When $R\_TLB\_LO$ is written, the page\_id and vpn fields of $R\_MMU\_CAUSE$ are written into the TLB using the index field in register $R\_TLB\_SELECT$ . ## 18.17.9 R\_TLB\_SELECT #### **MMU TLB Select Register, General Characteristics** | ID of register | R_TLB_SELECT | Size | 8 bits | |----------------|--------------|---------------|------------| | Offset | 254 | Read/Write | Read/Write | | Address | 0xB0000254 | Initial value | Unknown | #### Bit Assignments of R\_TLB\_SELECT | Bit(s) | Name | Description | State/Range | |--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 7 - 6 | Reserved | - | 0 | | 5 - 0 | index | The value of this field represents the TLB index. The index field selects the TLB entry to use when registers R_TLB_LO and R_TLB_HI are used. In the event of a miss exception, the index is loaded with a random value which selects the entry to replace. The random value is always a valid index for the faulting virtual address. All other exceptions load the index field with a pointer to the entry that triggered the exception. | 0 - 63 | #### 18.17.10 R\_TLB\_LO #### **MMU TLB Low Register, General Characteristics** | ID of register | R_TLB_LO | Size | 32 bits | |----------------|------------|---------------|------------| | Offset | 0x258 | Read/Write | Read/Write | | Address | 0xB0000258 | Initial value | Unknown | #### Bit Assignments of R\_TLB\_LO | Bit(s) | Name | Description | State/Range | |---------|----------|------------------------------------------------------------|-------------------| | 31 - 13 | pfn | This field represents a physical frame number <b>pfn</b> . | | | 12 - 4 | Reserved | - | 0 | | 3 | global | This field is the <b>global</b> bit of the TLB entry. | 0 = no<br>1 = yes | | 2 | valid | This field is the <b>valid</b> bit of the TLB entry. | 0 = no<br>1 = yes | | 1 | kernel | This field is the <b>kernel</b> bit of the TLB entry. | 0 = no<br>1 = yes | | 0 | we | This field is the <b>we</b> bit of the TLB entry. | 0 = no<br>1 = yes | #### Note: R\_TLB\_LO is used for reading and writing the lower part of an entry in the TLB. When this register is read, the **pfn**, **global**, **valid**, **kernel** and **we** fields of the TLB entry selected by the **index** field in R\_TLB\_SELECT will be read. When writing to R\_TLB\_LO, this value selected by the **index** field plus the **page\_id** and **vpn** fields in R\_MMU\_CAUSE, are written into the TLB entry selected by the **index** field in R\_TLB\_SELECT. #### 18.17.11 R\_TLB\_HI #### **MMU TLB High Register, General Characteristics** | ID of register | R_TLB_HI | Size | 32 bits | |----------------|------------|---------------|------------| | Offset | 0x25C | Read/Write | Read/Write | | Address | 0xB000025C | Initial value | Unknown | #### Bit Assignments of R\_TLB\_HI | Bit(s) | Name | Description | State/Range | |---------|----------|--------------------------------------------------|-------------| | 31 - 13 | vpn | This field gives the virtual page number. | | | 12 - 6 | Reserved | - | 0 | | 5 - 0 | page_id | This field gives the page identification number. | 0 - 63 | #### Note: R\_TLB\_HI is used for reading and writing the high part of an entry in the TLB. When this register is read, the $page\_id$ and vpn fields of the TLB entry selected by the index field in R\_TLB\_SELECT will be read. When writing to R\_TLB\_HI, this value selected by the index field is stored in the corresponding fields of R\_MMU\_CAUSE. When R\_TLB\_LO is written, the fields in R\_MMU\_CAUSE will be written into the TLB. The previous contents of R\_MMU\_CAUSE will be destroyed when writing to R\_TLB\_HI. ## 18.18 Synchronous Serial Port Registers #### 18.18.1 R\_SYNC\_SERIAL1\_REC\_DATA # Synchronous Serial Port 1 Receive Data Register, General Characteristics | ID of register | R_SYNC_SERIAL1_REC_DATA | Size | 32 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x6C | Read/Write | Read only | | Register address | 0xB000006C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_REC\_DATA | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------------------------------------------------|-------------| | 31 - 0 | data_in | This field contains 32 bits of data from the Synchronous Serial Port p1 receiver. | | #### 18.18.2 R\_SYNC\_SERIAL1\_REC\_WORD # Synchronous Serial Port 1 Receive 16-bit Data Register, General Characteristics | ID of register | R_SYNC_SERIAL1_REC_WORD | Size | 16 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x6C | Read/Write | Read only | | Register address | 0xB000006C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_REC\_WORD | Bit(s) | Name | Description | State/Range | |--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_in | This field contains 16 bits of data in from the Synchronous Serial Port p1 receiver. The state/range for data_in depends on the wordsize field in "R_SYNC_SERIAL1_CTRL". | 0 - 65535 | **Note:** This 16-bit wide register is part of the 32-bit R\_SYNC\_SERIAL1\_REC\_DATA register. #### 18.18.3 R\_SYNC\_SERIAL1\_REC\_BYTE # Synchronous Serial Port 1 Receive Byte Register, General Characteristics | ID of register | R_SYNC_SERIAL1_REC_BYTE | Size | 8 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x6C | Read/Write | Read only | | Register address | 0xB000006C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_REC\_BYTE | Bit(s) | Name | Description | State/Range | |--------|---------|-------------------------------------------------------------------------------------|-------------| | 7 - 0 | data_in | This field contains a byte of data in from the Synchronous Serial Port p1 receiver. | 0 - 255 | **Note:** This 8-bit wide register is part of the 32-bit R\_SYNC\_SERIAL1\_REC\_DATA register. #### 18.18.4 R\_SYNC\_SERIAL1\_STATUS #### Synchronous Serial Port 1 Status Register, General Characteristics | ID of register | R_SYNC_SERIAL1_STATUS | Size | 32 bits | |------------------|-----------------------|---------------|-----------| | Offset | 0x68 | Read/Write | Read only | | Register address | 0xB0000068 | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_STATUS | Bit(s) | Name | Description | State/Range | |---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 16 | Reserved | - | 0 | | 15 | rec_status | This field indicates whether the Synchronous Serial Port p1 receiver is running. If so, data may be arriving which may generate interrupts or activate the DMA channel. | 0 = running<br>1 = idle | | 14 | tr_empty | This field indicates whether the transmitter data pipeline of Synchronous Serial Port p1 is empty. When set to <b>empty</b> (1), nothing more is sent unless new data is written to the output register or transferred by DMA to the transmitter. | 1 = empty<br>0 = not_empty | | 13 | tr_ready | This field indicates whether the transmitter of Synchronous Serial Port p1 is ready. When set to <b>ready</b> (1), either 32, 16 or 8 bits of data can be written to the serial transmitter. | 0 = full<br>1 = ready | | 12 | pin_1 | This field is the value on input from ss1_in2. (note) | 0 = low<br>1 = high | | 11 | pin_0 | This field is the value on input from ss1_in1. (note) | 0 = low<br>1 = high | | 10 | underflow | This field is set when an underflow error is detected in the transmitter of Synchronous Serial Port p1. The field is cleared when the register R_SYNC_SERIAL1_STATUS is read. | 0 = no<br>1 = yes | | 9 | overrun | This field is set when an overrun error is detected in the Synchronous Serial Port p1 receiver. The field is cleared when the register R_SYNC_SERIAL1_STATUS is read. | 0 = no<br>1 = yes | | 8 | data_avail | This field is set when data is available from the Synchronous Serial Port p1 receiver. The bit is cleared when the R_SYNC_SERIAL1_REC_DATA register is read. | 0 = no<br>1 = yes | | 7 - 0 | Reserved | - | Unknown | **Note:** For more information about pin usage see chapter 12 Synchronous Serial Interface. #### 18.18.5 R\_SYNC\_SERIAL1\_TR\_DATA # Synchronous Serial Port 1 Transmit 32-bit Data Register, General Characteristics | ID of register | R_SYNC_SERIAL1_TR_DATA | Size | 32 bits | |------------------|------------------------|---------------|------------| | Offset | 0x6C | Read/Write | Write only | | Register address | 0xB000006C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_TR\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------|-------------| | 31 - 0 | data_out | This field gives 32 bits of data to the transmitter of Synchronous Serial Port p1. | | #### 18.18.6 R\_SYNC\_SERIAL1\_TR\_WORD # Synchronous Serial Port 1 Transmit 16-bit Data Register, General Characteristics | ID of register | R_SYNC_SERIAL1_TR_WORD | Size | 16 bits | |------------------|------------------------|---------------|------------| | Offset | 0x6C | Read/Write | Write only | | Register address | 0xB000006C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_TR\_WORD | Bit(s) | Name | Description | State/Range | |--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_out | This field contains 16 bits of data in from the Synchronous Serial Port p1 receiver. The state/range for data_out depends on the wordsize field in "R_SYNC_SERIAL1_CTRL". | 0 - 65535 | **Note:** This 16-bit wide register is part of the 32-bit R\_SYNC\_SERIAL1\_TR\_DATA register. #### 18.18.7 R\_SYNC\_SERIAL1\_TR\_BYTE # Synchronous Serial Port 1 Transmit Byte Register, General Characteristics | ID of register | R_SYNC_SERIAL1_TR_BYTE | Size | 8 bits | |------------------|------------------------|---------------|------------| | Offset | 0x6C | Read/Write | Write only | | Register address | 0xB000006C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_TR\_BYTE | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------|-------------| | 7 - 0 | data_out | This field gives a byte of data to the transmitter of Synchronous Serial Port p1. | 0 - 255 | **Note:** This 8-bit wide register is part of the 32-bit R\_SYNC\_SERIAL1\_TR\_DATA register. #### 18.18.8 R\_SYNC\_SERIAL1\_CTRL #### **Synchronous Serial Port 1 Control Register, General Characteristics** | ID of register | R_SYNC_SERIAL1_CTRL | Size | 32 bits | |------------------|---------------------|---------------|--------------------------------------------------| | Offset | 0x68 | Read/Write | Write only | | Register address | 0xB0000068 | Initial value | Bit 14 and 22 set to<br>0. Other bits<br>unknown | #### Bit Assignments of R\_SYNC\_SERIAL1\_CTRL | Bit(s) | Name | Description | State/Range | |---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 28 | tr_baud | The value in this field is the bit clock if <b>baudrate</b> clock is selected in register R_SYNC_SERIAL_PRESCALE. | 0 = c150Hz<br>1 = c300Hz<br>2 = c600Hz<br>3 = c1200Hz<br>4 = c2400Hz<br>5 = c4800Hz<br>6 = c9600Hz<br>7 = c19k2Hz<br>8 = c28k8Hz<br>9 = c57k6Hz<br>10 = c115k2Hz<br>11 = c230k4Hz<br>12 = c460k8Hz<br>13 = c921k6Hz<br>14 = c3125kHz<br>15 = reserved | | 27 | dma_enable | This field determines whether Synchronous Serial Port p1 should transfer data with DMA or by CPU accesses. | 0 = off<br>1 = on | | 26 - 24 | mode | The value in this field represents the mode selection command to Synchronous Serial Port p1: master - ETRAX generates clock and frame signals. slave - ETRAX listens to clock and frame signals. input - ETRAX receives data. output - ETRAX transmits data. bidir - ETRAX receives and transmits data. Note that Synchronous Serial Port p1 pin usage is changed when the value of the mode field is changed. Refer to chapter 13 Synchronous Serial Interface more information. | 0 = master_output<br>1 = slave_output<br>2 = master_input<br>3 = slave_input<br>4 = master_bidir<br>5 = slave_bidir | | 23 | еггог | This field determines whether transfer and receiver errors are ignored for Synchronous Serial Port p1: When set to <b>normal</b> (0), transmission is stopped when an underflow or overrun condition is detected. When set to <b>ignore</b> (1), transfer and receiver errors are ignored. The underflow and overrun fields are set, but the transmission is not halted. | 0 = normal<br>1 = ignore | | 22 | rec_enable | This field enables or disables incoming data. | 0 = disable<br>1 = enable | | 21 | f_synctype | This field determines frame sync activity for Synchronous Serial Port p1: normal - the frame sync signal is active during the first bit of the word. early - the frame sync signal is active 1 bit before the first bit of the word. | 0 = normal<br>1 = early | #### Bit Assignments of R\_SYNC\_SERIAL1\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | 20 - 19 | f_syncsize | This field determines frame sync size for Synchronous Serial Port p1: bit - the frame sync signal is active during first bit of the word. word - the frame sync signal is active over the entire word. extended - the frame sync signal is active over the entire word plus 1 bit. When sending a non-interrupted stream of data, frame sync will be continuously high. | 0 = bit<br>1 = word<br>2 = extended<br>3 = reserved | | 18 | f_sync | This field enables or disables frame sync for Synchronous Serial Port p1: on - The frame sync is enabled. off - The frame sync is ignored. Incoming and outgoing data are treated as a bitstream. | 0 = on<br>1 = off | | 17 | clk_mode | This field selects the clock mode for Synchronous Serial Port p1: normal - The clock is running continuously. gated - The clock is turned off when no data is transmitted. | 0 = normal<br>1 = gated | | 16 | clk_halt | This field stops the clock for Synchronous Serial Port p1. When set to <b>stopped</b> (1), the frame sync generator is stopped. | 0 = running<br>1 = stopped | | 15 | bitorder | This field chooses whether the lsb or the msb is sent first for Synchronous Serial Port p1. | 0 = lsb<br>1 = msb | | 14 | tr_enable | This field enables or disables outgoing data for Synchronous Serial Port p1. | 0 = disable<br>1 = enable | | 13 - 11 | wordsize | This field selects data unit size for Synchronous Serial Port p1. | 0 = size8bit<br>1 = size12bit<br>2 = size16bit<br>3 = size24bit<br>4 = size32bit | | 10 | buf_empty | This field is the buffer empty flow control status indicator for Synchronous Serial Port p1. <b>ss1status</b> is active if no more than 0 or 8 bytes remain in the output DMA FIFO buffer. | 0 = lmt_8<br>1 = lmt_0 | | 9 | buf_full | This field is the buffer full flow control status indicator for Synchronous Serial Port p1. <b>ss1status</b> is active if no more than 32 or 8 bytes of storage are free in the input DMA FIFO buffer. | 0 = lmt_32<br>1 = lmt_8 | | 8 | flow_ctrl | This field enables or disables flow control for Synchronous Serial Port p1. If the handling of status input and output signals becomes congested, frame or word start can be delayed when this field is set to <b>enabled</b> (1). | 0 = disabled<br>1 = enabled | | 7 | Reserved | - | 0 | | 6 | clk_polarity | This field selects the polarity of the sample edge of the incoming clock for Synchronous Serial Port p1. | 0 = pos<br>1 = neg | | 5 | frame_polarity | This field selects the polarity of the incoming frame signal for Synchronous Serial Port p1. When set to <b>normal</b> (0), the frame signal is active high. | 0 = normal<br>1 = inverted | | 4 | status_polarity | This field selects the polarity of the incoming status signal for Synchronous Serial Port p1. When set to <b>normal (0)</b> , the status signal is active high. | 0 = normal<br>1 = inverted | #### Bit Assignments of R\_SYNC\_SERIAL1\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 3 | clk_driver | This field selects the polarity of the outgoing clock signal for Synchronous Serial Port p1: normal - the internal reference clock signal is connected directly to the clock output. inverted - the internal reference clock signal is inverted and connected to the clock output. | 0 = normal<br>1 = inverted | | 2 | frame_driver | This field selects the polarity of the outgoing frame signal for Synchronous Serial Port p1: normal - the internal reference frame signal is connected directly to the status output. inverted - the internal reference frame signal is inverted and connected to the frame output. | 0 = normal<br>1 = inverted | | 1 | status_driver | This field selects the polarity of the outgoing status signal for Synchronous Serial Port p1: normal - the internal reference status signal is connected directly to the status output. inverted - the internal reference status signal is inverted and connected to the status output. | 0 = normal<br>1 = inverted | | 0 | def_out0 | This field is the value of the <b>ss1_out1</b> output pin when Serial Port p1 is enabled, but a sync serial mode is selected where the pin has no meaning/function (it is a spare pin given the configuration). | 0 = low<br>1 = high | #### 18.18.9 R\_SYNC\_SERIAL3\_REC\_DATA # Synchronous Serial Port 3 Receive 32-bit Data Register, General Characteristics | ID of register | R_SYNC_SERIAL3_REC_DATA | Size | 32 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x7C | Read/Write | Read only | | Register address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_REC\_DATA | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------------------------------------------------|-------------| | 31 - 0 | data_in | This field contains 32 bits of data from the Synchronous Serial Port p3 receiver. | | #### 18.18.10 R\_SYNC\_SERIAL3\_REC\_WORD # Synchronous Serial Port 3 Receive 16-bit Data Register, General Characteristics | ID of register | R_SYNC_SERIAL3_REC_WORD | Size | 16 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x7C | Read/Write | Read only | | Register address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_REC\_WORD | Bit(s) | Name | Description | State/Range | |--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_in | This field contains 16 bits of data from the Synchronous Serial Port p3 receiver. The state/range for data_in depends on the wordsize field in "R_SYNC_SERIAL3_CTRL". | 0 - 65535 | **Note:** This 16-bit wide register is part of the 32-bit R\_SYNC\_SERIAL3\_REC\_DATA register. #### 18.18.11 R\_SYNC\_SERIAL3\_REC\_BYTE # Synchronous Serial Port 3 Receive Byte Register, General Characteristics | ID of register | R_SYNC_SERIAL3_REC_BYTE | Size | 8 bits | |------------------|-------------------------|---------------|-----------| | Offset | 0x7C | Read/Write | Read only | | Register address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_REC\_BYTE | Bit(s) | Name | Description | State/Range | |--------|---------|-------------------------------------------------------------------------------------|-------------| | 7 - 0 | data_in | This field contains a byte of data in from the Synchronous Serial Port p3 receiver. | 0 - 255 | **Note:** This 8-bit wide register is part of the 32-bit R\_SYNC\_SERIAL3\_REC\_DATA register. #### 18.18.12 R\_SYNC\_SERIAL3\_STATUS #### Synchronous Serial Port 3 Status Register, General Characteristics | ID of register | R_SYNC_SERIAL3_STATUS | Size | 32 bits | |------------------|-----------------------|---------------|-----------| | Offset | 0x78 | Read/Write | Read only | | Register address | 0xB0000078 | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_STATUS | Bit(s) | Name | Description | State/Range | |---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 31 - 16 | Reserved | - | 0 | | 15 | rec_status | This field indicates whether the Synchronous Serial Port p3 receiver is running. If so, data may be arriving which may generate interrupts or activate the DMA channel. | 0 = running<br>1 = idle | | 14 | tr_empty | This field indicates whether the transmitter data pipeline of Synchronous Serial Port p3 is empty. When set to <b>empty</b> (1), nothing more is sent unless new data is written to the output register or transferred by DMA to the transmitter. | 1 = empty<br>0 = not_empty | | 13 | tr_ready | This field indicates whether the transmitter of Synchronous Serial Port p3 is ready. When set to <b>ready</b> (1), either 32, 16 or 8 bits of data can be written to the serial transmitter. | 0 = full<br>1 = ready | | 12 | pin_1 | This field is the value on input from ss3_in2. (note) | 0 = low<br>1 = high | | 11 | pin_0 | This field is the value on input from ss3_in1. (note) | 0 = low<br>1 = high | | 10 | underflow | This field is set when an underflow error is detected in the transmitter of Synchronous Serial Port p3. The field is cleared when the register R_SYNC_SERIAL3_STATUS is read. | 0 = no<br>1 = yes | | 9 | overrun | This field is set when an overrun error is detected in the Synchronous Serial Port p3 receiver. The field is cleared when the register R_SYNC_SERIAL3_STATUS is read. | 0 = no<br>1 = yes | | 8 | data_avail | This field is set when data is available from the Synchronous Serial Port p3 receiver. The bit is cleared when the register R_SYNC_SERIAL3_REC_DATA is read. | 0 = no<br>1 = yes | | 7 - 0 | Reserved | - | 0 | **Note:** For more information about pin usage see chapter 13 Synchronous Serial Interface. #### 18.18.13 R\_SYNC\_SERIAL3\_TR\_DATA # **Synchronous Serial Port 3 Transmit Data Register, General Characteristics** | ID of register | R_SYNC_SERIAL3_TR_DATA | Size | 32 bits | |------------------|------------------------|---------------|------------| | Offset | 0x7C | Read/Write | Write only | | Register address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_TR\_DATA | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------|-------------| | 31 - 0 | data_out | This field gives 32 bits of data to the transmitter of Synchronous Serial Port p3. | | #### 18.18.14 R\_SYNC\_SERIAL3\_TR\_WORD # Synchronous Serial Port 3 Transmit 16-bit Data Register, General Characteristics | ID of register | R_SYNC_SERIAL3_TR_WORD | Size | 16 bits | |------------------|------------------------|---------------|------------| | Offset | 0x7C | Read/Write | Write only | | Register address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_TR\_WORD | Bit(s) | Name | Description | State/Range | |--------|----------|------------------------------------------------------------------------------------|-------------| | 15 - 0 | data_out | This field gives 16 bits of data to the transmitter of Synchronous Serial Port p3. | 0 - 65535 | **Note:** This 16-bit wide register is part of the 32-bit R\_SYNC\_SERIAL3\_TR\_DATA register. #### 18.18.15 R\_SYNC\_SERIAL3\_TR\_BYTE # Synchronous Serial Port 3 Transmit Byte Register, General Characteristics | ID of register | R_SYNC_SERIAL3_TR_BYTE | Size | 8 bits | |------------------|------------------------|---------------|------------| | Offset | 0x7C | Read/Write | Write only | | Register address | 0xB000007C | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_TR\_BYTE | Bit(s) | Name | Description | State/Range | |--------|----------|-----------------------------------------------------------------------------------|-------------| | 7 - 0 | data_out | This field gives a byte of data to the transmitter of Synchronous Serial Port p3. | 0 - 255 | **Note:** This 8-bit wide register is part of the 32-bit R\_SYNC\_SERIAL3\_TR\_DATA register. #### 18.18.16 R\_SYNC\_SERIAL3\_CTRL #### **Synchronous Serial Port 3 Control Register, General Characteristics** | ID of register | R_SYNC_SERIAL3_CTRL | Size | 32 bits | |------------------|---------------------|---------------|-------------------------------------------------------| | Offset | 0x78 | Read/Write | Write only | | Register address | 0xB0000078 | Initial value | Bits 14 and 22 are<br>set to 0. Other bits<br>unknown | #### Bit Assignments of R\_SYNC\_SERIAL3\_CTRL | Bit(s) | Name | Description | State/Range | |---------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 - 28 | tr_baud | The value in this field is the bit clock if <b>baudrate</b> clock is selected in register R_SYNC_SERIAL_PRESCALE. | 0 = c150Hz<br>1 = c300Hz<br>2 = c600Hz<br>3 = c1200Hz<br>4 = c2400Hz<br>5 = c4800Hz<br>6 = c9600Hz<br>7 = c19k2Hz<br>8 = c28k8Hz<br>9 = c57k6Hz<br>10 = c115k2Hz<br>11 = c230k4Hz<br>12 = c460k8Hz<br>13 = c921k6Hz<br>14 = c3125kHz<br>15 = reserved | | 27 | dma_enable | This field determines whether Synchronous Serial Port p3 should transfer data with DMA or by CPU accesses. | 0 = off<br>1 = on | | 26 - 24 | mode | The value in this field represents the mode selection command to Synchronous Serial Port p3: master - ETRAX generates clock and frame signals. slave - ETRAX listens to clock and frame signals. input - ETRAX receives data. output - ETRAX transmits data. bidir - ETRAX receives and transmits data. Note that Synchronous Serial Port p3 pin usage is changed when the value of the mode field is changed. Refer to chapter 13 Synchronous Serial Interface for more information. | 0 = master_output<br>1 = slave_output<br>2 = master_input<br>3 = slave_input<br>4 = master_bidir<br>5 = slave_bidir | | 23 | еггог | This field determines whether transfer and receiver errors are ignored for Synchronous Serial Port p3: When set to <b>normal</b> (0), transmission is stopped when an underflow or overrun condition is detected. When set to <b>ignore</b> (1), transfer and receiver errors are ignored. The underflow and overrun fields are set, but the transmission is not halted. | 0 = normal<br>1 = ignore | | 22 | rec_enable | This field enables or disables incoming data. | 0 = disable<br>1 = enable | | 21 | f_synctype | This field determines frame sync activity for Synchronous Serial Port p3: normal - the frame sync signal is active during the first bit of the word. early - the frame sync signal is active 1 bit before the first bit of the word. | 0 = normal<br>1 = early | #### Bit Assignments of R\_SYNC\_SERIAL3\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | 20 - 19 | f_syncsize | This field determines frame sync size for Synchronous Serial Port p3: bit - the frame sync signal is active during first bit of the word. word - the frame sync signal is active over the entire word. extended - the frame sync signal is active over the entire word plus 1 bit. When sending a non-interrupted stream of data, frame sync will be continuously high. | 0 = bit<br>1 = word<br>2 = extended<br>3 = reserved | | 18 | f_sync | This field enables or disables frame sync for Synchronous Serial Port p3: on - The frame sync is enabled. off - The frame sync is ignored. Incoming and outgoing data are treated as a bitstream. | 0 = on<br>1 = off | | 17 | clk_mode | This field selects the clock mode for Synchronous Serial Port p3: normal - The clock is running continuously. gated - The clock is turned off when no data is transmitted. | 0 = normal<br>1 = gated | | 16 | clk_halt | This field stops the clock for Synchronous Serial Port p3. When set to <b>stopped</b> (1), the frame sync generator is temporarily stopped. | 0 = running<br>1 = stopped | | 15 | bitorder | This field chooses whether the lsb or the msb is sent first for Synchronous Serial Port p3. | 0 = lsb<br>1 = msb | | 14 | tr_enable | This field enables or disables outgoing data for Synchronous Serial Port p3. | 0 = disable<br>1 = enable | | 13 - 11 | wordsize | This field selects data unit size for Synchronous Serial Port p3. | 0 = size8bit<br>1 = size12bit<br>2 = size16bit<br>3 = size24bit<br>4 = size32bit | | 10 | buf_empty | This field is the buffer empty flow control status indicator for Synchronous Serial Port p3. <b>ss3status</b> is active if no more than 0 or 8 bytes remain in the output DMA FIFO buffer. | 0 = lmt_8<br>1 = lmt_0 | | 9 | buf_full | This field is the buffer full flow control status indicator for Synchronous Serial Port p3. <b>ss3status</b> is active if no more than 32 or 8 bytes of storage are free in the input DMA FIFO buffer. | 0 = lmt_32<br>1 = lmt_8 | | 8 | flow_ctrl | This field enables or disables flow control for Synchronous Serial Port p3. If the handling of status input and output signals becomes congested, frame or word start can be delayed when this field is set to <b>enabled</b> (1). | 0 = disabled<br>1 = enabled | | 7 | Reserved | - | 0 | | 6 | clk_polarity | This field selects the polarity of the sample edge of the incoming clock for Synchronous Serial Port p3. If the negative edge is to be used, this field should be set to <b>neg</b> (1). | 0 = pos<br>1 = neg | | 5 | frame_polarity | This field selects the polarity of the incoming frame signal for Synchronous Serial Port p3. When set to <b>normal</b> (0), the frame signal is active high. | 0 = normal<br>1 = inverted | | 4 | status_polarity | This field selects the polarity of the incoming status signal for Synchronous Serial Port p3. When set to <b>normal</b> (0), the status signal is active high. | 0 = normal<br>1 = inverted | #### Bit Assignments of R\_SYNC\_SERIAL3\_CTRL (continued) | Bit(s) | Name | Description | State/Range | |--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 3 | clk_driver | This field selects the polarity of the outgoing clock signal for Synchronous Serial Port p3: normal - the internal reference clock signal is connected directly to the clock output. inverted - the internal reference clock signal is inverted and connected to the clock output. | 0 = normal<br>1 = inverted | | 2 | frame_driver | This field selects the polarity of the outgoing frame signal for Synchronous Serial Port p3: normal - the internal reference frame signal is connected directly to the status output. inverted - the internal reference frame signal is inverted and connected to the frame output. | 0 = normal<br>1 = inverted | | 1 | status_driver | This field selects the polarity of the outgoing status signal for Synchronous Serial Port p3: normal - the internal reference status signal is connected directly to the status output. inverted - the internal reference status signal is inverted and connected to the status output. | 0 = normal<br>1 = inverted | | 0 | def_out0 | This field is the value of the <b>ss3_out1</b> output pin when Serial Port p3 is enabled, but a sync serial mode is selected where the pin has no meaning/function (it is a spare pin given the configuration). | 0 = low<br>1 = high | #### 18.18.17 R\_SYNC\_SERIAL\_PRESCALE #### **Synchronous Serial Prescale Register, General Characteristics** | ID of register | R_SYNC_SERIAL_PRESCALE | Size | 32 bits | |----------------|------------------------|---------------|------------| | Offset | 0xF4 | Read/Write | Write only | | Address | 0xB00000F4 | Initial value | Unknown | #### Bit Assignments of R\_SYNC\_SERIAL\_PRESCALE | Bit(s) | Name | Description | State/Range | |---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | 31 - 24 | Reserved | - | 0 | | 23 | clk_sel_u3 | This field selects whether the codec clock or the baudrate clock is used as clock source for Synchronous Serial Port p3. If set to <b>baudrate</b> (1), the clock is generated from the baudrate clock from the asynchronous serial port. If set, the codec clock will be used. The source for the codec clock can be external or internal, defined by what operation mode is selected in R_SYNC_SERIAL3_CTRL. | 0 = codec<br>1 = baudrate | | 22 | word_stb_sel_u3 | This field selects how the incoming word strobe for Synchronous Serial Port p3 is generated. If set, the word strobe is equal to the frame strobe and is extracted from the external incoming frame. This is the normal setting. If this field is set to <code>internal</code> (1), the word strobe is generated by internal counters. <code>word_stb_sel_u3</code> should only be set to <code>internal</code> if the interface is running in any of the slave modes that are selected in <code>R_SYNC_SERIAL3_CTRL</code> . | 0 = external<br>1 = internal | | 21 | clk_sel_u1 | This field selects whether the codec clock or the baudrate clock is used as clock source for Synchronous Serial Port p1. If set to <b>baudrate</b> (1), the clock is generated from the baudrate clock from the asynchronous serial port. If <b>clk_sel_u3</b> is set to <b>codec</b> (0), the codec clock will be used. The source for the codec clock can be external or internal, defined by what operation mode is selected in R_SYNC_SERIAL1_CTRL. | 0 = codec<br>1 = baudrate | | 20 | word_stb_sel_u1 | This field selects how the incoming word strobe Synchronous Serial Port p1 is generated. If set, the word strobe is equal to the frame strobe and is extracted from the external incoming frame. This is the normal setting. If this field is set to <code>internal</code> (1), the word strobe is generated by internal counters. <code>word_stb_sel_u1</code> should only be set to <code>internal</code> if the interface is running in any of the slave modes that are selected in <code>R_SYNC_SERIAL1_CTRL</code> . | 0 = external<br>1 = internal | | 19 | Reserved | - | 0 | | 18 - 16 | prescaler | This field sets the divide factor for the codec clock. Both synchronous serial ports are affected. The codec clock is 4.096 MHz divided by the division factor of 1 to 128. (note) | 0 = div1<br>1 = div2<br>2 = div4<br>3 = div8<br>4 = div16<br>5 = div32<br>6 = div64<br>7 = div128 | | 15 | warp_mode | If warp_mode is <b>enabled</b> the codec base clock is changed from $4.096~\mathrm{MHz}$ to $12.5~\mathrm{MHz}$ . This is only used for testing purposes. | 0 = normal<br>1 = enabled | #### Bit Assignments of R\_SYNC\_SERIAL\_PRESCALE (continued) | 14 - 11 | frame_rate | This field selects the frame_trigger divisor. (note) | 0-15 | |---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | 10 | Reserved | - | 0 | | 9 - 0 | word_rate | This field selects the word rate. Enough time must be left for the selected number of data bits to be transferred. If 8-bit word size is selected, the smallest value for this field is 7. (8 if early framesync is selected). (note) | 0-1023 | #### Note: In master mode, the bitclock and framesync rates are programable. The sample rate is selected by writing to this register which contains all integer division factors. The bitclock is generated by dividing the internal ETRAX 100LX codec clock (4.096MHz) by $(2^N)$ . The valid range for the divisor is: $1 \le (2^N) \le 128$ . (See the **prescaler** field.) Word sync is generated by dividing the bitclock by (D+1) where D is the value of the **word\_rate** field. The divisor may be in the range: $0 \le D \le 1023$ . Framesync is generated by dividing wordsync by (F+1) where F is the value of the **frame\_rate** field. The divisor may be in the range: $0 \le D \le 15$ . If the bitclock = 2.048 MHz (N=1) and **word\_rate** = 255 and **frame\_rate** = 0, then framesync and wordsync will be 8.0 KHz. ## 19 Electrical Information #### 19.1 Pinout Figure 19-1 The ETRAX 100LX Pinout ## 19.2 Clock and PLL Signals | Solder Ball | Name | Direction | Description | |-------------|--------|-----------|---------------------------------------------| | V9 | clkin | in | External clock input. | | W9 | pllagn | out | PLL loop filter internal ground connection. | | Y9 | plllp2 | in/out | PLL loop filter. | Table 19-1 Clock and Phase-locked Loop Signals ## 19.3 Power and Ground Signals | Solder Ball | Name | Description | |--------------------------------------------------------------------------------------------------|-------------|------------------------| | A1<br>D4<br>D8<br>D13<br>D17<br>H4<br>H17<br>N4<br>N17<br>U4<br>U8<br>U13<br>U17<br>V10 | $V_{ss}$ | Ground connection. | | D6<br>D11<br>D15<br>F4<br>F17<br>F20<br>K4<br>L17<br>M20<br>R4<br>R17<br>U6<br>U10<br>U15<br>U20 | $ m V_{dd}$ | Supply voltage, 3.3 V. | Table 19-2 Power and Ground Signals ## 19.4 Bus Interface Signals #### **Data Bus** | Solder Ball | Direction | Pin Name | |-------------|-----------|----------| | G1 | in/out | d0 | | Н3 | in/out | d1 | | H2 | in/out | d2 | | H1 | in/out | d3 | | J4 | in/out | d4 | | J3 | in/out | d5 | | J2 | in/out | d6 | | J1 | in/out | d7 | | K2 | in/out | d8 | | K3 | in/out | d9 | | K1 | in/out | d10 | | L1 | in/out | d11 | | L2 | in/out | d12 | | L3 | in/out | d13 | | L4 | in/out | d14 | | M1 | in/out | d15 | | M2 | in/out | d16 | | M3 | in/out | d17 | | M4 | in/out | d18 | | N1 | in/out | d19 | | N2 | in/out | d20 | | N3 | in/out | d21 | | P1 | in/out | d22 | | P2 | in/out | d23 | | R1 | in/out | d24 | | P3 | in/out | d25 | | R2 | in/out | d26 | | T1 | in/out | d27 | | P4 | in/out | d28 | | R3 | in/out | d29 | | T2 | in/out | d30 | | U1 | in/out | d31 | | | | | **Address Bus** | Audiess Dus | | | | | | | | |-------------|-----------|--------------|--|--|--|--|--| | Solder Ball | Direction | Pin Name | | | | | | | A8 | out | a1 (Note 1) | | | | | | | D9 | out | a2 | | | | | | | C9 | out | a3 | | | | | | | B9 | out | a4 | | | | | | | A9 | out | a5 | | | | | | | D10 | out | a6 | | | | | | | C10 | out | a7 | | | | | | | B10 | out | a8 | | | | | | | A10 | out | a9 | | | | | | | A11 | out | a10 | | | | | | | C11 | out | a11 | | | | | | | B11 | out | a12 | | | | | | | A12 | out | a13 | | | | | | | B12 | out | a14 | | | | | | | C12 | out | a15 | | | | | | | D12 | out | a16 | | | | | | | A13 | out | a17 | | | | | | | B13 | out | a18 | | | | | | | C13 | out | a19 | | | | | | | A14 | out | a20 | | | | | | | B14 | out | a21 | | | | | | | C14 | out | a22 | | | | | | | A15 | out | a23 (Note 2) | | | | | | | B15 | out | a24 (Note 2) | | | | | | | D14 | out | a25 (Note 2) | | | | | | | | | | | | | | | Table 19-3 Data and Address Buses **Note 1:** Solder ball A8 is dual-function. See table 19-5. **Note 2:** Solder balls A15, B15 and D14 are dual-function. See table 19-6. #### **Chip Select Signals** | Solder Ball | Direction | Pin Name | Description | |-------------|-----------|----------|-------------------------------------------| | B5 | out | cse0 | Chip select signal for EPROM/flashPROM 0. | | A4 | out | cse1 | Chip select signal for EPROM/flashPROM 1. | | D7 | out | csr0 | Chip select signal for SRAM 0. | | C6 | out | csr1 | Chip select signal for SRAM 1. | | B6 | out | csp0 | Peripheral chip select signal 0. | | A5 | out | csp4 | Peripheral chip select signal 4. | Table 19-4 Chip Select Signals Peripheral chip select signals $\overline{csp1}$ to $\overline{csp3}$ and $\overline{csp5}$ to $\overline{csp7}$ are multiplexed with bits pb2 to pb7 in general port PB. See tables 19-19 and 19-20. #### **Read/Write Strobes** | Solder | | Bytewise | Common Write Enable | | | |--------|-----------|--------------------------|---------------------|----------------|---------------------------------------------------------------------------------------| | Ball | Direction | Write Enable | 16-bit Mode | 32-bit Mode | Description | | B8 | out | $\overline{\mathrm{rd}}$ | rd | rd | Read strobe, common to all four bytes of the data bus. Not active during DRAM access. | | A7 | out | wr0 | | | Write strobe for byte 0 of the data bus. | | | | | be0 | <del>be0</del> | Byte enable strobe for byte 0 of the data bus. | | B7 | out | wr1 | | | Write strobe for byte 1 of the data bus. | | | | | be1 | be1 | Byte enable strobe for byte 1 of the data bus. | | A6 | out | wr2 | | | Write strobe for byte 2 of the data bus. | | | | | | be2 | Byte enable strobe for byte 2 of the data bus. | | C7 | out | wr3 | | | Write strobe for byte 3 of the data bus. | | | | | we | we | Write enable strobe, common to all four bytes of the data bus. | | A8 | out | a1 | a1 | | Least significant address bit. | | | | | | be3 | Byte enable strobe for byte 3 of the data bus. | Table 19-5 Read/Write Strobe Signals for Bytewise and Common Write Enable Modes #### **Asynchronous and Synchronous DRAM Signals** | | | | Asynchronous DRAM | | | | |----------------|-----------|------------------|-------------------|---------------|---------------------------------------------------------------|--| | Solder<br>Ball | Direction | Bytewise<br>Mode | Bankwise<br>Mode | Sync.<br>DRAM | Description | | | E4 | out | casa0 | | | Column address strobe for byte 0 in Async. DRAM bank 0 and 1. | | | | | | casa0 | | Column address strobe for Async. DRAM bank 0. | | | | | | | dqm0 | Data qualify mask 0. | | | C1 | out | casa1 | | | Column address strobe for byte 1 in Async. DRAM bank 0 and 1. | | | | | | casa1 | | Column address strobe for Async. DRAM bank 1. | | | | | | | dqm1 | Data qualify mask 1. | | | D1 | out | casa2 | | | Column address strobe for byte 2 in Async. DRAM bank 0 and 1. | | | | | | casa2 | | Column address strobe for Async. DRAM bank 2. | | | | | | | dqm2 | Data qualify mask 2. | | | E2 | out | casa3 | | | Column address strobe for byte 3 in Async. DRAM bank 0 and 1. | | | | | | casa3 | | Column address strobe for Async. DRAM bank 3. | | | | | | | dqm3 | Data qualify mask 3. | | | F3 | out | casb0 | | | Column address strobe for byte 0 in Async. DRAM bank 2 and 3. | | | | | | <del>be0</del> | | Enable signal for byte 0 of the data bus. | | | | | | | dqm4 | Data qualify mask 4. | | | G4 | out | casb1 | | | Column address strobe for byte 1 in Async. DRAM bank 2 and 3. | | | | | | <del>be1</del> | | Enable signal for byte 1 of the data bus. | | | | | | | dqm5 | Data qualify mask 5. | | | F2 | out | casb2 | | | Column address strobe for byte 2 in Async. DRAM bank 2 and 3. | | | | | | <del>be2</del> | | Enable signal for byte 2 of the data bus. | | | | | | | dqm6 | Data qualify mask 6. | | | F1 | out | casb3 | | | Column address strobe for byte 3 in Async. DRAM bank 2 and 3. | | | | | | <del>be3</del> | | Enable signal for byte 2 of the data bus. | | | | | | | dqm7 | Data qualify mask 7. | | | G3 | out | dramwe | dramwe | | Write enable signal for Async. DRAM. | | | | in/out | | | dqs | DDR data qualify strobe. | | | C5 | out | ras0 | ras0 | • | Row address strobe for Async. DRAM bank 0. | | | | | | | csd0 | Chip select signal for Sync. DRAM group 0. | | | B4 | out | ras1 | ras1 | | Row address strobe for Async. DRAM bank 1. | | | | | | | csd1 | Chip select signal for Sync. DRAM group 1. | | | A3 | out | ras2 | ras2 | | Row address strobe for Async. DRAM bank 2. | | | | | | | clk | Master clock signal for Sync. DRAM. | | | D5 | out | ras3 | ras3 | | Row address strobe for Async. DRAM bank 3. | | | | | | | cke | Clock enable for Sync. DRAM. | | | A15 | out | a23 | a23 | | Bit 23 of address bus. | | | | | | | sdram_we | Write enable signal for Sync. DRAM. | | | B15 | out | a24 | a24 | _ | Bit 24 of address bus. | | | | | | | sdram_cas | Column address strobe for Sync. DRAM. | | | D14 | out | a25 | a25 | | Bit 25 of address bus. | | | 2 | | uno. | 220 | sdram_ras | Row address strobe for Sync. DRAM. | | | | | | | Januari_103 | Lauress suress for Sylle, Diviniti | | Table 19-6 Asynchronous and Synchronous DRAM Signals #### **Miscellaneous Bus Interface Signals** | Solder Ball | Direction | Name | Description | |-------------|-----------|-------|--------------------------------------------------| | G2 | in | rerun | Bus rerun signal. | | W6 | in | dreq0 | DMA request, external DMA0. | | Y6 | in | dreq1 | DMA request, external DMA1. | | V7 | out | dack0 | DMA acknowledge, external DMA0. | | W7 | out | dack1 | DMA acknowledge, external DMA1. | | U9 | in | irq | Interrupt request. | | A18 | in | nmi | Non maskable interrupt request. | | A17 | in | wait | External wait state input. | | C8 | out | inta | External interrupt acknowledge. | | Y10 | in | reset | System reset. | | W10 | in | hcfg | Hardware configuration for serial ports 2 and 3. | Table 19-7 Miscellaneous Bus Interface Signals #### 19.5 Logic Analyzer Mode and Test Signals | Solder Ball | Direction | Name | Description | |-------------|-----------|----------|-----------------------------------------------------| | T3 | in/out | bs0 | Bus status, bit 0 (Note 3). | | U2 | in/out | bs1 | Bus status, bit 1 (Note 3). | | V1 | in/out | bs2 | Bus status, bit 2 (Note 3). | | T4 | in/out | bs3 | Bus status, bit 3 (Note 3). | | B16 | in | test | Test input, should be high for normal operation. | | A16 | out | testout | Test output, must not be connected. | | C15 | out | busclk | Bus synchronization clock. Used for debug purposes. | | U18 | out | testout2 | Test output, must not be connected. | Table 19-8 Logic Analyzer Mode and Test Signals **Note 3:** These signals are for bus configuration during power-on reset. They are used as status outputs for debugging purposes when reset is inactive. ## 19.6 General Port PA Signals | Solder Ball | Direction | Name | Description | |-------------|-----------|------|-------------------------| | W1 | in/out | pa0 | General port PA, bit 0. | | U5 | in/out | pa1 | General port PA, bit 1. | | Y3 | in/out | pa2 | General port PA, bit 2. | | Y4 | in/out | pa3 | General port PA, bit 3. | | W5 | in/out | pa4 | General port PA, bit 4. | | Y5 | in/out | pa5 | General port PA, bit 5. | | V6 | in/out | pa6 | General port PA, bit 6. | | U7 | in/out | pa7 | General port PA, bit 7. | Table 19-9 General Port PA Signals ## 19.7 Asynchronous Serial Port 0 Signals | Solder Ball | Direction | Name | Description | |-------------|-----------|------|---------------------------------| | Y7 | out | txd0 | Transmit data, serial port 0. | | V8 | out | rts0 | Request to send, serial port 0. | | W8 | in | rxd0 | Receive data, serial port 0. | | Y8 | in | cts0 | Clear to send, serial port 0. | Table 19-10 Serial Port 0 Signals **Note 4:** I/O signals at Asynchronous Serial Ports p1 to p3 are multiplexed on to pins used by other interfaces. Sections 19-9 and 19-10 refer. ## 19.8 Network Interface Signals | Solder Ball | Direction | Name | MII Usage | SNI Usage | |-------------|-----------|---------|---------------------------------------------------------|------------------| | Y11 | in/out | mdio | Management data. | General I/O. | | W11 | out | mdc | Management clock. | General output. | | V11 | out | txdata0 | Data out, bit 0. | Data out. | | U11 | out | txdata1 | Data out, bit 1. | General output. | | Y12 | out | txdata2 | Data out, bit 2. | General output. | | W12 | out | txdata3 | Data out, bit 3. | General output. | | V12 | out | txen | Transmit enable. | Transmit enable. | | U12 | out | txer | Transmit error/<br>25 MHz clock/<br>Address recognized. | General output. | | Y13 | in | crs | Carrier sense. | Carrier sense. | | W13 | in | col | Collision. | Collision. | | V13 | in | txclk | Transmit clock. | Transmit clock. | | Y14 | in | rxer | Receive error. | General input. | | W14 | in | rxclk | Receive clock. | Receive clock. | | Y15 | in | rxdv | Data in valid. | Not used. | | V14 | in | rxdata0 | Data in, bit 0. | Data in. | | W15 | in | rxdata1 | Data in, bit 1. | General input. | | Y16 | in | rxdata2 | Data in, bit 2. | General input. | | U14 | in | rxdata3 | Data in, bit 3. | General input. | Table 19-11 Network Interface Signals #### 19.9 Multiplexed Signal Groups To optimize chip efficiency and minimize the device footprint, certain interfaces share a number of I/O pins. The input and outputs to and from these interfaces are multiplexed on to these common pins. The table below lists the interfaces whose inputs and outputs are multiplexed in this way. | Interface | |-------------------------------------------------------------------------------------------| | Asynchronous Serial Port p1<br>Asynchronous Serial Port p2<br>Asynchronous Serial Port p3 | | Synchronous Serial Port p1<br>Synchronous Serial Port p3 | | Shared RAM (8-bit)<br>Shared RAM-W (16-bit wide) | | Parallel Port p0<br>Parallel Port p1<br>Parallel Port-W (16-bit wide) | | SCSI-8 Port p0<br>SCSI-8 Port p1<br>SCSI-W (16-bit wide) | | ATA interface | | Additional Chip Select (CSP)<br>I2C Port | | USB interface port p1<br>USB interface port p2 | | General I/O pins | Table 19-12 Multiplexed Interfaces The I/O pins on to which the interface signals are multiplexed are arranged in six groups denoted A to F respectively. The table on the next page maps the relationships between the groups of pins and the interfaces that use them. It shows that some interfaces are mutually exclusive - they cannot use the I/O pins simultaneously. For example it is not possible to use SCSI-8 p0 at the same time as Asynchronous Serial Port p2 because the four Group B pins used by the serial port are also required for the SCSI interface. Pins that are not used by a particular interface are available for general I/O purposes. | I/O PIN GROUPS | | | | | | | | | |---------------------|--------------------------------|--------------------------------|---------------------|--------------------------------|-------------------------------------------|--|--|--| | A<br>(19 pins) | B<br>(4 pins) | C<br>(4 pins) | D<br>(19 pins) | E<br>(4 pins) | F<br>(8 pins) | | | | | - | Asynchronous<br>Serial Port p2 | Asynchronous<br>Serial Port p3 | - | Asynchronous<br>Serial Port p1 | - | | | | | - | - | Synchronous<br>Serial Port p3 | - | Synchronous<br>Serial Port p1 | Synchronous<br>Serial Port p1<br>(Note 5) | | | | | - | - | - | - | - | Synchronous<br>Serial Port p3<br>(Note 5) | | | | | Shared<br>RAM | - | - | - | - | - | | | | | Shared<br>RAM-W | - | - | Shared<br>RAM-W | - | - | | | | | Parallel<br>Port p0 | - | - | Parallel<br>Port p1 | - | - | | | | | Parallel<br>Port-W | - | - | Parallel<br>Port-W | - | - | | | | | SCSI-8<br>Port p0 | SCSI-8<br>Port p0 | - | - | - | SCSI-8<br>Port p0<br>(Note 5) | | | | | - | - | SCSI-8<br>Port p1 | SCSI-8<br>Port p1 | - | SCSI-8<br>Port p1<br>(Note 5) | | | | | SCSI-W<br>Port | SCSI-W<br>Port | - | SCSI-W<br>Port | - | SCSI-W<br>Port | | | | | ATA<br>Port | ATA<br>Port | ATA<br>Port | ATA<br>Port | - | - | | | | | - | - | - | - | - | CSP and<br>I2C Port | | | | | - | - | - | USB<br>Port p2 | USB<br>Port p1 | USB<br>Port p1 | | | | | General I/O<br>Port | General I/O<br>Port | General I/O<br>Port | General I/O<br>Port | General I/O<br>Port | General I/O<br>Port | | | | Table 19-13 Multiplexed Interfaces and I/O Pin Groups # Note 5: These ports use only two pins of I/O pin Group F. Consequently the two synchronous serial ports are not mutually exclusive of each other because unused pins remain available. Similarly the two SCSI-8 ports are not mutually exclusive of each other. However the *pairs of ports* are mutually exclusive because, in Group F, Synchronous Serial Port p1 and SCSI-8 p0 both use pin W17, and Synchronous Serial Port p3 and SCSI-8 p1 both use pin U16. # 19.9.1 Multiplexed I/O Signals - Group A | | | | | | | | | INTER | FACES | | | | | | | | |-----|-------------|------------|-------------|------------|--------|------------|----------------------------|------------|----------------|------------|-----------------------|------------|---|---|-----|-------------| | Pin | SCSI | -8 p0 | scs | SI-W | AT | A | Paral<br>Port <sub>I</sub> | | Paral<br>Port- | | Shared<br>Shar<br>RAM | red | | | | neral<br>/O | | V20 | s0msg | in/<br>out | s0msg | in/<br>out | iordy | in | p0perror | in | p0perror | in | pr_adr0 | in | - | - | g5 | in | | T18 | s0cd | in/<br>out | s0cd | in/<br>out | dmarq0 | in | p0ack | in | p0ack | in | pr_adr1 | in | - | - | g4 | in | | T19 | s0io | in/<br>out | s0io | in/<br>out | dmarq1 | in | p0busy | in | p0busy | in | intio | in | - | - | g3 | in | | T20 | s0req | in | s0req | in | dmarq2 | in | p0fault | in | p0fault | in | rd_wr | in | - | - | g2 | in | | R18 | s0rst | in | s0rst | in | dmarq3 | in | p0select | in | p0select | in | pr_req | in | - | - | g1 | in | | P17 | s0rst | out | s0rst | out | cs0 | out | p0data_oe | out | p0data_oe | out | pr_int | out | - | - | g5 | out | | R19 | s0ack | out | s0ack | out | cs1 | out | p0selectin | out | p0selectin | out | pr_ack | out | - | - | g4 | out | | R20 | s0atn | out | s0atn | out | a0 | out | p0autofd | out | p0autofd | out | a_sel | out | - | - | g3 | out | | K20 | s0bsy | out | s0bsy | out | a1 | out | p0strobe | out | p0strobe | out | - | - | - | - | g2 | out | | P20 | s0oe | out | s0oe | out | a2 | out | p0init | out | p0init | out | - | - | - | - | g1 | out | | N18 | s0p | in/<br>out | s0p | in/<br>out | dmack0 | out | - | - | - | - | - | - | - | - | g0 | in/<br>out | | N19 | s0d7 | in/<br>out | s0d7 | in/<br>out | d7 | in/<br>out | p0d7 | in/<br>out | p0d7 | in/<br>out | pr_d7 | in/<br>out | - | - | g15 | in/<br>out | | N20 | s0d6 | in/<br>out | <u>s0d6</u> | in/<br>out | d6 | in/<br>out | p0d6 | in/<br>out | p0d6 | in/<br>out | pr_d6 | in/<br>out | - | - | g14 | in/<br>out | | M17 | s0d5 | in/<br>out | s0d5 | in/<br>out | d5 | in/<br>out | p0d5 | in/<br>out | p0d5 | in/<br>out | pr_d5 | in/<br>out | - | - | g13 | in/<br>out | | M18 | s0d4 | in/<br>out | s0d4 | in/<br>out | d4 | in/<br>out | p0d4 | in/<br>out | p0d4 | in/<br>out | pr_d4 | in/<br>out | - | - | g12 | in/<br>out | | M19 | <u>s0d3</u> | in/<br>out | <u>s0d3</u> | in/<br>out | d3 | in/<br>out | p0d3 | in/<br>out | p0d3 | in/<br>out | pr_d3 | in/<br>out | - | - | g11 | in/<br>out | | L19 | s0d2 | in/<br>out | <u>s0d2</u> | in/<br>out | d2 | in/<br>out | p0d2 | in/<br>out | p0d2 | in/<br>out | pr_d2 | in/<br>out | - | - | g10 | in/<br>out | | L18 | s0d1 | in/<br>out | <u>s0d1</u> | in/<br>out | d1 | in/<br>out | p0d1 | in/<br>out | p0d1 | in/<br>out | pr_d1 | in/<br>out | - | - | g9 | in/<br>out | | L20 | <u>s0d0</u> | in/<br>out | <u>s0d0</u> | in/<br>out | d0 | in/<br>out | p0d0 | in/<br>out | p0d0 | in/<br>out | pr_d0 | in/<br>out | - | - | g8 | in/<br>out | Table 19-14 Multiplexed I/O Signals - Group A # 19.9.2 Multiplexed I/O Signals - Group B | | | | | | | | | INTER | FACES | 5 | | | | | | | |-----|-------|-------|-------|------|--------|-----|------|--------------------|-------|---|---|---|---|---|----|---------------| | Pin | SCSI | -8 p0 | scs | SI-W | ΑT | ΓA | | c. Serial<br>rt p2 | | | | | | | | eneral<br>I/O | | P19 | s0en | out | s0en | out | dior0 | out | rts2 | out | - | - | - | - | - | - | g7 | out | | K19 | s0sel | out | s0sel | out | dior1 | out | txd2 | out | - | - | - | - | - | - | g6 | out | | K18 | s0bsy | in | s0bsy | in | intrq0 | in | cts2 | in | - | - | - | - | - | - | g7 | in | | J20 | s0sel | in | s0sel | in | intrq1 | in | rxd2 | in | - | - | - | - | - | | g6 | in | Table 19-15 Multiplexed I/O Signals - Group B # 19.9.3 Multiplexed I/O Signals - Group C | | | | | | | | | INTER | FACES | | | | | | | | |-----|-------|-------|---|---|--------|-----|------|-------------------|-----------------|-----|---|---|---|---|-----|--------------| | Pin | SCSI | -8 p1 | | | A | ГА | | . Serial<br>rt p3 | Sync. S<br>Port | | | | | | | neral<br>//O | | J19 | s1bsy | in | - | - | intrq2 | in | cts3 | in | ss3_in2 | in | - | - | - | - | g31 | in | | J18 | s1sel | in | - | - | intrq3 | in | rxd3 | in | ss3_in1 | in | - | - | - | - | g30 | in | | B19 | s1en | out | - | - | dior2 | out | rts3 | out | ss3_out2 | out | - | - | - | - | g31 | out | | H20 | s1sel | out | - | - | dior3 | out | txd3 | out | ss3_out1 | out | - | - | - | - | g30 | out | Table 19-16 Multiplexed I/O Signals - Group C #### 19.9.4 Multiplexed I/O Signals - Group D | | | | | | | | | INTER | FACES | | | | | | | | |-----|-------------|------------|--------------|------------|--------|------------|----------------------------|------------|--------------|------------|-------------|------------|---------------|-----|-----|-------------| | Pin | SCSI- | -8 p1 | SCSI | -W | AT | A | Paral<br>Port <sub>I</sub> | | Para<br>Port | | Shar<br>RAM | | USB<br>Port p | | | neral<br>/O | | H19 | s1d7 | in/<br>out | s0d15 | in/<br>out | d15 | in/<br>out | p1d7 | in/<br>out | p0d15 | in/<br>out | pr_d15 | in/<br>out | - | - | g23 | in/<br>out | | H18 | s1d6 | in/<br>out | s0d14 | in/<br>out | d14 | in/<br>out | p1d6 | in/<br>out | p0d14 | in/<br>out | pr_d14 | in/<br>out | - | - | g22 | in/<br>out | | G20 | <u>s1d5</u> | in/<br>out | <u>s0d13</u> | in/<br>out | d13 | in/<br>out | p1d5 | in/<br>out | p0d13 | in/<br>out | pr_d13 | in/<br>out | - | - | g21 | in/<br>out | | G19 | s1d4 | in/<br>out | s0d12 | in/<br>out | d12 | in/<br>out | p1d4 | in/<br>out | p0d12 | in/<br>out | pr_d12 | in/<br>out | - | - | g20 | in/<br>out | | G18 | s1d3 | in/<br>out | s0d11 | in/<br>out | d11 | in/<br>out | p1d3 | in/<br>out | p0d11 | in/<br>out | pr_d11 | in/<br>out | - | - | g19 | in/<br>out | | F19 | s1d2 | in/<br>out | <u>s0d10</u> | in/<br>out | d10 | in/<br>out | p1d2 | in/<br>out | p0d10 | in/<br>out | pr_d10 | in/<br>out | - | - | g18 | in/<br>out | | E20 | s1d1 | in/<br>out | s0d9 | in/<br>out | d9 | in/<br>out | p1d1 | in/<br>out | p0d9 | in/<br>out | pr_d9 | in/<br>out | - | - | g17 | in/<br>out | | G17 | s1d0 | in/<br>out | s0d8 | in/<br>out | d8 | in/<br>out | p1d0 | in/<br>out | p0d8 | in/<br>out | pr_d8 | in/<br>out | - | - | g16 | in/<br>out | | E19 | s1p | in/<br>out | <u>s0p1</u> | in/<br>out | dmack1 | out | - | - | - | - | - | - | - | - | g24 | in/<br>out | | D20 | s1msg | in/<br>out | - | - | dmack2 | out | p1perror | in | - | - | - | - | usb2_oe | out | g29 | in | | E18 | s1cd | in/<br>out | - | - | dmack3 | out | p1ack | in | - | - | - | - | usb2_speed | out | g28 | in | | D19 | s1io | in/<br>out | - | - | g27 | out | p1busy | in | - | - | - | - | usb2_rcv | in | g27 | in | | E17 | s1req | in | - | - | - | - | p1fault | in | - | - | - | - | usb2_vp | in | g26 | in | | C20 | s1rst | in | - | - | - | - | p1select | in | - | - | - | - | usb2_vm | in | g25 | in | | C19 | s1rst | out | - | - | diow0 | out | p1data_oe | out | - | - | - | - | - | - | g29 | out | | B20 | s1ack | out | - | - | diow1 | out | p1selectin | out | - | - | - | - | - | - | g28 | out | | C18 | s1atn | out | - | - | diow2 | out | p1autofd | out | - | - | - | - | usb2_vpo | out | g27 | out | | J17 | s1bsy | out | s0enhiid | out | diow3 | out | p1strobe | out | - | - | - | - | usb2_vmo | out | g26 | out | | A20 | s1oe | out | s1oe | out | ext_oe | out | p1init | out | - | - | - | - | - | - | g25 | out | Table 19-17 Multiplexed I/O Signals - Group D # 19.9.5 Multiplexed I/O Signals - Group E | | | | | | | | | INTER | ACES | | | | | | | |-----|---|---|---|---|---|---|-----------------|-------|------|--------------------|---|---|---------------|-----|--| | Pin | | | | | | | Sync. S<br>Port | | | c. Serial<br>rt p1 | | | USB<br>Port p | 1 | | | U19 | - | - | - | - | - | - | ss1_out1 | out | txd1 | out | - | - | usb1_oe | out | | | W20 | - | - | - | - | - | - | ss1_out2 | out | rts1 | out | - | - | usb1_speed | out | | | T17 | - | - | - | - | - | - | ss1_in1 | in | rxd1 | in | - | - | usb1_rcv | in | | | V19 | - | - | - | - | - | - | ss1_in2 | in | cts1 | in | - | - | usb1_vp | in | | Table 19-18 Multiplexed I/O Signals - Group E # 19.9.6 Multiplexed I/O Signals - Group F | | | | | | | | I | INTERI | ACES | | | | | | | | |-----|--------|------|--------|------|----------|-----|-----------------|------------|-----------------|------------|---------|------------|---------------|-----|-----|-------------| | Pin | SCSI- | 8 p0 | SCSI- | 8 p1 | scs | I-W | Sync. S<br>Port | | Sync. S<br>Port | | CSP ar | nd I2C | USB<br>Port p | | | neral<br>/O | | V15 | - | - | - | - | - | - | - | - | - | - | i2c_d | in/<br>out | - | - | pb0 | in/<br>out | | W16 | - | - | - | - | - | - | - | - | - | - | i2c_clk | out | - | - | pb1 | in/<br>out | | Y17 | - | - | - | - | - | - | - | - | - | - | csp1 | out | usb1_vpo | out | pb2 | in/<br>out | | V16 | - | - | - | - | - | - | - | - | - | - | csp2 | out | usb1_vmo | out | pb3 | in/<br>out | | W17 | s0enph | out | - | - | s0enph | out | ss1_io3 | in/<br>out | - | - | csp3 | out | - | - | pb4 | in/<br>out | | Y18 | - | - | * | - | - | - | - | - | - | - | csp5 | out | usb1_vm | in | pb5 | in/<br>out | | Y19 | - | - | - | - | - | - | - | - | - | - | csp6 | out | - | - | pb6 | in/<br>out | | U16 | - | - | s1enph | out | s0enloid | out | - | - | ss3_io3 | in/<br>out | csp7 | out | - | - | pb7 | in/<br>out | Table 19-19 Multiplexed I/O Signals - Group F # 19.10 Multiplexed Interfaces This section provides signal assignment details of the various interfaces that are multiplexed on to the I/O pins. #### 19.10.1 SCSI Ports #### SCSI-8 Port p0 The pins listed below are used by SCSI-8 Port p0 in 8-bit mode. These pins are also used by the SCSI-W port in 16-bit (wide) mode (see table 19-20). | Solder<br>Ball | Chip Pin<br>Name | Interface<br>Pin Name | Direction | Description | |------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | V20 | s0msg | s0msg | in/out (Note 6) | Message, driven by target during message phase. | | T18 | s0cd | s0cd | in/out (Note 6) | Control/Data, driven by target to determine whether control or data information is on the bus. | | T19 | s0io | s0io | in/out (Note 6) | Input/Output, driven by target and indicates bus direction. | | R19 | s0ack | s0ack | out | $\label{lem:constraint} A cknowledgement \ signal \ in \ the \ information \ transfer handshake.$ | | T20 | s0req | s0req | in | Request signal in the information transfer handshake. | | R20 | s0atn | s0atn | out | $\label{eq:Attention} Attention condition indicator from ETRAX~100LX~to~target.$ | | K19 | s0sel | s0sel | out | Select or reselect signal from SCSI interface to SCSI buffer. | | J20 | s0sel | s0sel | in (Note 7) | -SEL signal from SCSI bus to SCSI interface. | | K20 | s0bsy | s0bsy | out | Bus in use signal from SCSI interface to SCSI buffer. | | K18 | s0bsy | s0bsy | in (Note 7) | -BSY signal from SCSI bus to SCSI interface. | | P17 | s0rst | s0rst | out | Bus reset signal from SCSI interface to SCSI buffer. | | R18 | s0rst | s0rst | in (Note 7) | -RST signal from SCSI bus to SCSI interface. | | N18 | s0p | s0p | in/out | Data bus parity. | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19 | s0d0 s0d1 s0d2 s0d3 s0d4 s0d5 s0d6 s0d7 | s0d0<br>s0d1<br>s0d2<br>s0d3<br>s0d4<br>s0d5<br>s0d6<br>s0d7 | in/out in/out in/out in/out in/out in/out in/out in/out | Data bus of port p0 in SCSI 8-bit mode. | | P20 | s0oe | s0oe | out | External bus driver direction for signals $\overline{s0d0}$ to $\overline{s0d7}$ and $\overline{s0p}$ . | | P19 | s0en | s0en | out | External driver output enable for signals $\overline{s0ack}$ and $\overline{s0atn}$ . | | W17 | pb4 | s0enph | in/out | SCSI-0 phase enable for software ID select. | Table 19-20 SCSI-8 Port p0 Signals For Notes 6 and 7, refer to SCSI-W Port on page 566. #### SCSI-8 Port p1 The pins listed below are used by SCSI-8 Port p1 in 8-bit mode. Some pins are also used by the SCSI-W Port in 16-bit (wide) mode (see tables 19-20, 19-21, and 19-22). | Solder<br>Ball | Chip Pin<br>Name | Interface<br>Pin Name | Direction | Description | |------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | D20 | s1msg | s1msg | in/out (Note 6) | Message, driven by target during message phase. | | E18 | s1cd | s1cd | in/out (Note 6) | Control/Data, driven by target to determine whether control or data information is on the bus. | | D19 | s1io | s1io | in/out (Note 6) | Input/Output, driven by target and indicates bus direction. | | B20 | s1ack | s1ack | out | $\label{lem:constraint} A cknowledgement \ signal \ in \ the \ information \ transfer handshake.$ | | E17 | s1req | s1req | in | Request signal in the information transfer handshake. | | C18 | s1atn | s1atn | out | Attention condition indicator from ETRAX 100LX to target. | | H20 | s1sel | s1sel | out | Select or reselect signal from SCSI interface to SCSI buffer. | | J18 | s1sel | s1sel | in (Note 7) | -SEL signal from SCSI bus to SCSI interface. | | J17 | s1bsy | s1bsy | out | Bus in use signal from SCSI interface to SCSI buffer. | | J19 | s1bsy | s1bsy | in (Note 7) | -BSY signal from SCSI bus to SCSI interface. | | C19 | s1rst | s1rst | out | Bus reset signal from SCSI interface to SCSI buffer. | | C20 | s1rst | s1rst | in (Note 7) | -RST signal from SCSI bus to SCSI interface. | | E19 | s1p | s1p | in/out | Data bus parity. | | G17<br>E20<br>F19<br>G18<br>G19<br>G20<br>H18<br>H19 | \$1d0<br>\$1d1<br>\$1d2<br>\$1d3<br>\$1d4<br>\$1d5<br>\$1d6<br>\$1d7 | \$1d0<br>\$1d1<br>\$1d2<br>\$1d3<br>\$1d4<br>\$1d5<br>\$1d6<br>\$1d7 | in/out in/out in/out in/out in/out in/out in/out in/out in/out | Data bus of port p1 in SCSI 8-bit mode. | | A20 | s1oe | s1oe | out | External bus driver direction for signals $\overline{s1d0}$ to $\overline{s1d7}$ and $\overline{s1p}$ . | | B19 | s1en | s1en | out | External driver output enable for signals $\overline{s1ack}$ and $\overline{s1atn}$ . | | U16 | pb7 | s1enph | in/out | SCSI-1 phase enable for software ID select. | Table 19-21 SCSI-8 Port p1 Signals For Notes 6 and 7, refer to SCSI-W Port on page 566. #### **SCSI-W Port** In 16-bit mode the SCSI-W Port uses the following I/O pins, which are also used by SCSI-8 Ports p0 and p1 in 8-bit mode. | Solder<br>Ball | Chip Pin<br>Name | Interface<br>Pin Name | Direction | Description | |------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------| | V20 | s0msg | s0msg | in/out (Note 6) | Message, driven by target during message phase. | | T18 | s0cd | s0cd | in/out (Note 6) | Control/Data, driven by target to determine whether control or data information is on the bus. | | T19 | s0io | s0io | in/out (Note 6) | Input/output driven by target to show bus direction. | | R19 | s0ack | s0ack | out | Acknowledge signal in transfer handshake. | | T20 | s0req | s0req | in | Request signal in the information transfer handshake. | | R20 | s0atn | s0atn | out | Attention condition indicator from ETRAX 100LX to target. | | K19 | s0sel | s0sel | out | Select or reselect signal from SCSI interface to SCSI buffer. | | J20 | s0sel | s0sel | in (Note 7) | -SEL signal from SCSI bus to SCSI interface. | | K20 | s0bsy | s0bsy | out | Bus in use signal from SCSI interface to SCSI buffer. | | J17 | s1bsy | s0enhiid | out | Enable arbitration ID 7 - 0 for software ID. | | K18 | s0bsy | s0bsy | in (Note 7) | -BSY signal from SCSI bus to SCSI interface. | | P17 | s0rst | s0rst | out | Bus reset signal from SCSI interface to SCSI buffer. | | R18 | s0rst | s0rst | in (Note 7) | -RST signal from SCSI bus to SCSI interface. | | N18 | s0p | s0p | in/out | Data bus low byte parity. | | E19 | s1p | s0p1 | in/out | Data bus high byte parity. | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19 | s0d0 s0d1 s0d2 s0d3 s0d4 s0d5 s0d6 s0d7 | s0d0 s0d1 s0d2 s0d3 s0d4 s0d5 s0d6 s0d7 | in/out in/out in/out in/out in/out in/out in/out in/out in/out | Low byte of data bus in SCSI-W mode. | | G17<br>E20<br>F19<br>G18<br>G19<br>G20<br>H18<br>H19 | $\begin{array}{c} \overline{s1d0} \\ \hline s1d1 \\ \hline s1d2 \\ \hline s1d3 \\ \hline s1d4 \\ \hline s1d5 \\ \hline s1d6 \\ \hline s1d7 \\ \end{array}$ | s0d8 s0d9 s0d10 s0d11 s0d12 s0d13 s0d14 s0d15 | in/out<br>in/out<br>in/out<br>in/out<br>in/out<br>in/out<br>in/out | High byte of data bus in SCSI-W mode. | | P20 | s0oe | s0oe | out | External bus driver direction for $\overline{s0d0}$ to $\overline{s0d7}$ and $\overline{s0p}$ . | | A20 | s1oe | s1oe | out | External bus driver direction for $\overline{s0d8}$ to $\overline{s0d15}$ and $\overline{s1p}$ . | | P19 | s0en | s0en | out | External driver output enable for soack and soatn. | | W17 | pb4 | s0enph | in/out | SCSI-0 phase enable for software ID select. | | U16 | pb7 | s0enloid | in/out | Enable arbitration ID 15 - 8 for software ID. | Table 19-22 SCSI-W Signals - **Note 6:** If software ID is enabled, the host SCSI ID number is driven to external logic during arbitration. Please refer to the information about the software ID and external buffer solution in Chapter 10. - **Note 7:** These OR-gated SCSI bus signals are generated by the external SCSI buffer. # 19.10.2 ATA | Solder<br>Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description | |--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------| | V20 | s0msg | iordy | in | I/O ready. | | T18<br>T19<br>T20<br>R18 | sOcd<br>sOio<br>sOreq<br>sOrst | dmarq0<br>dmarq1<br>dmarq2<br>dmarq3 | in<br>in<br>in<br>in | DMA request bus 0. DMA request bus 1. DMA request bus 2. DMA request bus 3. | | P17 | s0rst | cs0 | out | Chip select 0. | | R19 | s0ack | cs1 | out | Chip select 1. | | R20<br>K20<br>P20 | s0atn<br>s0bsy<br>s0oe | a0<br>a1<br>a2 | out<br>out<br>out | Device address bit 0. Device address bit 1. Device address bit 2. | | N18<br>E19<br>D20<br>E18 | s1p<br>s1msg<br>s1cd | dmack0<br>dmack1<br>dmack2<br>dmack3 | out<br>out<br>out<br>out | DMA acknowledge bus 0. DMA acknowledge bus 1. DMA acknowledge bus 2. DMA acknowledge bus 3. | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19<br>G17<br>E20<br>F19<br>G18<br>G19<br>G20<br>H18<br>H19 | s0d0<br>s0d1<br>s0d2<br>s0d3<br>s0d4<br>s0d5<br>s0d6<br>s0d7<br>s1d0<br>s1d1<br>s1d2<br>s1d3<br>s1d4<br>s1d5<br>s1d6<br>s1d7 | d0<br>d1<br>d2<br>d3<br>d4<br>d5<br>d6<br>d7<br>d8<br>d9<br>d10<br>d11<br>d12<br>d13<br>d14<br>d15 | in/out | 16-bit data bus of ATA port. | | P19<br>K19<br>B19<br>H20 | s0en<br>s0sel<br>s1en<br>s1sel | dior0<br>dior1<br>dior2<br>dior3 | out<br>out<br>out<br>out | Read strobe signal 0. Read strobe signal 1. Read strobe signal 2. Read strobe signal 3. | | K18<br>J20<br>J19<br>J18 | s0bsy<br>s0sel<br>s1bsy<br>s1sel | intrq0<br>intrq1<br>intrq2<br>intrq3 | in<br>in<br>in<br>in | Interrupt request bus 0. Interrupt request bus 1. Interrupt request bus 2. Interrupt request bus 3. | | C19<br>B20<br>C18<br>J17 | s1rst<br>s1ack<br>s1atn<br>s1bsy | diow0<br>diow1<br>diow2<br>diow3 | out<br>out<br>out<br>out | Write strobe signal 0. Write strobe signal 1. Write strobe signal 2. Write strobe signal 3. | | A20 | s1oe | ext_oe | out | Output enable for external driver. | Table 19-23 ATA Signals #### 19.10.3 Parallel Ports #### Parallel Port p0 | Solder<br>Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description (Note 8) | |------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------| | V20 | s0msg | p0perror | in | Peripheral error signal to parallel port p0. | | T18 | s0cd | p0ack | in | Peripheral acknowledgement signal to parallel port p0. | | T19 | s0io | p0busy | in | Peripheral busy signal to parallel port p0. | | T20 | s0req | p0fault | in | Peripheral fault signal to parallel port p0. | | R18 | s0rst | p0select | in | Peripheral select signal to parallel port p0. | | P17 | s0rst | p0data_oe | out | Data output enable from parallel port p0. | | R19 | s0ack | p0selectin | out | Select in signal from parallel port p0. | | R20 | s0atn | p0autofd | out | Autofeed signal from parallel port p0. | | K20 | s0bsy | p0strobe | out | Strobe signal from parallel port p0. | | P20 | s0oe | p0init | out | Initialization signal from parallel port p0. | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19 | s0d0 s0d1 s0d2 s0d3 s0d4 s0d5 s0d6 s0d7 | p0d0<br>p0d1<br>p0d2<br>p0d3<br>p0d4<br>p0d5<br>p0d6<br>p0d7 | in/out in/out in/out in/out in/out in/out in/out in/out in/out | 8-bit data bus of parallel port p0. | Table 19-24 Parallel Port p0 Signals #### Parallel Port p1 | Solder<br>Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description (Note 8) | |------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------| | D20 | s1msg | p1perror | in | Peripheral error signal to parallel port p1. | | E18 | s1cd | p1ack | in | Peripheral acknowledgement signal to parallel port p1. | | D19 | s1io | p1busy | in | Peripheral busy signal to parallel port p1. | | E17 | s1req | p1fault | in | Peripheral fault signal to parallel port p1. | | C20 | s1rst | p1select | in | Peripheral select signal to parallel port p1. | | C19 | s1rst | p1data_oe | out | Data output enable from parallel port p1. | | B20 | s1ack | p1selectin | out | Select in signal from parallel port p1. | | C18 | s1atn | p1autofd | out | Autofeed signal from parallel port p1. | | J17 | s1bsy | p1strobe | out | Strobe signal from parallel port p1. | | A20 | s1oe | p1init | out | Initialization signal from parallel port p1. | | G17<br>E20<br>F19<br>G18<br>G19<br>G20<br>H18<br>H19 | \$1d0<br>\$1d1<br>\$1d2<br>\$1d3<br>\$1d4<br>\$1d5<br>\$1d6<br>\$1d7 | p1d0<br>p1d1<br>p1d2<br>p1d3<br>p1d4<br>p1d5<br>p1d6<br>p1d7 | in/out<br>in/out<br>in/out<br>in/out<br>in/out<br>in/out<br>in/out<br>in/out | 8-bit data bus of parallel port p1. | Table 19-25 Parallel Port p1 Signals Note 8: These descriptions apply to Centronics (Compatibility) mode only, which is the default mode of the parallel ports. For descriptions of these signals in other IEEE 1284 modes, please refer to *chapter* 13 *Parallel Ports.* # Parallel Port-W (16-bit wide) | Solder<br>Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description | |--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------| | V20 | s0msg | p0perror | in | Peripheral acknowledge signal to $\overline{p0init}$ . | | T18 | s0cd | p0ack | in | Handshake signal in reverse mode. | | T19 | s0io | p0busy | in | Flow control signal in the forward direction. | | T20 | s0req | p0fault | in | Interrupt request from peripheral. | | R18 | s0rst | p0select | in | Indicates the ECP mode support. | | P17 | s0rst | p0data_oe | out | Data output enable signal. | | R19 | s0ack | p0selectin | out | Negotiation signal. | | R20 | s0atn | p0autofd | out | Flow control signal in the reverse direction. | | K20 | s0bsy | p0strobe | out | Handshake signal in forward mode. | | P20 | s0oe | p0init | out | Indicates the reverse mode when asserted (low). | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19<br>G17<br>E20<br>F19<br>G18<br>G19<br>G20<br>H18<br>H19 | s0d0 s0d1 s0d2 s0d3 s0d4 s0d5 s0d6 s0d7 s1d0 s1d1 s1d2 s1d3 s1d4 s1d5 s1d6 s1d7 | p0d0<br>p0d1<br>p0d2<br>p0d3<br>p0d4<br>p0d5<br>p0d6<br>p0d7<br>p0d8<br>p0d9<br>p0d10<br>p0d11<br>p0d12<br>p0d13<br>p0d14 | in/out | 16-bit data bus of parallel port-W. | Table 19-26 Parallel Port-W Signals # 19.10.4 Shared RAM and Shared RAM-W #### **Shared RAM** | Solder<br>Ball | Chip Pin<br>Name | Interface<br>Pin Name | Direction | Description | |------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------| | V20 | s0msg | pr_adr0 | in | Address bit 0, internally multiplexed with internally generated address bits. | | T18 | s0cd | pr_adr1 | in | Address bit 1, internally multiplexed with internally generated address bits. | | T19 | s0io | intio | in | Interrupt from peripheral. | | T20 | s0req | rd_wr | in | Read/write select. | | R18 | s0rst | pr_req | in | Request from peripheral. | | P17 | s0rst | pr_int | out | Interrupt to peripheral. | | R19 | s0ack | pr_ack | out | Acknowledgement to peripheral. | | R20 | s0atn | a_sel | out | Address select for externally multiplexed address bits. High for address from external device. | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19 | s0d0 s0d1 s0d2 s0d3 s0d4 s0d5 s0d6 s0d7 | pr_d0<br>pr_d1<br>pr_d2<br>pr_d3<br>pr_d4<br>pr_d5<br>pr_d6<br>pr_d7 | in/out in/out in/out in/out in/out in/out in/out in/out in/out | Data bus. | Table 19-27 Shared RAM Signals #### **Shared RAM-W** | Solder<br>Ball | Chip Pin<br>Name | Interface<br>Pin Name | Direction | Description | |------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------| | V20 | s0msg | pr_adr0 | in | Address bit 0, internally multiplexed with internally generated address bits. | | T18 | s0cd | pr_adr1 | in | Address bit 1, internally multiplexed with internally generated address bits. | | T19 | s0io | intio | in | Interrupt from peripheral. | | T20 | s0req | rd_wr | in | Read/write select. | | R18 | s0rst | pr_req | in | Request from peripheral. | | P17 | s0rst | pr_int | out | Interrupt to peripheral. | | R19 | s0ack | pr_ack | out | Acknowledgement to peripheral. | | R20 | s0atn | a_sel | out | Address select for externally multiplexed address bits. High for address from external device. | | L20<br>L18<br>L19<br>M19<br>M18<br>M17<br>N20<br>N19 | s0d0<br>s0d1<br>s0d2<br>s0d3<br>s0d4<br>s0d5<br>s0d6<br>s0d7 | pr_d0<br>pr_d1<br>pr_d2<br>pr_d3<br>pr_d4<br>pr_d5<br>pr_d6<br>pr_d7 | in/out in/out in/out in/out in/out in/out in/out in/out in/out | Data bus low byte. | | G17<br>E20<br>F19<br>G18<br>G19<br>G20<br>H18<br>H19 | \$1d0<br>\$1d1<br>\$1d2<br>\$1d3<br>\$1d4<br>\$1d5<br>\$1d6<br>\$1d7 | pr_d8<br>pr_d9<br>pr_d10<br>pr_d11<br>pr_d12<br>pr_d13<br>pr_d14<br>pr_d15 | in/out in/out in/out in/out in/out in/out in/out in/out in/out | Data bus high byte. | Table 19-28 Shared RAM-W Signals # 19.10.5 Asynchronous Serial Ports | Solder Ball | Chip Pin<br>Name | Interface<br>Pin Name | Direction | Description | |-------------|------------------|-----------------------|-----------|---------------------------------------------------| | U19 | txd1 | txd1 | out | Transmit data from Asynchronous Serial Port p1. | | W20 | rts1 | rts1 | out | Request to send from Asynchronous Serial Port p1. | | T17 | rxd1 | rxd1 | in | Receive data at Asynchronous Serial Port p1. | | V19 | cts1 | cts1 | in | Clear to send at Asynchronous Serial Port p1. | | | | | | | | P19 | s0en | rts2 | out | Request to send from Asynchronous Serial Port p2. | | K19 | s0sel | txd2 | out | Transmit data to Asynchronous Serial Port p2. | | K18 | s0bsy | cts2 | in | Clear to send to Asynchronous Serial Port p2. | | J20 | s0sel | rxd2 | in | Receive data at Asynchronous Serial Port p2. | | | | | | | | J19 | s1bsy | cts3 | in | Clear to send to Asynchronous Serial Port p3. | | J18 | s1sel | rxd3 | in | Receive data at Asynchronous Serial Port p3. | | B19 | s1en | rts3 | out | Request to send from Asynchronous Serial Port p3. | | H20 | s1sel | txd3 | out | Transmit data from Asynchronous Serial Port p3. | Table 19-29 Asynchronous Serial Ports p1, p2 and p3 Signals # 19.10.6 Synchronous Serial Ports p1 and p3 The synchronous serial ports have six different modes of operation: Master Output; Master Input; Slave Output; Slave Input; Master Bidirectional; Slave Bidirectional. The signal names at the I/O pins differ, depending upon the mode in use. The following tables show the different I/O pin assignments of the two synchronous serial ports in each mode of operation. | | | | SYNCHRO | NOUS SEF | RIAL PORTS - | MASTER OUT | PUT MODE | |----------------|---------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|-----------------------------------------------------------------| | Synchr | onous Seri | al Port p1 | Synchr | onous Seri | al Port p3 | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | T17 | rxd1 | - | J18 | s1sel | - | ss1_in1<br>ss3_in1 | Not used by the synchronous serial ports in Master Output mode. | | V19 | cts1 | ss1status | J19 | s1bsy | ss3status | ss1_in2<br>ss3_in2 | Serial busy input to respective port. | | U19 | txd1 | ss1clk | H20 | s1sel | ss3clk | ss1_out1<br>ss3_out1 | Serial clock output from respective port. | | W20 | rts1 | ss1data | B19 | s1en | ss3data | ss1_out2<br>ss3_out2 | Serial data output from respective port. | | W17 | pb4 | ss1frame | U16 | pb7 | ss3frame | ss1_io3<br>ss3_io3 | Serial frame indicator output from respective port. | Table 19-30 Pin Assignments of Synchronous Serial Ports p1 and p3 in Master Output Mode | | | | SYNCHR | ONOUS SE | RIAL PORTS | - MASTER INF | PUT MODE | |----------------|---------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|----------------------------------------------------------------| | Synchr | onous Seri | al Port p1 | Synchr | onous Seri | al Port p3 | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | T17 | rxd1 | ss1data | J18 | s1sel | ss3data | ss1_in1<br>ss3_in1 | Serial data input to respective port. | | V19 | cts1 | ss1status | J19 | s1bsy | ss3status | ss1_in2<br>ss3_in2 | Serial empty input to respective port. | | U19 | txd1 | ss1clk | H20 | s1sel | ss3clk | ss1_out1<br>ss3_out1 | Serial clock output from respective port. | | W20 | rts1 | ss1frame | B19 | s1en | ss3frame | ss1_out2<br>ss3_out2 | Serial frame indicator from respective port. | | W17 | pb4 | - | U16 | pb7 | - | - | Not used by the synchronous serial ports in Master Input mode. | Table 19-31 Pin Assignments of Synchronous Serial Ports p1 and p3 in Master Input Mode | SYNCHRONOUS SERIAL PORTS - SLAVE OUTPUT MODE | | | | | | | | | | |----------------------------------------------|---------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|----------------------------------------------------------------|--|--| | Synchr | onous Seri | ial Port p1 | Synchr | ronous Seri | al Port p3 | | | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | | | T17 | rxd1 | ss1clk | J18 | s1sel | ss3clk | ss1_in1<br>ss3_in1 | Serial clock input to respective port. | | | | V19 | cts1 | ss1frame | J19 | s1bsy | ss3frame | ss1_in2<br>ss3_in2 | Serial frame indicator to respective port. | | | | U19 | txd1 | ss1data | H20 | s1sel | ss3data | ss1_out1<br>ss3_out1 | Serial data output from respective port. | | | | W20 | rts1 | ss1status | B19 | s1en | ss3status | ss1_out2<br>ss3_out2 | Serial empty output from respective port. | | | | W17 | pb4 | - | U16 | pb7 | - | - | Not used by the synchronous serial ports in Slave Output mode. | | | Table 19-32 Pin Assignments of Synchronous Serial Ports p1 and p3 in Slave Output Mode | | | | SYNCHI | RONOUS S | ERIAL PORT | S - SLAVE INPU | JT MODE | |----------------|---------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|---------------------------------------------------------------| | Synchr | onous Seri | al Port p1 | Synchr | onous Seri | al Port p3 | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | T17 | rxd1 | ss1clk | J18 | s1sel | ss3clk | ss1_in1<br>ss3_in1 | Serial clock input to respective port. | | V19 | cts1 | ss1frame | J19 | s1bsy | ss3frame | ss1_in2<br>ss3_in2 | Serial frame indicator to respective port. | | U19 | txd1 | - | H20 | s1sel | - | ss1_out1<br>ss3_out1 | Not used by the synchronous serial ports in Slave Input mode. | | W20 | rts1 | ss1status | B19 | s1en | ss3status | ss1_out2<br>ss3_out2 | Serial busy output from respective port. | | W17 | pb4 | ss1data | U16 | pb7 | ss3data | ss1_io3<br>ss3_io3 | Serial data input to respective port. | Table 19-33 Pin Assignments of Synchronous Serial Ports p1 and p3 in Slave Input Mode | | | SY | NCHRONO | US SERIAL | PORTS - MA | STER BIDIREC | CTIONAL MODE | |----------------|---------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|-----------------------------------------------------| | Synchr | onous Seri | al Port p1 | Synchr | onous Seri | al Port p3 | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | T17 | rxd1 | ss1status | J18 | s1sel | ss3status | ss1_in1<br>ss3_in1 | Serial busy input to respective port. | | V19 | cts1 | ss1idata | J19 | s1bsy | ss3idata | ss1_in2<br>ss3_in2 | Serial data input to respective port. | | U19 | txd1 | ss1clk | H20 | s1sel | ss3clk | ss1_out1<br>ss3_out1 | Serial clock output from respective port. | | W20 | rts1 | ss1odata | B19 | s1en | ss3odata | ss1_out2<br>ss3_out2 | Serial data output from respective port. | | W17 | pb4 | ss1frame | U16 | pb7 | ss3frame | ss1_io3<br>ss3_io3 | Serial frame indicator output from respective port. | Table 19-34 Pin Assignments of Synchronous Serial Ports p1 and p3 in Master Bidirectional Mode | | | S | YNCHRONO | OUS SERIA | L PORTS - SI | AVE BIDIREC | TIONAL MODE | |----------------|---------------------|------------------------|----------------|---------------------|------------------------|-----------------------------|--------------------------------------------| | Synchr | onous Seri | ial Port p1 | Synchr | ronous Seri | al Port p3 | | | | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Solder<br>Ball | Chip<br>Pin<br>Name | Mode<br>Signal<br>Name | Interface<br>Signal<br>Name | Description | | T17 | rxd1 | ss1clk | J18 | s1sel | ss3clk | ss1_in1<br>ss3_in1 | Serial clock input to respective port. | | V19 | cts1 | ss1frame | J19 | s1bsy | ss3frame | ss1_in2<br>ss3_in2 | Serial frame indicator to respective port. | | U19 | txd1 | ss1status | H20 | s1sel | ss3status | ss1_out1<br>ss3_out1 | Serial busy output from respective port. | | W20 | rts1 | ss1odata | B19 | s1en | ss3odata | ss1_out2<br>ss3_out2 | Serial data output from respective port. | | W17 | pb4 | ss1idata | U16 | pb7 | ss3idata | ss1_io3<br>ss3_io3 | Serial data input to respective port. | Table 19-35 Pin Assignments of Synchronous Serial Ports p1 and p3 in Slave Bidirectional Mode #### 19.10.7 USB # USB Port p1 | Solder Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description | |-------------|------------------|-----------------------|-----------|------------------------------------------| | U19 | txd1 | usb1_oe | out | Output enable from USB Port p1. | | W20 | rts1 | usb1_speed | out | Speed indicator signal from USB Port p1. | | T17 | rxd1 | usb1_rcv | in | Serial data input to USB Port p1. | | V19 | cts1 | usb1_vp | in | Plus (D+) input to USB Port p1. | | Y17 | pb2 | usb1_vpo | out | Plus (D+) output from USB Port p1. | | V16 | pb3 | usb1_vmo | out | Minus (D-) output from USB Port p1. | | Y18 | pb5 | usb1_vm | in | Minus (D-) input to USB Port p1. | Table 19-36 USB Port p1 Signals # USB Port p2 | Solder Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description | |-------------|------------------|-----------------------|-----------|------------------------------------------| | D20 | s1msg | usb2_oe | out | Output enable from USB Port p2. | | E18 | s1cd | usb2_speed | out | Speed indicator signal from USB Port p2. | | D19 | s1io | usb2_rcv | in | Serial data input to USB Port p2. | | E17 | s1req | usb2_vp | in | Plus (D+) input to USB Port p2. | | C18 | s1atn | usb2_vpo | out | Plus (D+) output from USB Port p2. | | C20 | s1rst | usb2_vm | in | Minus (D-) input to USB Port p2. | | J17 | s1bsy | usb2_vmo | out | Minus (D-) output from USB Port p2. | Table 19-37 USB Port p2 Signals # 19.10.8 Chip Selects for Peripherals (CSP) The CSP port offers additional chip select signals for use with peripheral devices. | Solder Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description | |-------------|------------------|-----------------------|-----------|---------------------------------------------| | Y17 | pb2 | csp1 | out | Additional peripheral chip select signal 1. | | V16 | pb3 | csp2 | out | Additional peripheral chip select signal 2. | | W17 | pb4 | csp3 | out | Additional peripheral chip select signal 3. | | Y18 | pb5 | csp5 | out | Additional peripheral chip select signal 5. | | Y19 | pb6 | csp6 | out | Additional peripheral chip select signal 6. | | U16 | pb7 | csp7 | out | Additional peripheral chip select signal 7. | Table 19-38 CSP Signals #### 19.10.9 I2C | Solder Ball | Chip Pin<br>Name | Interface Pin<br>Name | Direction | Description | |-------------|------------------|-----------------------|-----------|--------------------------| | V15 | pb0 | i2c_d | in/out | I2C data input/output. | | W16 | pb1 | i2c_clk | out | I2C output clock signal. | Table 19-39 I2C Signals #### 19.10.10 General Port PB | Solder Ball | Name | Direction | Description | |-------------|------|-----------|-------------------------| | V15 | pb0 | in/out | General Port PB, bit 0. | | W16 | pb1 | in/out | General Port PB, bit 1. | | Y17 | pb2 | in/out | General Port PB, bit 2. | | V16 | pb3 | in/out | General Port PB, bit 3. | | W17 | pb4 | in/out | General Port PB, bit 4. | | Y18 | pb5 | in/out | General Port PB, bit 5. | | Y19 | pb6 | in/out | General Port PB, bit 6. | | U16 | pb7 | in/out | General Port PB, bit 7. | Table 19-40 General Port PB Signals # 19.11 I/O Pin Default Values All bidirectional ports are input by default. The output pins have the default values given in the table below. | | | | Interface Pin Name | | | | | | | |----------------|---------------------------|------------------|--------------------|-----------------|--------|-------------------|---------------|------------|----------------| | Solder<br>Ball | Default<br>Value | Chip Pin<br>Name | SCSI | Serial<br>Ports | ATA | Parallel<br>Ports | Shared<br>RAM | Gen<br>I/O | USB | | P17 | 0 | s0rst | s0rst | | cs0 | p0data_oe | pr_int | g5 | | | R19 | 0 | s0ack | s0ack | | cs1 | p0selectin | pr_ack | g4 | | | R20 | 0 | s0atn | s0atn | | a0 | p0autofd | a_sel | g3 | | | K20 | 0 | s0bsy | s0bsy | | a1 | p0strobe | | g2 | | | P20 | 0 | s0oe | s0oe | | a2 | p0init | | g1 | | | P19 | 1 | s0en | s0en | rts2 | dior0 | | | g7 | | | K19 | No<br>default<br>(Note 9) | s0sel | s0sel | txd2 | dior1 | | | g6 | | | B19 | 1 | s1en | s1en | rts3 | dior2 | | | g31 | | | H20 | No<br>default<br>(Note 9) | s1sel | s1sel | txd3 | dior3 | | | g30 | | | C19 | 0 | s1rst | s1rst | | diow0 | p1data_oe | | g29 | | | B20 | 0 | s1ack | s1ack | | diow1 | p1selectin | | g28 | | | C18 | 0 | s1atn | s1atn | | diow2 | p1autofd | | g27 | | | J17 | 0 | s1bsy | s1bsy | | diow3 | p1strobe | | g26 | | | A20 | 0 | s1oe | s1oe | | ext_oe | p1init | | g25 | | | Y7 | 1 | txd0 | | txd0 | | | | | | | V8 | 1 | rts0 | | rts0 | | | | | | | U19 | 1 | txd1 | | txd1 | | | | | usb_oe | | W20 | 1 | rts1 | | rts1 | | | | | usb1_spee<br>d | Table 19-41 I/O Pin Default Values **Note 9:** These pins have no default. Their condition depends upon the state of serial port hardware configuration signal hcfg as follows: ``` if (hcfg = 1), then \{s0sel = 0, s1sel = 0\} if (hcfg = 0), then \{s0sel = 1, s1sel = 1\} ``` Signal hcfg is listed in Table 19-7. # 19.12 DC Electrical Specifications #### 19.12.1 Absolute Maximum Ratings | Symbol | Parameter | Min | Max | Unit | |------------------|------------------------------|-----|-----|------| | $V_{DD}$ | DC supply voltage. | 0 | 3.6 | V | | V <sub>in</sub> | DC input voltage. | 0 | 6.5 | V | | V <sub>out</sub> | DC off-state output voltage. | 0 | 6.5 | V | | $T_{stg}$ | Storage temperature. | -65 | 150 | °C | | $T_{A}$ | Operating temperature. | 0 | 70 | °C | Table 19-42 Absolute Maximum Ratings **ESD protection:** up to 2kV (Human Body Model according to the MIL-STD-883 method 3015). **Lead temperature:** accords with the specification for a JEDEC Level 3 package. #### 19.12.2 Recommended Operating Conditions | Symbol | Parameter | Min | Typical | Max | Unit | |------------------|-------------------------------------------------------------------------------------|--------|---------|-----------|----------| | $V_{DD}$ | DC supply voltage. | 3.0 | 3.3 | 3.6 | V | | V <sub>in</sub> | DC input voltage. | 0 | - | 5.5 | V | | V <sub>out</sub> | DC off-state output voltage. | 0 | - | 5.5 | V | | $T_A$ | Operating temp. (Ambient temp. range). | 0 | - | 70 | °C | | $I_{OH}$ | High level output current:<br>pa0, pa1, pa2, pa3, pa4, pa5, pa6, pa7.<br>All other. | - | - | -12<br>-4 | mA<br>mA | | $I_{OL}$ | Low level output current:<br>pa0, pa1, pa2, pa3, pa4, pa5, pa6, pa7.<br>All other. | -<br>- | - | 12<br>4 | mA<br>mA | Table 19-43 Recommended Operating Conditions # 19.12.3 Capacitance All pins have a typical capacitance of 5 pF and a maximum capacitance of 6 pF. # 19.12.4 DC Electrical Characteristics | Symbol | Parameter | Min | Typical | Max | Unit | |-----------------|----------------------------------------------------|----------------------------------|---------|----------------------------------|------| | $V_{IH}$ | High level input voltage, all inputs except clkin. | 2.0 | - | 5.5 | V | | $V_{IL}$ | Low level input voltage, all inputs except clkin. | 0 | - | 0.8 | V | | $V_{IH}$ | High level input voltage, clkin. | $0.7~\mathrm{x}~\mathrm{V_{DD}}$ | - | 5.5 | V | | $V_{IL}$ | Low level input voltage, clkin. | 0 | - | $0.3~\mathrm{x}~\mathrm{V_{DD}}$ | V | | | Schmitt-trigger hysteresis. (See Table 19-45). | 0.5 | 0.575 | 0.65 | V | | $V_{OH}$ | High level output voltage. | 2.4 | - | $V_{DD}$ | V | | $V_{OL}$ | Low level output voltage. | 0 | - | 0.4 | V | | I <sub>in</sub> | Input leakage current. | -10 | - | 10 | μА | | $I_{ioz}$ | I/O leakage current. | -10 | - | 10 | μА | | $I_{DD}$ | Supply current. | - | 105 | 170 | mA | Table 19-44 DC Electrical Characteristics # 19.12.5 Input Buffer Types | Signal | Buffer Type | |----------------------------------------------------------------------------------------------------------------------------|---------------------| | clkin. | CMOS | | $\overline{\text{cts0}}$ , $\overline{\text{irq}}$ , $\overline{\text{nmi}}$ , $\overline{\text{reset}}$ , $\text{rxd0}$ . | TTL Schmitt Trigger | | All other. | TTL | Table 19-45 Input Buffer Types # 19.13 AC Electrical Specifications This section provides the AC characteristics for the ETRAX 100LX. The timing sequences are related to the internal 100 MHz clock. The table below lists all bus states used in the timing diagrams on the following pages. #### **Bus State Descriptions** | State | Description | Comment | |--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | T <sub>a</sub> | Activate state. The $\overline{rd}$ , $\overline{wr}$ or $\overline{inta}$ strobes are asserted in this state. Signal $\overline{cas}$ is asserted after the end of this state. | | | $T_d$ | Data state. "Data in" is sampled at the end of this state, except for EDO DRAM, where data is sampled 15 ns after the end of this state. | | | T <sub>z</sub> | Data bus turn-off state. This state is inserted between bursts, to allow the ETRAX 100LX and external units to turn off their outputs before the data bus is driven by another source. This state may overlap with a $T_{\rm ew}$ state. | | | $T_{pa}$ | Row address signal $\overline{ras}$ precharge activate state. Signal $\overline{ras}$ is set high after the end of this state. | | | $T_{pd}$ | Row address signal ras precharge state. DRAM row address is asserted after the end of this state. During DRAM refresh, column address signal cas is set low after the end of this state. | | | $T_{ra}$ | Row address signal $\overline{\text{ras}}$ activate state. Signal $\overline{\text{ras}}$ is set low after the end of this state. | | | $T_{rd}$ | Row address hold state. | | | $T_{be0}, T_{be1}$ | Burst end states. This is inserted at the end of an EDO DRAM read burst, to allow the last data of the burst to be sampled. These states may overlap with a $T_{\rm ew}$ state. | | | $T_{ew}$ | Early wait state. This state may overlap with a $T_{z,}T_{zw,}T_{be0,}$ or $T_{be1}$ state. | Inserted before T <sub>a</sub> | | $T_{lw}$ | Late wait state. | Inserted between $T_{a}$ and $T_{d}$ | | $T_{zw}$ | Turn-off wait state. This state may overlap with a $T_{\rm ew}$ state. | Inserted after $T_d$ | | $T_{xw}$ | External wait state. | | | $T_{xx}$ | Any bus state. | | Table 19-46 Bus State Descriptions #### **Wait States** The table below lists the wait state parameters used in the timing diagrams that follow. These parameters correspond to the wait state values described in Chapter 5. | Name | Description | |------|----------------------------------------------------------------| | ew | Number of early wait states. | | lw | Number of late wait states. | | ZW | Number of turn-off wait states. | | c | Column address signal cas delay. | | cw | Number of cas wait states. | | cp | Number of cas precharge wait states. | | rp | Number of ras precharge wait states. | | rs | Number of row address setup wait states. | | rh | Number of row address hold wait states. | | CZ | Number of turn-off wait states after $\overline{\text{cas}}$ . | Table 19-47 Wait States #### 19.13.1 Conditions The timing information in the chapter is valid under the operating conditions given in the table below. | Condition | Value | |-----------------|-----------------| | $T_A$ | 0°C to 70°C | | $V_{DD}$ | 3.3 V +/- 0.3 V | | Capacitive load | 50 pF | Table 19-48 Operating Conditions for Timing Information #### 19.13.2 SRAM/Flash/Peripheral Timing #### **Read Cycle** Active and inactive $\overline{cs}$ are valid for $\overline{cse0}$ , $\overline{cse1}$ , $\overline{csr0}$ , $\overline{csr1}$ , $\overline{csp0}$ and $\overline{csp4}$ . Figure 19-2 SRAM/Flash/Peripheral - Read Cycle Timing Diagram | | | | With | out Waits | tates | Add with | | |----|-------------------|---------------------------------------------------------------------------|------|-----------|-------|------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address and chip select delay from clock. (Note 10). | 2 | - | 8 | - | ns | | 2 | t <sub>rl</sub> | Read low delay from clock. | 2 | - | 8 | - | ns | | 3 | t <sub>rh</sub> | Read high delay from clock. | 2 | - | 7 | - | ns | | 4 | t <sub>cshr</sub> | Chip select high to read low. | 8 | - | - | - | ns | | 5 | t <sub>rhcs</sub> | Read high to chip select low. | 0 | - | = | - | ns | | 6 | t <sub>ds</sub> | Data in setup time to clock. | 0 | - | - | - | ns | | 7 | t <sub>dh</sub> | Data hold time from address, chip select or read, whichever occurs first. | 0 | - | - | - | ns | | 8 | $t_{\rm rhw}$ | Read inactive width within burst. | -2 | - | = | 10∙ew | ns | | 9 | $t_{rw}$ | Read active width. | 16 | 20 | - | 10·lw | ns | | 10 | t <sub>rc</sub> | Read cycle. | - | 20 | - | 10·(ew+lw) | ns | | 11 | $t_{rhr}$ | Read inactive width after burst. | 8 | - | = | 10·zw | ns | | 12 | t <sub>ar</sub> | Read inactive time after chip select or address. | -2 | - | - | 10∙ew | ns | | 13 | t <sub>pcs</sub> | pb delay from clock when used as chip selects. | 3 | - | 12 | - | ns | Table 19-49 SRAM/Flash/Peripheral Read Cycle Timing **Note 10:** Valid for $\overline{cse0}$ , $\overline{cse1}$ , $\overline{csr0}$ , $\overline{csr1}$ , $\overline{csp0}$ and $\overline{csp4}$ . #### Write Cycle, Normal Write Figure 19-3 SRAM/Flash/Peripheral Write Cycle Timing Diagram - Normal Write | | | | With | out Waits | tates | Add with | | |----|------------------|-------------------------------------------------|------|-----------|-------|------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address and chip select delay from clock. | 2 | - | 8 | - | ns | | 2 | t <sub>wl</sub> | Write low delay from clock. | 7 | - | 13 | - | ns | | 3 | t <sub>wh</sub> | Write high delay from clock. | 7 | - | 13 | - | ns | | 4 | t <sub>ww</sub> | Write pulse width. | 6 | - | - | 10·lw | ns | | 5 | $t_{\rm whw}$ | Write inactive width within burst. | 9 | - | - | 10·ew | ns | | 6 | t <sub>whl</sub> | Write inactive width after burst. | 19 | - | - | 10·zw | ns | | 7 | t <sub>wc</sub> | Write cycle time. | - | 20 | - | 10·(ew+lw) | ns | | 8 | t <sub>awl</sub> | Address and chip select setup to write low. | 2 | - | - | 10·ew | ns | | 9 | t <sub>awh</sub> | Address and chip select setup to end of write. | 11 | - | - | 10·(ew+lw) | ns | | 10 | t <sub>ahw</sub> | Address hold after write high. | 3 | - | - | - | ns | | 11 | $t_{do}$ | Data delay from clock. | 6 | - | 13 | - | ns | | 12 | $t_{ m doe}$ | Data turn on time from clock. | 6 | - | - | - | ns | | 13 | $t_{ m doz}$ | Data turn off time from clock. | 6 | - | 10 | 10·zw | ns | | 14 | $t_{\rm dwh}$ | Data valid to end of write. | 6 | - | - | 10·lw | ns | | 15 | t <sub>pcs</sub> | pb delay from clock, when used as chip selects. | 3 | - | 12 | - | ns | Table 19-50 SRAM/Flash/Peripheral Write Cycle Timing - Normal Write #### Write Cycle, Extended Write Figure 19-4 SRAM/Flash/Peripheral Write Cycle Timing Diagram - Extended Write | | | | Without Waitstates | | | Add with | | |----|-------------------|-------------------------------------------------|--------------------|-----|-----|------------------------------------------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address and chip select delay from clock. | 2 | - | 8 | - | ns | | 2 | $t_{wl}$ | Write low delay from clock. | 7 | - | 13 | - | ns | | 3 | t <sub>whx</sub> | Write high delay from clock. | 2 | - | 7 | - | ns | | 4 | t <sub>wwx</sub> | Write pulse width. | 11 | - | - | 10·lw | ns | | 5 | t <sub>whwx</sub> | Write inactive width within burst. | 4 | - | - | 10-ew | ns | | 6 | t <sub>whlx</sub> | Write inactive width after burst. | 13 | - | - | 10·zw | ns | | 7 | t <sub>wcx</sub> | Write cycle time. | - | 20 | - | 10·(ew+lw) | ns | | 8 | t <sub>awl</sub> | Address and chip select setup to write low. | 2 | - | - | 10-ew | ns | | 9 | t <sub>awhx</sub> | Address and chip select setup to end of write. | 16 | - | - | 10·(ew+lw) | ns | | 10 | t <sub>whdx</sub> | Data hold after end of write. | 2 | ± | ±' | 10-ew<br>within burst,<br>10-zw after<br>burst | ns | | 11 | $t_{do}$ | Data delay from clock. | 6 | - | 13 | - | ns | | 12 | $t_{doe}$ | Data turn on time from clock. | 6 | - | - | - | ns | | 13 | $t_{doz}$ | Data turn off time from clock. | 6 | - | 10 | 10·zw | ns | | 14 | $t_{\rm dwhx}$ | Data valid to end of write. | 11 | - | - | 10·lw | ns | | 15 | t <sub>pcs</sub> | pb delay from clock, when used as chip selects. | 3 | - | 12 | - | ns | Table 19-51 SRAM/Flash/Peripheral Write Cycle Timing - Extended Write Timing # 19.13.3 Synchronous DRAM #### 50/100 MHz Mode, Read Figure 19-5 Synchronous DRAM, 50/100 MHz Mode - Read Timing Diagram | No | Name | Explanation | Min | Nom | Max | Unit | |----|--------------------|------------------------------------|-----|-----|-----|------| | 1 | t <sub>sclks</sub> | Clock period, 50 MHz mode | - | 20 | - | ns | | 2 | t <sub>sclkf</sub> | Clock period, 100 MHz mode | - | 10 | - | ns | | 3 | t <sub>sas</sub> | Address setup time to clock | 9 | - | - | ns | | 4 | t <sub>sah</sub> | Address hold time from clock | 9 | - | - | ns | | 5 | t <sub>scs</sub> | sdram_csd0/1 setup time to clock | 4 | - | - | ns | | 6 | t <sub>ch</sub> | sdram_csd0/1 hold time from clock. | 4 | - | - | ns | | 7 | t <sub>rs</sub> | sdram_ras setup time to clock | 9 | - | - | ns | | 8 | t <sub>rh</sub> | sdram_ras hold time from clock | 9 | - | - | ns | | 9 | t <sub>scs</sub> | sdram_cas setup time to clock | 9 | - | - | ns | | 10 | t <sub>sch</sub> | sdram_cas hold time from clock | 9 | - | - | ns | | 11 | t <sub>sws</sub> | sdram_we setup time to clock | 9 | - | - | ns | | 12 | t <sub>swh</sub> | sdram_we hold time from clock | 9 | - | - | ns | | 13 | t <sub>sds</sub> | sdram_dqm setup time to clock | 9 | - | - | ns | | 14 | t <sub>sdh</sub> | sdram_dqm hold time from clock | 9 | - | - | ns | | 15 | t <sub>sdis</sub> | Data in setup time to clock | 1 | - | - | ns | | 16 | t <sub>sdih</sub> | Data in hold time from clock | 3 | - | - | ns | Table 19-52 Synchronous DRAM, 50/100 MHz Mode - Read Timing # sdram\_clk 50 MHz sdram\_csd0 sdram\_csd0 sdram\_csd1 sdram\_csd0 sdram\_csd1 sdram\_csd0 sdram\_csd1 sdram\_csd0 sdram\_csd1 sdram\_csd0 sdram\_csd1 7 8 11 12 sdram\_we sdram\_dqm #### 50/100 MHz Mode, Write Data out precharge Figure 19-6 Synchronous DRAM, 50/100 MHz Mode - Write Timing Diagram write activate | No | Name | Explanation | Min | Nom | Max | Unit | |----|--------------------|------------------------------------|-----|-----|-----|------| | 1 | t <sub>sclks</sub> | Clock period, 50 MHz mode | - | 20 | - | ns | | 2 | t <sub>sclkf</sub> | Clock period, 100 MHz mode | - | 10 | - | ns | | 3 | t <sub>sas</sub> | Address setup time to clock | 9 | - | - | ns | | 4 | t <sub>sah</sub> | Address hold time from clock | 9 | - | - | ns | | 5 | t <sub>scs</sub> | sdram_csd0/1 setup time to clock | 4 | - | - | ns | | 6 | t <sub>sch</sub> | sdram_csd0/1 hold time from clock. | 4 | - | - | ns | | 7 | t <sub>srs</sub> | sdram_ras setup time to clock | 9 | - | - | ns | | 8 | t <sub>srh</sub> | sdram_ras hold time from clock | 9 | - | - | ns | | 9 | t <sub>scs</sub> | sdram_cas setup time to clock | 9 | - | - | ns | | 10 | t <sub>sch</sub> | sdram_cas hold time from clock | 9 | - | - | ns | | 11 | t <sub>sws</sub> | sdram_we setup time to clock | 9 | - | - | ns | | 12 | t <sub>swh</sub> | sdram_we hold time from clock | 9 | - | - | ns | | 13 | t <sub>sds</sub> | sdram_dqm setup time to clock | 9 | - | - | ns | | 14 | t <sub>sdh</sub> | sdram_dqm hold time from clock | 9 | - | - | ns | | 15 | t <sub>sdoe</sub> | Data out turn on time to clock | - | - | 11 | ns | | 16 | t <sub>sdoz</sub> | Data out turn off time from clock | - | - | 13 | ns | | 17 | t <sub>sdos</sub> | Data out setup time to clock | 7 | - | - | ns | | 18 | t <sub>sdoh</sub> | Data out hold time from clock | 9 | - | - | ns | Table 19-53 Synchronous DRAM, 50/100 MHz Mode - Write Timing #### DDR 100 MHz Mode, Read Figure 19-7 DDR 100 MHz Mode - Read Timing Diagram | No | Name | Explanation | Min | Nom | Max | Unit | |----|--------------------|------------------------------------|------|-----|-----|------| | 1 | t <sub>sclkf</sub> | Clock period | - | 10 | - | ns | | 2 | t <sub>sas</sub> | Address setup time to clock | 9 | - | - | ns | | 3 | t <sub>sah</sub> | Address hold time from clock | 9 | - | - | ns | | 4 | t <sub>scs</sub> | sdram_csd0/1 setup time to clock | 4 | - | - | ns | | 5 | t <sub>sch</sub> | sdram_csd0/1 hold time from clock. | 4 | - | - | ns | | 6 | t <sub>srs</sub> | sdram_ras setup time to clock | 9 | - | - | ns | | 7 | t <sub>srh</sub> | sdram_ras hold time from clock | 9 | - | - | ns | | 8 | t <sub>scs</sub> | sdram_cas setup time to clock | 9 | - | - | ns | | 9 | t <sub>sch</sub> | sdram_cas hold time from clock | 9 | - | - | ns | | 10 | t <sub>sws</sub> | sdram_we setup time to clock | 9 | - | - | ns | | 11 | t <sub>swh</sub> | sdram_we hold time from clock | 9 | - | - | ns | | 12 | $t_{dsdq}$ | sdram_dqs turn off time to clock | 22 | - | - | ns | | 13 | $t_{dsdqe}$ | sdram_dqs turn on time from clock | 24 | - | - | ns | | 14 | t <sub>dsdis</sub> | Data in setup time from sdram_dqs | -0.5 | - | - | ns | | 15 | t <sub>dsdih</sub> | Data in hold time from sdram_dqs | 3 | - | - | ns | Table 19-54 DDR 100 MHz Mode - Read Timing # sdram\_clk 100MHz sdram\_csd0 sdram\_csd0 sdram\_csd1 sdram\_csd sdram\_csd sdram\_dqm sdram\_dqm sdram\_dqm sdram\_dqm sdram\_dqm pata out Command precharge activate write write #### **DDR 100 MHz Mode, Write** Figure 19-8 DDR 100 MHz Mode - Write Timing Diagram | No | Name | Explanation | Min | Nom | Max | Unit | |----|--------------------|------------------------------------------------|-----|-----|-----|------| | 1 | t <sub>sclkf</sub> | Clock period | - | 10 | - | ns | | 2 | t <sub>sas</sub> | Address setup time to clock | 9 | - | - | ns | | 3 | t <sub>sah</sub> | Address hold time from clock | 9 | - | - | ns | | 4 | t <sub>scs</sub> | sdram_csd0/1 setup time to clock | 4 | - | = | ns | | 5 | t <sub>sch</sub> | sdram_csd0/1 hold time from clock. | 4 | - | = | ns | | 6 | t <sub>srs</sub> | sdram_ras setup time to clock | 9 | - | - | ns | | 7 | t <sub>srh</sub> | sdram_ras hold time from clock | 9 | - | - | ns | | 8 | t <sub>scs</sub> | sdram_cas setup time to clock | 9 | - | - | ns | | 9 | t <sub>sch</sub> | sdram_cas hold time from clock | 9 | - | - | ns | | 10 | t <sub>sws</sub> | sdram_we setup time to clock | 9 | - | - | ns | | 11 | ts <sub>wh</sub> | sdram_we hold time from clock | 9 | - | = | ns | | 12 | $t_{dsdmsr}$ | sdram_dqm setup time to sdram_dqs rising edge | 6 | - | - | ns | | 13 | $t_{dsdmhr}$ | sdram_dqm hold time from sdram_dqs rising edge | 2.5 | - | - | ns | | 14 | $t_{dsdmsf}$ | sdram_dqm setup time to sdram_dqs falling edge | 1.5 | - | = | ns | | 15 | $t_{dsdmhf}$ | sdram_dqm hold time to sdram_dqs falling edge | 8 | - | - | ns | | 16 | $t_{dsdoe}$ | Data out turn on time to sdram_dqs | - | - | 28 | ns | | 17 | $t_{\rm dsdoz}$ | Data out turn off time from sdram_dqs | - | - | 3 | ns | | 18 | $t_{dsdos}$ | Data out setup time to sdram_dqs | 8 | - | - | ns | | 19 | $t_{dsdoh}$ | Data out hold time from sdram_dqs | 3 | - | - | ns | Table 19-55 DDR 100 MHz Mode - Write Timing # 19.13.4 Asynchronous DRAM #### Fast Page Mode, Read Figure 19-9 Asynchronous DRAM, Fast Page Mode - Read Timing Diagram | | | | With | out Waits | tates | Add with | | |----|-------------------|-------------------------------------------------------------------------------------------|------|-----------|-------|--------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address delay from clock. | 2 | - | 8 | - | ns | | 2 | t <sub>casl</sub> | cas low delay from clock. | 2 | - | 8 | 5-c | ns | | 3 | t <sub>cash</sub> | cas high delay from clock. | 2 | - | 8 | - | ns | | 4 | $t_{ds}$ | Data in setup time to clock. | 0 | - | - | - | ns | | 5 | t <sub>dh</sub> | Data in hold time from $\overline{\text{cas}}$ or address change, whichever occurs first. | 0 | - | - | - | ns | | 6 | t <sub>rasl</sub> | ras low time from clock. | 3 | - | 10 | - | ns | | 7 | t <sub>rash</sub> | ras high time from clock. | 7 | - | 13 | - | ns | | 8 | t <sub>rcs</sub> | $\overline{\text{dramwe}}$ high setup time to $\overline{\text{cas}}$ low. | 4 | - | - | 5·c | ns | | 9 | $t_{rch}$ | $\overline{\text{dramwe}}$ high hold time from $\overline{\text{cas}}$ high. | 2 | - | - | - | ns | | 10 | t <sub>cas</sub> | cas pulse width. | 7 | - | - | 10·cw - 5·c | ns | | 11 | $t_{cp}$ | cas precharge time. | 7 | - | - | 10·cp + 5·c | ns | | 12 | t <sub>pc</sub> | cas cycle time. | - | 20 | - | 10·(cp + cw) | ns | | 13 | $t_{rp}$ | ras precharge time. | 14 | - | - | 10·(rp + rs) | ns | | 14 | t <sub>asr</sub> | Row address setup time to $\overline{\text{ras}}$ . | 9 | - | - | 10⋅rs | ns | | 15 | t <sub>rah</sub> | Row address hold time from $\overline{ras}$ . | 4 | - | - | 10∙rh | ns | | 16 | t <sub>asc</sub> | Column address setup time to $\overline{\text{cas}}$ . | 7 | - | - | 10·cp + 5·c | ns | | 17 | t <sub>cah</sub> | Column address hold time from $\overline{\text{cas}}$ . | 7 | - | - | 10·cw - 5·c | ns | | 18 | t <sub>be</sub> | casb delay from clock, when used as byte enable (bankwise mode). | 2 | - | 8 | - | ns | Table 19-56 Asynchronous DRAM, Fast Page Mode - Read Timing #### **EDO DRAM, Read** Figure 19-10 EDO DRAM - Read Timing Diagram | | | | With | out Waits | states | Add with | | |----|-------------------|------------------------------------------------------------------------|------|-----------|--------|----------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address delay from clock. | 2 | - | 8 | - | ns | | 2 | t <sub>casl</sub> | cas low delay from clock. | 2 | - | 8 | 5·c | ns | | 3 | t <sub>cash</sub> | cas high delay from clock. | 2 | - | 8 | - | ns | | 4 | $t_{dd}$ | Data in valid delay from clock. | - | - | 15 | - | ns | | 5 | $t_{coh}$ | Data in hold time from cas low. | 4 | - | - | (-10)·cp - 5·c | ns | | 6 | t <sub>rasl</sub> | ras low time from clock. | 3 | - | 10 | - | ns | | 7 | t <sub>rash</sub> | ras high time from clock. | 8 | - | 13 | - | ns | | 8 | t <sub>rcs</sub> | dramwe high setup time to cas low. | 4 | - | - | 5·c | ns | | 9 | t <sub>dh</sub> | Data in hold time from dramwe low or ras high, whichever occurs first. | 0 | - | - | - | ns | | 10 | t <sub>cas</sub> | cas pulse width. | 7 | - | - | 10·cw - 5·c | ns | | 11 | $t_{cp}$ | cas precharge time. | 7 | - | - | 10·cp + 5·c | ns | | 12 | t <sub>pc</sub> | cas cycle time. | - | 20 | - | 10·(cp + cw) | ns | | 13 | t <sub>rp</sub> | ras precharge time. | 14 | - | - | 10·(rp + rs) | ns | | 14 | t <sub>asr</sub> | Row address setup time to ras. | 9 | - | - | 10·rs | ns | | 15 | t <sub>rah</sub> | Row address hold time from $\overline{\text{ras}}$ . | 4 | - | 12 | 10∙rh | ns | | 16 | t <sub>asc</sub> | Column address setup time to $\overline{\text{cas}}$ . | 7 | - | - | 10·cp + 5·c | ns | | 17 | t <sub>cah</sub> | Column address hold time from $\overline{\text{cas}}$ . | 7 | - | - | 10·cw - 5·c | ns | | 18 | t <sub>be</sub> | casb delay from clock, when used as byte enable (bankwise mode). | 2 | - | 8 | - | ns | | 19 | t <sub>wel</sub> | dramwe low delay from clock. | 7 | - | 13 | - | ns | | 20 | t <sub>wew</sub> | dramwe pulse width after EDO read burst. | 7 | - | - | 10-cz | ns | Table 19-57 EDO DRAM - Read Timing #### Asynchronous DRAM, Write Figure 19-11 Asynchronous DRAM - Write Timing Diagram | | | | With | out Waits | states | Add with | | |----|-------------------|------------------------------------------------------------------|------|-----------|--------|--------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address delay from clock. | 2 | - | 8 | - | ns | | 2 | t <sub>casl</sub> | cas low delay from clock. | 2 | - | 8 | 5·c | ns | | 3 | t <sub>cash</sub> | cas high delay from clock. | 2 | - | 8 | - | ns | | 4 | $t_{doe}$ | Data out turn on time from clock. | 7 | - | - | - | ns | | 5 | $t_{doz}$ | Data out turn off time from clock. | - | - | 10 | 10·cz | ns | | 6 | t <sub>rasl</sub> | ras low time from clock. | 3 | - | 10 | - | ns | | 7 | t <sub>rash</sub> | ras high time from clock. | 8 | - | 13 | - | ns | | 8 | t <sub>wcs</sub> | dramwe low setup time to cas low. | 2 | - | - | - | ns | | 9 | t <sub>weh</sub> | dramwe low hold time from cas high. | 1 | - | - | - | ns | | 10 | t <sub>cas</sub> | cas pulse width. | 7 | - | - | 10·cw - 5·c | ns | | 11 | t <sub>cp</sub> | cas precharge time. | 7 | - | - | 10·cp + 5·c | ns | | 12 | t <sub>pc</sub> | cas cycle time. | - | 20 | - | 10·(cp + cw) | ns | | 13 | $t_{rp}$ | ras precharge time. | 14 | - | - | 10·(rp + rs) | ns | | 14 | t <sub>asr</sub> | Row address setup time to ras. | 9 | - | - | 10·rs | ns | | 15 | t <sub>rah</sub> | Row address hold time from ras. | 4 | - | 12 | 10∙rh | ns | | 16 | t <sub>asc</sub> | Column address setup time to $\overline{\text{cas}}$ . | 7 | - | - | 10·cp + 5·c | ns | | 17 | t <sub>cah</sub> | Column address hold time from $\overline{\text{cas}}$ . | 7 | - | - | 10·cw - 5·c | ns | | 18 | t <sub>be</sub> | casb delay from clock, when used as byte enable (bankwise mode). | 2 | - | 8 | - | ns | | 19 | $t_{do}$ | Data delay from clock. | 6 | - | - | - | ns | | 20 | $t_{dsc}$ | Data setup to cas low. | 2 | - | - | 5·c | ns | | 21 | $t_{ m dhc}$ | Data hold after cas low. | 10 | - | - | 10·cw - 5·c | ns | Table 19-58 Asynchronous DRAM - Write Timing # CAS Before RAS Refresh Cycle Figure 19-12 $\overline{CAS}$ Before $\overline{RAS}$ Refresh Cycle Timing Diagram | | | | With | out Waits | tates | Add with | | |----|-------------------|----------------------------|------|-----------|-------|-------------------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address delay from clock. | 2 | - | 8 | - | ns | | 2 | t <sub>casl</sub> | cas low delay from clock. | 2 | - | 8 | 5·c | ns | | 3 | t <sub>cash</sub> | cas high delay from clock. | 2 | - | 8 | - | ns | | 4 | t <sub>rasl</sub> | ras low time from clock. | 3 | - | 10 | - | ns | | 5 | t <sub>rash</sub> | ras high time from clock. | 8 | - | 13 | - | ns | | 6 | $t_{rpc}$ | ras to cas precharge time. | 2 | - | - | 10·rp | ns | | 7 | t <sub>csr</sub> | cas setup time to ras. | 7 | - | - | 10·rs | ns | | 8 | t <sub>ras</sub> | ras pulse width. | 40 | - | - | $10\cdot(rh + cp + cw)$ | ns | | 9 | $t_{rp}$ | ras precharge time. | 14 | - | - | 10·(rp + rs) | ns | Table 19-59 $\overline{CAS}$ Before $\overline{RAS}$ Refresh Cycle Timing # 19.13.5 General Bus Interface Timing Diagrams #### **Data Turn-off Timing** This diagram specifies the relationships of the data turn-off timing of Asynchronous DRAM and non-DRAM bursts. Figure 19-13 Data Turn-off Timing Diagram | | | | Without Waitstates | | | Add with | | |----|-------------------|----------------------------------------------|--------------------|-----|-----|------------|------| | No | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>a</sub> | Address delay from clock. | 2 | - | 8 | - | ns | | 2 | $t_{rdo}$ | Read high to data out. | 13 | - | - | 10·zw | ns | | 3 | t <sub>cr</sub> | cas high to read low. | 7 | - | - | 10·cz | ns | | 4 | t <sub>welr</sub> | dramwe low to read low after EDO read burst. | 13 | - | - | 10·cz | ns | | 5 | $t_{\rm dozr}$ | Data out turn-off before read low. | 5 | - | - | - | ns | Table 19-60 Data Turn-off Timing #### **External Interrupt Acknowledge Cycle** The external interrupt acknowledge cycle always uses a maximum number of waitstates. Figure 19-14 External Interrupt Acknowledge Cycle Timing Diagram | No | Name | Explanation | Min | Nom | Max | Unit | |----|-----------------|-----------------------------------|-----|-----|-----|------| | 1 | t <sub>il</sub> | inta low delay from clock. | 2 | - | 8 | ns | | 2 | t <sub>ih</sub> | inta high delay from clock. | 2 | - | 7 | ns | | 3 | $t_{iw}$ | inta pulse width. | 167 | 170 | 172 | ns | | 4 | t <sub>ds</sub> | Data in setup time to clock. | 0 | - | - | ns | | 5 | t <sub>dh</sub> | Data in hold time from inta high. | 0 | - | - | ns | | 6 | $t_{ihr}$ | inta high to read low. | 38 | - | - | ns | Table 19-61 External Interrupt Acknowledge Cycle Timing #### Timing of wait and rerun Figure 19-15 Wait and Rerun Timing Diagram | No | Name | Explanation | Min | Nom | Max | Note | Unit | |----|------------------|------------------------------------------------------------------------|-----|-----|-----|---------|------| | 1 | t <sub>xws</sub> | wait setup time to clock. | 1 | - | - | Note 11 | ns | | 2 | t <sub>xwh</sub> | wait hold time from clock. | 2 | - | - | Note 11 | ns | | 3 | t <sub>xwi</sub> | wait sampled to end of bus cycle (wait not activated). | 30 | 30 | 30 | Note 12 | ns | | 4 | t <sub>xwa</sub> | wait sampled to end of bus cycle (wait activated). | 50 | - | 80 | Note 12 | ns | | 5 | t <sub>res</sub> | $\overline{\text{rerun}}$ setup time to $\overline{\text{wait}}$ high. | 1 | - | - | - | ns | | 6 | t <sub>reh</sub> | rerun hold time after wait high. | 1 | - | - | - | ns | Table 19-62 Wait and Rerun Timing - **Note 11:** The wait signal is synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. - Note 12: The wait signal is sampled three clock cycles before the end of the bus cycle, taking only the internal wait states into consideration. To recognize wait, a number of internal lw and/or ew waitstates must be added. Typically, three internal wait states are necessary, but this depends on the external wait state logic. ### 19.13.6 External DMA Timing Diagrams #### External DMA, Handshake Mode Timing, Read Figure 19-16 External DMA, Handshake Mode Timing, Read The timing diagram above is shown with **dreq** and **dack** configured to be active high, and with two late waitstates (The number of waitstates is just an example however; there does not need to be two waitstates.). | | | | Without Waitstates | | | Add with | | |--------|-------------------|-----------------------------------------------------------------------------------------------------------|--------------------|-----|-----|----------------|------| | Number | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>ckp</sub> | Internal clock period | - | 10 | - | - | ns | | 2 | t <sub>drs</sub> | dreq setup time to clock (note 13) | 1 | - | - | - | ns | | 3 | t <sub>drh</sub> | <b>dreq</b> hold time from clock (note 13) | 2 | - | - | - | ns | | 4 | $t_{dack}$ | dack delay from clock | 8 | - | 17 | - | ns | | 5 | t <sub>drda</sub> | dreq to dack latency | 4*t <sub>ckp</sub> | - | - | - | ns | | 6 | $t_{\rm dadr}$ | dreq hold time from dack | 0 | - | - | - | ns | | 7 | t <sub>dai</sub> | dreq inactive to dack inactive latency (note 14) | 2*t <sub>ckp</sub> | - | - | - | ns | | 8 | t <sub>rwda</sub> | $\overline{\mathbf{wr}}$ (extended write) high or $\overline{\mathbf{rd}}$ high to $\mathbf{dack}$ active | 5 | - | - | - | ns | | 9 | t <sub>wrda</sub> | $\overline{\mathbf{wr}}$ (normal write) high to $\mathbf{dack}$ active | 10 | - | - | - | ns | | 10 | t <sub>dard</sub> | dack active to $\overline{rd}$ low | 1 | - | - | 10*max(0,ew-1) | ns | | 11 | t <sub>rhda</sub> | $\overline{rd}$ high to dack inactive | 5 | - | - | - | ns | Table 19-63 External DMA, Handshake Mode Timing, Read - **Note 13:** The **dreq** signal is synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. - Note 14: $t_{dai}$ will be the maximum of $2*t_{ckp}$ and the time to the end of the Td state of the external DMA bus cycle. **External DMA, Handshake Mode Timing, Write** Tz Figure 19-17 External DMA, Handshake Mode Timing, Write The timing diagram above is shown with **dreq** and **dack** configured to be active high, and with two late waitstates (The number of waitstates is just an example however; there does not need to be two waitstates.). | | | | With | out Waits | tates | Add with | | |--------|-------------------|----------------------------------------------------------------------------|--------------------|-----------|-------|----------------|------| | Number | Name | Explanation | Min | Nom | Max | Waitstates | Unit | | 1 | t <sub>ckp</sub> | Internal clock period | - | 10 | - | - | ns | | 2 | t <sub>drs</sub> | dreq setup time to clock (note 15) | 1 | - | - | - | ns | | 3 | t <sub>drh</sub> | <b>dreq</b> hold time from clock (note 15) | 2 | - | - | - | ns | | 4 | t <sub>dack</sub> | dack delay from clock | 8 | - | 17 | - | ns | | 5 | $t_{drda}$ | dreq to dack latency | 4*t <sub>ckp</sub> | - | - | - | ns | | 6 | $t_{\rm dadr}$ | dreq hold time from dack | 0 | - | - | - | ns | | 7 | t <sub>dai</sub> | dreq inactive to dack inactive latency (note 16) | 2*t <sub>ckp</sub> | - | - | - | ns | | 8 | t <sub>rwda</sub> | wr (extended write) high or rd high to dack active | 5 | - | - | - | ns | | 9 | t <sub>wrda</sub> | wr (normal write) high to dack active | 10 | - | - | - | ns | | 10 | $t_{\rm dawr}$ | dack active to $\overline{\mathbf{wr}}$ low | 6 | - | - | 10*max(0,ew-1) | ns | | 11 | t <sub>whda</sub> | wr (normal write) high to dack inactive | 10 | - | - | - | ns | | 12 | t <sub>weda</sub> | $\overline{\mathbf{wr}}$ (extended write) high to $\mathbf{dack}$ inactive | 5 | - | - | - | ns | Table 19-64 External DMA, Handshake Mode Timing, Write - Note 15: The **dreq** signal is synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. - Note 16: $t_{dai}$ will be the maximum of $2*t_{ckp}$ and the time to the end of the Td state of the external DMA bus cycle. ### External DMA, Burst Mode Timing, Read Figure 19-18 External DMA, Burst Mode Timing, Read The timing diagram above is shown with **dreq** and **dack** configured to be active high, and with 0 waitstates. | | | | With | out Waits | tates | | | |--------|-------------------|----------------------------------------------------|--------------------|-----------|-------|---------------------|------| | Number | Name | Explanation | Min | Nom | Max | Add with Waitstates | Unit | | 1 | $t_{ckp}$ | Internal clock period | - | 10 | - | - | ns | | 2 | t <sub>drs</sub> | <b>dreq</b> setup time to clock (note 17) | 1 | - | - | - | ns | | 3 | t <sub>drh</sub> | <b>dreq</b> hold time from clock (note 17) | 2 | - | - | - | ns | | 4 | $t_{dack}$ | dack delay from clock | 8 | - | 17 | - | ns | | 5 | t <sub>drda</sub> | dreq to dack latency | 4*t <sub>ckp</sub> | - | - | - | ns | | 6 | $t_{\rm dadr}$ | dreq hold time from dack | 0 | - | - | - | ns | | 7 | t <sub>dadi</sub> | dreq inactive time from dack | - | - | 12 | 10*(max(0,ew-1)+lw) | ns | | 8 | t <sub>rwda</sub> | wr (extended write) high or rd high to dack active | 5 | - | - | - | ns | | 9 | t <sub>wrda</sub> | wr (normal write) high to dack active | 10 | - | - | - | ns | | 10 | t <sub>dard</sub> | dack active to $\overline{rd}$ low | 1 | - | - | 10*max(0,ew-1) | ns | | 11 | t <sub>rhda</sub> | rd high to dack inactive | 5 | - | - | - | ns | | 12 | t <sub>dair</sub> | dack inactive to $\overline{rd}$ low | 1 | - | - | 10*zw | ns | | 13 | t <sub>daiw</sub> | dack inactive to $\overline{\mathbf{wr}}$ low | 6 | - | - | 10*zw | ns | | 14 | t <sub>dada</sub> | dack inactive to dack active time | 17 | - | - | - | ns | Table 19-65 External DMA, Burst Mode Timing, Read **Note 17:** The **dreq** signal is synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. ### **External DMA, Burst Mode Timing, Write** Figure 19-19 External DMA, Burst Mode Timing, Write The timing diagram above is shown with **dreq** and **dack** configured to be active high, and with 0 waitstates. | | | | With | out Waits | tates | | | |--------|-------------------|------------------------------------------------------------------------------|--------------------|-----------|-------|---------------------|------| | Number | Name | Explanation | Min | Nom | Max | Add with Waitstates | Unit | | 1 | t <sub>ckp</sub> | Internal clock period | - | 10 | - | - | ns | | 2 | t <sub>drs</sub> | <b>dreq</b> setup time to clock (note 18) | 1 | - | - | - | ns | | 3 | t <sub>drh</sub> | <b>dreq</b> hold time from clock (note 18) | 2 | - | - | - | ns | | 4 | t <sub>dack</sub> | dack delay from clock | 8 | - | 17 | - | ns | | 5 | t <sub>drda</sub> | dreq to dack latency | 4*t <sub>ckp</sub> | - | - | - | ns | | 6 | $t_{\rm dadr}$ | dreq hold time from dack | 0 | - | - | - | ns | | 7 | t <sub>dadi</sub> | dreq inactive time from dack | - | - | 12 | 10*(max(0,ew-1)+lw) | ns | | 8 | t <sub>rwda</sub> | <ul><li>wr (extended write) high or</li><li>rd high to dack active</li></ul> | 5 | - | - | - | ns | | 9 | t <sub>wrda</sub> | wr (normal write) high to dack active | 10 | - | - | - | ns | | 10 | $t_{\rm dawr}$ | dack active to $\overline{\mathbf{wr}}$ low | 6 | - | - | 10*max(0,ew-1) | ns | | 11 | t <sub>whda</sub> | wr (normal write) high to dack inactive | 10 | - | - | - | ns | | 12 | t <sub>weda</sub> | wr (extended write) high to dack inactive | 5 | - | - | - | ns | | 13 | t <sub>dair</sub> | $dack$ inactive to $\overline{rd}$ low | 1 | - | - | 10*zw | ns | | 14 | t <sub>daiw</sub> | dack inactive to $\overline{\mathbf{wr}}$ low | 6 | - | - | 10*zw | ns | | 15 | t <sub>dada</sub> | dack inactive to dack active time | 17 | - | - | - | ns | Table 19-66 External DMA, Burst Mode Timing, Write **Note 18:** The **dreq** signal is synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. # 19.13.7 $\overline{\text{irq}}$ and $\overline{\text{nmi}}$ Timing Figure 19-20 **irq** and **nmi** Timing | Number | Name | Explanation | Min | Nom | Max | Unit | |--------|-------------------|-----------------------------------------------------------------------------------|-----|-----|-----|------| | 1 | t <sub>irqs</sub> | $\overline{\text{irq}}$ and $\overline{\text{nmi}}$ setup time to clock (note 19) | 6 | - | - | ns | | 2 | t <sub>irqh</sub> | irq and nmi hold time from clock (note 19) | -3 | - | - | ns | Table 19-67 $\overline{irq}$ and $\overline{nmi}$ Timing **Note 19:** The $\overline{irq}$ and $\overline{nmi}$ signals are synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. # 19.13.8 Shared RAM Interface Timing #### Shared RAM Interface, Peripheral Read and Write Cycle Timing Figure 19-21 Shared RAM Interface, Peripheral Read and Write Cycle Timing | Number | Name | Explanation | Min | Nom | Max | Unit | |--------|-------------------|------------------------------------------------------------------------|---------------------|--------------------|--------------------|------| | 1 | t <sub>ckp</sub> | Internal clock period | - | 10 | - | ns | | 2 | t <sub>srqs</sub> | pr_req setup time to clock (note 20) | 2 | - | - | ns | | 3 | t <sub>srqh</sub> | pr_req hold time from clock (note 20) | 1 | - | - | ns | | 4 | t <sub>srs</sub> | Peripheral address, peripheral data and rd_wr setup time to pr_req | 0 | - | - | ns | | 5 | t <sub>srh</sub> | Peripheral address, peripheral data and rd_wr hold time from pr_req | 0 | - | - | ns | | 6 | t <sub>sroe</sub> | Data output enable time from clock | 7 | - | - | ns | | 7 | t <sub>srdv</sub> | Data to peripheral valid from clock | - | - | 17 | ns | | 8 | t <sub>srds</sub> | Data to peripheral setup time to $\overline{pr\_ack}$ | 27 | - | - | ns | | 9 | t <sub>srdh</sub> | Data to peripheral hold time from $\overline{pr\_req}$ | 1 | - | - | ns | | 10 | t <sub>srad</sub> | pr_ack delay from clock | 3 | - | 12 | ns | | 11 | t <sub>srap</sub> | pr_req delay from pr_ack | 0 | - | - | ns | | 12 | t <sub>srra</sub> | pr_req to pr_ack latency | 12*t <sub>ckp</sub> | - | - | ns | | 13 | t <sub>srri</sub> | $\overline{pr\_req}$ inactive to $\overline{pr\_ack}$ inactive latency | 2*t <sub>ckp</sub> | 2*t <sub>ckp</sub> | 2*t <sub>ckp</sub> | ns | Table 19-68 Shared RAM Interface, Peripheral Read and Write Cycle Timing Note 20: The <u>pr\_req</u> signal is synchronized internally. Setup and hold times need to be taken into consideration only if detection in a specific clock cycle is required. # Shared RAM Interface, a\_sel Timing Figure 19-22 Shared RAM Interface, a\_sel Timing | Number | Name | Explanation | Min | Nom | Max | Unit | |--------|-------------------|------------------------------------------|-----|-----|-----|------| | 1 | t <sub>a</sub> | Address and chip select delay from clock | 2 | - | 8 | ns | | 2 | t <sub>srsh</sub> | a_sel high delay from clock | 3 | - | 10 | ns | | 3 | t <sub>srsl</sub> | a_sel low delay from clock | 3 | - | 11 | ns | Table 19-69 Shared RAM Interface, a\_sel Timing # **Shared RAM Interface, Interrupt Timing** Figure 19-23 Shared RAM Interface, Interrupt Timing | Number | Name | Explanation | Min | Nom | Max | Unit | |--------|-------------------|---------------------------|-----|-----|-----|------| | 1 | t <sub>sriw</sub> | intio pulse width | 25 | - | - | ns | | 2 | t <sub>srpw</sub> | <b>pr_int</b> pulse width | 590 | 600 | 610 | ns | Table 19-70 Shared RAM Interface, Interrupt Timing # 19.13.9 Network Interface Timing Figure 19-24 Network Interface Timing | Number | Name | Explanation | Min | Nom | Max | Unit | |--------|-------------------|---------------------------------------------------------------------------------------------------------------|----------|-----|-----|----------| | 1 | t <sub>etcp</sub> | txclk and rxclk clock period, MII operation txclk and rxclk clock period, SNI operation | 35<br>70 | - | - | ns<br>ns | | 2 | t <sub>etcw</sub> | txclk and rxclk pulse width | 10 | - | - | ns | | 3 | t <sub>etdd</sub> | txdata, txen and txer delay from txclk | 4 | - | 16 | ns | | 4 | t <sub>etds</sub> | rxdata, rxdv and rxer setup time to rxclk | 3 | - | - | ns | | 5 | t <sub>etdh</sub> | rxdata, rxdv and rxer hold time from rxclk | 1 | - | - | ns | | 6 | t <sub>etcd</sub> | <b>txer</b> delay from internal clock, when used as 25MHz clock output | 7 | - | 16 | ns | | 7 | t <sub>etmd</sub> | txdata, txer, mdc and mdio delay from internal clock, when controlled by the R_NETWORK_MGM_CTRL mode register | 7 | - | 15 | ns | | 8 | t <sub>etme</sub> | mdio output enable from internal clock | 6 | - | - | ns | | 9 | t <sub>etmz</sub> | mdio turn off time from internal clock | 6 | - | 14 | ns | Table 19-71 Network Interface Timing # 19.13.10 Reset and Clock Timing #### **System Clock Timing** Figure 19-25 System Clock Timing Diagram | No | Name | Explanation | Min | Nom | Max | Unit | |----|-------------------|--------------------------------------|-----|----------------------|-----|------| | 1 | t <sub>clkp</sub> | Input clock period (Note 21). | 49 | 50 | 51 | ns | | 2 | t <sub>clkh</sub> | Input clock high time. | 15 | - | - | ns | | 3 | t <sub>clkl</sub> | Input clock low time. | 15 | - | - | ns | | 4 | t <sub>clkd</sub> | Input clock to internal clock delay. | 0.9 | 2.5 | 4 | ns | | 5 | t <sub>ckp</sub> | Internal clock period. | - | $0.2 \cdot t_{clkp}$ | - | ns | Table 19-72 System Clock Timing Note 21: Some applications may require less tolerance on the clock period. For example, if txer is configured as the clock for Fast Ethernet, greater clock cycle accuracy is needed (see 100BASE-T standard: IEEE 802.3u.). # **Reset Timing** Figure 19-26 Reset Timing Diagram | No | Name | Explanation | Min | Nom | Max | Unit | |----|-------------------|-----------------------------------|---------------------|-----|-----|------| | 1 | t <sub>ress</sub> | reset setup to clkin. (Note 22). | 2 | - | - | ns | | 2 | t <sub>resh</sub> | reset hold from clkin. (Note 22). | 1 | - | - | ns | | 3 | t <sub>resw</sub> | reset pulse width. | 5·t <sub>clkp</sub> | - | - | ns | | 4 | t <sub>resd</sub> | reset to output delay. | - | - | 25 | ns | Table 19-73 Reset Timing **Note 22:** The reset signal is internally synchronized. Setup and hold times can be ignored unless recognition on a specific clock cycle is required. # 19.14 Physical Dimensions The package of the ETRAX 100LX is a 256 lead Plastic Ball Grid Array (PBGA). Figure 19-27 256 PBGA - Mechanical Drawing # Appendix A Register Address Index This index lists the addresses used in the ETRAX 100LX, and the registers that are located at each address along with the read/write status for each register in parentheses. The final number to the right of each parentheses is the page number for that register in chapter 19. | Numerics | 0xB0000039 | |-----------------------------------|--------------------------------------| | | R_PORT_PB_DIR (write only) 247 | | 0xB0000000 | 0xB000003A | | R_WAITSTATES (write only) 207 | R_PORT_PB_CONFIG (write only) 248 | | 0xB0000004 | 0xB000003B | | R_BUS_CONFIG (write only) 209 | R_PORT_PB_I2C (write only) 249 | | R_BUS_STATUS (read only) 210 | 0xB000003C | | 0xB0000008 | R_SET_EOP (write only) 391 | | R_DRAM_TIMING (write only) 211 | 0xB0000040 | | R_SDRAM_TIMING (write only) 212 | R_ATA_CTRL_DATA (write only) 331 | | 0xB00000C | R_ATA_STATUS_DATA (read only) 332 | | R_DRAM_CONFIG (write only) 213 | R_PAR_ECP16_DATA (read/write) 315 | | R_SDRAM_CONFIG (write only) 215 | R_PAR0_CTRL_DATA (write only) 308 | | 0xB0000010 | R_PAR0_STATUS_DATA (read only) 311 | | R_EXT_DMA_0_CMD (write only) 217 | R_SCSI0_CMD_DATA (write only) 337 | | R_EXT_DMA_0_STAT (read only) 218 | R_SCSI0_DATA (write only) 338 | | 0xB0000014 | R_SCSI0_DATA_IN (read only) 343 | | R_EXT_DMA_0_ADDR (write only) 219 | R_SHARED_RAM_CONFIG (write only) 234 | | 0xB0000018 | 0xB0000042 | | R_EXT_DMA_1_CMD (write only) 220 | R_PAR0_CTRL (write only) 310 | | R_EXT_DMA_1_STAT (read only) 221 | R_PAR0_STATUS (read only) 313 | | 0xB000001C | R_SCSI0_CMD (write only) 339 | | R_EXT_DMA_1_ADDR (write only) 222 | 0xB0000043 | | 0xB0000020 | R_SCSI0_STATUS_CTRL (write only) 340 | | R_TIMER_CTRL (write only) 223 | 0xB0000044 | | R_TIMER_DATA (read only) 225 | R_ATA_CONFIG (write only) 333 | | 0xB0000022 | R_PAR0_CONFIG (write only) 316 | | R_TIMER0_DATA (read only) 227 | R_SCSI0_CTRL (write only) 335 | | R_TIMER01_DATA (read only) 226 | R_SHARED_RAM_ADDR (write only) 235 | | 0xB0000023 | 0xB0000048 | | R_TIMER1_DATA (read only) 228 | R_ATA_TRANSFER_CNT (read/write) 334 | | 0xB0000024 | R_PAR0_DELAY (write only) 319 | | R_WATCHDOG (write only) 229 | R_SCSI0_STATUS (read only) 341 | | 0xB0000028 | 0xB0000050 | | R_PORT_G_DATA (read/write) 239 | R_PAR1_CTRL_DATA (write only) 320 | | 0xB000002C | R_PAR1_STATUS_DATA (read only) 323 | | R_GEN_CONFIG (write only) 236 | R_SCSI1_CMD_DATA (write only) 346 | | 0xB0000030 | R_SCSI1_DATA (write only) 347 | | R_PORT_PA_DATA (write only) 241 | R_SCSI1_DATA_IN (read only) 352 | | R_PORT_PA_READ (read only) 243 | 0xB0000052 | | R_PORT_PA_SET (write only) 240 | R_PAR1_CTRL (write only) 322 | | 0xB0000031 | R_PAR1_STATUS (read only) 325 | | R_PORT_PA_DIR (write only) 242 | R_SCSI1_CMD (write only) 348 | | 0xB0000034 | R_USB_PORT2_DISABLE (write only) 515 | | R_GEN_CONFIG_II (write only) 238 | 0xB0000053 | | 0xB0000038 | R_SCSI1_STATUS_CTRL (write only) 349 | | R_PORT_PB_DATA (write only) 246 | 0xB0000054 | | R_PORT_PB_READ (read only) 250 | R_PAR1_CONFIG (write only) 327 | | R_PORT_PB_SET (write only) 244 | R_SCSI1_CTRL (write only) 344 | | 0xB0000058 | R_SERIAL2_TR_CTRL (write only) 275 | |-----------------------------------------------|---------------------------------------------------------------------| | R_PAR1_DELAY (write only) 330 | 0xB0000072 | | R_SCSI1_STATUS (read only) 350 | R_SERIAL2_REC_CTRL (write only) 274 | | 0xB000005C | 0xB0000073 | | R_ALT_SER_BAUDRATE (write only) 291 | R_SERIAL2_BAUD (write only) 273 | | 0xB000060 | 0xB0000078 | | R_SERIAL0_CTRL (write only) 251 | R_SERIAL3_CTRL (write only) 281 | | R_SERIALO_READ (read only) 257 | R_SERIAL3_READ (read only) 287 | | R_SERIALO_REC_DATA (read only) 259 | R_SERIAL3_REC_DATA (read only) 289 | | R_SERIALO_TR_DATA (write only) 256 | R_SERIAL3_TR_DATA (write only) 286 | | 0xB0000061 | R_SYNC_SERIAL3_CTRL (write only) 545 | | R_SERIALO_STATUS (read only) 258 | R_SYNC_SERIAL3_STATUS (read only) 541 | | R_SERIALO_TR_CTRL (write only) 255 | 0xB0000079 | | 0xB0000062 | R_SERIAL3_STATUS (read only) 288 | | | R_SERIAL3_STATOS (lead only) 288 R_SERIAL3_TR_CTRL (write only) 285 | | R_SERIALO_REC_CTRL (write only) 254 O×BOOOO63 | 0xB000007A | | | | | R_SERIALO_BAUD (write only) 253 | R_SERIAL3_REC_CTRL (write only) 284 | | 0xB0000064 | 0xB000007B | | R_SERIALO_XOFF (write only) 260 | R_SERIAL3_BAUD (write only) 283 | | 0xB0000068 | 0xB000007C | | R_SERIAL1_CTRL (write only) 261 | R_SERIAL3_XOFF (write only) 290 | | R_SERIAL1_READ (read only) 267 | R_SYNC_SERIAL3_REC_BYTE (read only) | | R_SERIAL1_REC_DATA (read only) 269 | 540 | | R_SERIAL1_TR_DATA (write only) 266 | R_SYNC_SERIAL3_REC_DATA (read only) | | R_SYNC_SERIAL1_CTRL (write only) 535 | 538 | | R_SYNC_SERIAL1_STATUS (read only) 531 | R_SYNC_SERIAL3_REC_WORD (read only) | | 0xB0000069 | 539 | | R_SERIAL1_STATUS (read only) 268 | R_SYNC_SERIAL3_TR_BYTE (write only) | | R_SERIAL1_TR_CTRL (write only) 265 | 544 | | 0xB000006A | R_SYNC_SERIAL3_TR_DATA (write only) | | R_SERIAL1_REC_CTRL (write only) 264 | 542 | | R_USB_PORT1_DISABLE (write only) 514 | R_SYNC_SERIAL3_TR_WORD (write only) | | 0xB000006B | 543 | | R_SERIAL1_BAUD (write only) 263 | 0xB0000080 | | 0xB000006C | R_NETWORK_SA_0 (write only) 296 | | R_SERIAL1_XOFF (write only) 270 | 0xB0000084 | | R_SYNC_SERIAL1_REC_BYTE (read only) | R_NETWORK_SA_1 (write only) 297 | | 530 | 0xB0000088 | | R_SYNC_SERIAL1_REC_DATA (read only) | R_NETWORK_SA_2 (write only) 298 | | 528 | 0xB000008C | | R_SYNC_SERIAL1_REC_WORD (read only) | R_NETWORK_GA_0 (write only) 299 | | 529 | 0xB0000090 | | R_SYNC_SERIAL1_TR_BYTE (write only) | R_NETWORK_GA_1 (write only) 300 | | 534 | 0xB0000094 | | R_SYNC_SERIAL1_TR_DATA (write only) | R_NETWORK_REC_CONFIG (write only) | | 532 | 301 | | R_SYNC_SERIAL1_TR_WORD (write only) | 0xB0000098 | | 533 | R_NETWORK_GEN_CONFIG (write only) | | 0xB0000070 | 302 | | R_SERIAL2_CTRL (write only) 271 | 0xB000009C | | R_SERIAL2_READ (read only) 277 | R_NETWORK_TR_CTRL (write only) 303 | | R_SERIAL2_REC_DATA (read only) 279 | 0xB00000A0 | | R_SERIAL2_TR_DATA (write only) 276 | R_NETWORK_MGM_CTRL (write only) 304 | | 0xB0000071 | R_NETWORK_STAT (read only) 305 | | R_SERIAL2_STATUS (read only) 278 | 0×B00000A4 | | ic belief ies billion (icad only) 270 | 0/100000/11 | - R\_REC\_COUNTERS (read only) 306 0×B00000A8 - $\begin{array}{c} R\_TR\_COUNTERS \text{ (read only) } 307 \\ \text{O} \times \text{BOOOOOAC} \end{array}$ - R\_PHY\_COUNTERS (read only) 308 O×BOOOOCO - R\_IRQ\_MASK0\_CLR (write only) 358 R\_IRQ\_MASK0\_RD (read only) 353 0×B00000C4 - R\_IRQ\_MASK0\_SET (write only) 362 R\_IRQ\_READ0 (read only) 360 - 0xB00000C8 - R\_IRQ\_MASK1\_CLR (write only) 369 R\_IRQ\_MASK1\_RD (read only) 365 0×B00000CC - R\_IRQ\_MASK1\_SET (write only) 373 R\_IRQ\_READ1 (read only) 371 0×B00000D0 - R\_IRQ\_MASK2\_CLR (write only) 378 R\_IRQ\_MASK2\_RD (read only) 375 0×B00000D4 - R\_IRQ\_MASK2\_SET (write only) 382 R\_IRQ\_READ2 (read only) 380 0×B00000D8 - R\_VECT\_MASK\_CLR (write only) 386 R\_VECT\_MASK\_RD (read only) 384 0×B00000DC - R\_VECT\_MASK\_SET (write only) 390 R\_VECT\_READ (read only) 388 O×BOOOOFO - R\_CLOCK\_PRESCALE (write only) 230 R\_PRESCALE\_STATUS (read only) 232 - R\_TIM\_PRESC\_STATUS (read only) 233 - R\_TIMER\_PRESCALE (write only) 231 0×B00000F2 - R\_SER\_PRESC\_STATUS (read only) 294 R\_SERIAL\_PRESCALE (write only) 293 0×B00000F4 - R\_SYNC\_SERIAL\_PRESCALE (write only) 548 - 0xB00000FC - R\_TEST\_MODE (write only) 486 $0 \times B00000FE$ - R\_SINGLE\_STEP (write only) 488 0×B0000100 - R\_DMA\_CH0\_HWSW (read/write) 392 0×B0000104 - R\_DMA\_CH0\_NEXT (read/write) 394 0×B0000108 - R\_DMA\_CH0\_BUF (read/write) 395 0×B000010C - R\_DMA\_CH0\_DESCR (read/write) 393 0×B0000110 - R\_DMA\_CH1\_HWSW (read/write) 400 OxB0000114 - $\begin{array}{l} R\_DMA\_CH1\_NEXT \text{ (read/write) } 402\\ 0\times B0000116 \end{array}$ - $\begin{array}{l} R\_SERIAL2\_XOFF \ (write \ only) \ 280 \\ \text{O}\times \text{B}0000118 \end{array}$ - R\_DMA\_CH1\_BUF (read/write) 403 0×B000011C - R\_DMA\_CH1\_DESCR (read/write) 401 0×B0000120 - $\begin{array}{l} R\_DMA\_CH2\_HWSW \text{ (read/write) } 408 \\ \text{0} \times \text{B} \text{0} \text{0} \text{0} \text{1} \text{2} \text{4} \end{array}$ - R\_DMA\_CH2\_NEXT (read/write) 410 0×B0000128 - R\_DMA\_CH2\_BUF (read/write) 411 $0\times B000012C$ - R\_DMA\_CH2\_DESCR (read/write) 409 0×B0000130 - R\_DMA\_CH3\_HWSW (read/write) 416 0×B0000134 - R\_DMA\_CH3\_NEXT (read/write) 418 0×B0000138 - R\_DMA\_CH3\_BUF (read/write) 419 $0\times B000013C$ - R\_DMA\_CH3\_DESCR (read/write) 417 0×B0000140 - R\_DMA\_CH4\_HWSW (read/write) 424 0×B0000144 - R\_DMA\_CH4\_NEXT (read/write) 426 0×B0000148 - R\_DMA\_CH4\_BUF (read/write) 427 0×B000014C - R\_DMA\_CH4\_DESCR (read/write) 425 0×B0000150 - R\_DMA\_CH5\_HWSW (read/write) 432 0×B0000154 - R\_DMA\_CH5\_NEXT (read/write) 434 0×B0000158 - R\_DMA\_CH5\_BUF (read/write) 435 OxB000015C - R\_DMA\_CH5\_DESCR (read/write) 433 0×B0000160 - R\_DMA\_CH6\_HWSW (read/write) 440 0×B0000164 - R\_DMA\_CH6\_NEXT (read/write) 442 0×B0000168 - R\_DMA\_CH6\_BUF (read/write) 443 0×B000016C - R\_DMA\_CH6\_DESCR (read/write) 441 0×B0000170 - R\_DMA\_CH7\_HWSW (read/write) 448 0×B0000174 - R\_DMA\_CH7\_NEXT (read/write) 450 0×B0000178 - $\begin{array}{c} R\_DMA\_CH7\_BUF \ (read/write) \ 451 \\ 0\times B000017C \end{array}$ - R DMA CH7 DESCR (read/write) 449 - 0xB0000180 - R\_DMA\_CH8\_HWSW (read/write) 456 0×B0000184 - R\_DMA\_CH8\_NEXT (read/write) 458 0×B0000188 - R\_DMA\_CH8\_BUF (read/write) 459 0×B000018C - R DMA CH8 DESCR (read/write) 457 - R\_DMA\_CH8\_SUB (read/write) 464 0×B0000190 - R\_DMA\_CH9\_HWSW (read/write) 478 0×B0000194 - R\_DMA\_CH9\_NEXT (read/write) 480 0×B0000198 - R\_DMA\_CH9\_BUF (read/write) 481 OxB000019C - R\_DMA\_CH9\_DESCR (read/write) 479 0×B00001A0 - R\_DMA\_CH0\_FIRST (read/write) 396 0×B00001A4 - R\_DMA\_CH1\_FIRST (read/write) 404 0×B00001A8 - R\_DMA\_CH2\_FIRST (read/write) 412 0×B00001AC - R\_DMA\_CH3\_FIRST (read/write) 420 0×B00001B0 - R\_DMA\_CH4\_FIRST (read/write) 428 0×B00001B4 - R\_DMA\_CH5\_FIRST (read/write) 436 0xB00001B8 - R\_DMA\_CH6\_FIRST (read/write) 444 0×B00001BC - R\_DMA\_CH7\_FIRST (read/write) 452 0×B00001C0 - R\_DMA\_CH8\_FIRST (read/write) 460 - R\_DMA\_CH8\_NEP (read/write) 465 0xB00001C4 - R\_DMA\_CH9\_FIRST (read/write) 482 0xB00001C8 - R\_DMA\_CH8\_SUB0\_EP (read/write) 466 0xB00001CC - R\_DMA\_CH8\_SUB1\_EP (read/write) 469 0×B00001D0 - R\_DMA\_CH0\_CMD (read/write) 397 0xB00001D1 - $\begin{array}{l} R\_DMA\_CH0\_CLR\_INTR \ (write \ only) \ 398 \\ 0\times B00001D2 \end{array}$ - R\_DMA\_CH0\_STATUS (read only) 399 0xB00001D3 - R\_DMA\_CH8\_SUB0\_CMD (read/write) 467 0×B00001D4 - R\_DMA\_CH1\_CMD (read/write) 405 0×B00001D5 - R\_DMA\_CH1\_CLR\_INTR (write only) 406 OxB00001D6 - R\_DMA\_CH1\_STATUS (read only) 407 0×B00001D7 - R\_DMA\_CH8\_SUB1\_CMD (read/write) 470 0xB00001D8 - R\_DMA\_CH2\_CMD (read/write) 413 0×B00001D9 - $\begin{array}{c} R\_DMA\_CH2\_CLR\_INTR \text{ (write only) } 414\\ 0\times B00001DA \end{array}$ - R\_DMA\_CH2\_STATUS (read only) 415 $0\times B00001DB$ - R\_DMA\_CH8\_SUB2\_CMD (read/write) 473 OxB00001DC - R\_DMA\_CH3\_CMD (read/write) 421 0×B00001DD - R\_DMA\_CH3\_CLR\_INTR (write only) 422 0×B00001DE - R\_DMA\_CH3\_STATUS (read only) 423 0xB00001DF - R\_DMA\_CH8\_SUB3\_CMD (read/write) 476 0xB00001E0 - R\_DMA\_CH4\_CMD (read/write) 429 0xB00001E1 - $\begin{array}{c} R\_DMA\_CH4\_CLR\_INTR \text{ (write only) } 430\\ 0\times B00001E2 \end{array}$ - R\_DMA\_CH4\_STATUS (read only) 431 0×B00001E3 - R\_DMA\_CH8\_SUB0\_CLR\_INTR (write only) 468 - 0xB00001E4 - R\_DMA\_CH5\_CMD (read/write) 437 - 0xB00001E5 - R\_DMA\_CH5\_CLR\_INTR (write only) 438 0xB00001E6 - $\begin{array}{lll} R\_DMA\_CH5\_STATUS \ (read \ only) \ 439 \\ 0 \times B00001E7 \end{array}$ - R\_DMA\_CH8\_SUB1\_CLR\_INTR (write only) 471 - 0xB00001E8 - R\_DMA\_CH6\_CMD (read/write) 445 - 0xB00001E9 - R\_DMA\_CH6\_CLR\_INTR (write only) 446 0×B00001EA - R\_DMA\_CH6\_STATUS (read only) 447 0×B00001EB - R\_DMA\_CH8\_SUB2\_CLR\_INTR (write only) 474 - 0xB00001EC - R\_DMA\_CH7\_CMD (read/write) 453 O×B00001ED - R\_DMA\_CH7\_CLR\_INTR (write only) 454 $0\times B00001EE$ - R\_DMA\_CH7\_STATUS (read only) 455 0×B00001EF - R\_DMA\_CH8\_SUB3\_CLR\_INTR (write only) 0xB00001F0 R DMA CH8 CMD (read/write) 461 0xB00001F1 R DMA CH8 CLR INTR (write only) 462 0xB00001F2 R DMA CH8 STATUS (read only) 463 0xB00001F4 R\_DMA\_CH9\_CMD (read/write) 483 0xB00001F5 R DMA CH9 CLR INTR (write only) 484 0xB00001F6 R DMA CH9 STATUS (read only) 485 0xB00001F8 R\_DMA\_CH8\_SUB2\_EP (read/write) 472 0xB00001FC R DMA CH8 SUB3 EP (read/write) 475 0xB0000200 R\_USB\_REVISION (read only) 489 0xB0000201 R USB COMMAND (read/write) 490 R USB COMMAND DEV (read/write) 491 0xB0000202 R\_USB\_STATUS (read only) 492 0xB0000203 R\_USB\_RH\_STATUS (read only) 506 0xB0000204 R USB IRQ MASK READ (read only) 494 R USB IRQ MASK READ DEV (read only) 498 R\_USB\_IRQ\_MASK\_SET (write only) 493 R USB IRQ MASK SET DEV (write only) 497 0xB0000206 R\_USB\_IRQ\_MASK\_CLR (write only) 495 R USB IRQ MASK CLR DEV (write only) R USB IRQ READ (read only) 496 R USB IRQ READ DEV (read only) 500 0xB0000208 R\_USB\_EPT\_INDEX (read/write) 509 0xB000020C R USB FM NUMBER (read/write) 501 R USB FM NUMBER DEV (read/write) 502 0xB0000210 R\_USB\_FM\_INTERVAL (read/write) 503 0xB0000212 R\_USB\_FM\_REMAINING (read only) 504 0xB0000214 R USB FM PSTART (read/write) 505 0xB0000218 0xB000021C R USB EPT DATA (read/write) 510 R\_USB\_EPT\_DATA\_DEV (read/write) 512 R USB EPT DATA ISO (read/write) 511 0xB0000224 R USB EPID ATTN (read only) 513 0xB0000240 R\_MMU\_CONFIG (write only) 516 R MMU KSEG (write only) 518 0xB0000242 R MMU CTRL (write only) 519 0xB0000243 R\_MMU\_ENABLE (write only) 520 0xB0000244 R MMU KBASE LO (write only) 521 0xB0000248 R\_MMU\_KBASE\_HI (write only) 522 0xB000024C R\_MMU\_CAUSE (read/write) 523 0xB0000250 R\_MMU\_CAUSE (read only) 524 0xB0000254 R\_TLB\_SELECT (read/write) 525 0xB0000258 R\_TLB\_LO (read/write) 526 0xB000025C R\_TLB\_HI (read/write) 527 R\_USB\_RH\_PORT\_STATUS\_1 (read only) R\_USB\_RH\_PORT\_STATUS\_2 (read only) 507 508 0xB000021A # Appendix B PLL Clock Generation The ETRAX 100LX uses a *Phase Locked Loop* (PLL) to generate the internal reference clock from a clock supplied to the **clkin** pin. The PLL circuit multiplies the **clkin** frequency by a factor of 15. For normal operation the **clkin** frequency should be 20 MHz, resulting in an internal reference frequency of 300 MHz. #### **PLL Pins** The following pins are used permanently by the PLL: | Name | Direction | Description | |--------|-----------|-------------------------------| | clkin | input | External clock input | | plllp2 | in/out | Loop filter | | pllagn | output | Loop filter ground connection | Table B-1 Permanent PLL pins The following pins are used to choose the PLL operating modes (See "Operating Modes"): | Name | Direction | Description | |------|-----------|-------------| | test | input | | | nmi | input | | Table B-2 PLL operating modes pins **Note 1:** PLL only uses the $\overline{\text{test}}$ and $\overline{\text{nmi}}$ pins during reset. #### **External Loop Filter** The loop filter resistor and capacitors should be connected as close as possible to the chip. Figure B-1 shows a diagram of the external loop filter, and table B-3 lists its minimum, recommended and maximum values. Figure B-1 External Loop Filter | | Minimum | Recommended | Maximum | |----|---------|-------------|---------| | R1 | 8.2 Ω | 8.2 Ω | 8.2 kΩ | | C1 | 39pF | 39pF | 39pF | | C2 | 680 pF | 680 pF | 1.0 μF | Table B-3 External loop filter #### **Operating Modes** The PLL operates in three modes: - Normal Mode - PLL Bypass Mode - PLL Test Mode | Mode | test<br>(time a) | test<br>(time b) | nmi<br>(time a) | nmi<br>(time b) | |-----------------|------------------|------------------|-----------------|-----------------| | Normal Mode | 1 | 1 | Don't care | Don't care | | PLL Bypass Mode | 0 | 1 | 0 | 1 | | PLL-test Mode | 0 | 0 | 0 | 0 | Table B-4 Operating modes Figure B-2 PLL Mode Timing #### **Normal Mode** In normal mode the PLL generates the internal reference clock from the clock supplied to the **clkin** pin. The PLL circuit multiplies the clkin frequency by a factor of 15. At reset, the internal reference clock is disabled as long as **reset** is active. When **reset** is released, the reference clock is disabled for an additional 1.6 ms. During this time the PLL locks the internal reference signal. The internal 300 MHz clock is locked to the rising edge of **clkin**. Internal Reference Clock Figure B-3 Normal Mode #### **PLL Bypass Mode** In PLL bypass mode, the PLL is bypassed and **clkin** is used directly as the <u>refer</u>ence clock. When <u>reset</u> is active, the internal reference clock is disabled. When <u>reset</u> is released, **clkin** is immediately used as the reference clock. In this mode, the output of the 1.6 ms PLL lock timer can be read in the **pll\_lock\_tm** field of the R\_BUS\_STATUS register, which is used to test the timer. #### **PLL-test Mode** The PLL-test mode is only used for factory testing of the PLL. In this mode, the clock will be turned off for the rest of the chip. For more information please contact Axis Communications.