# Features

- ARM7TDMI<sup>™</sup> ARM<sup>®</sup> Thumb<sup>®</sup> Processor Core
- Two 16-bit Fixed-point OakDSPCore<sup>®</sup> Cores
- 256 x 32-bit Boot ROM
- 88K Bytes of Integrated Fast RAM for Each DSP
- Flexible External Bus Interface with Programmable Chip Selects
- Dual Codec Interface
- Multi-level Priority, Individually Maskable, Vectored Interrupt Controller
- Three 16-bit Timer/Counters
- Additional Watchdog Timer
- Two USARTs with FIFO and Modem Control Lines
- Industry-standard Serial Peripheral Interface
- Up to 23 General-purpose I/O Pins
- On-chip DRAM Controller
- JTAG Debug Interface
- Software Development Tools Available for ARM7TDMI and OakDSPCore
- Supported by a Wide Range of Ready-to-use Application Software, including
- Multitasking Operating System, Networking, Modems and Voice-processing Functions • Available in a 160-lead PQFP Package
- 3.3V Power Supply

# Description

The Atmel AT75C310 Smart Internet Appliance Processor (SIAP<sup>™</sup>) is a high-performance processor designed for internet appliance applications such as Internet Telephony (Voice over Internet Protocol – VoIP). The AT75C310 is built around an ARM7TDMI microcontroller core running at 20 MIPS with two DSP co-processors running at 40 MIPS each. All three processors deliver unmatched performance for low power consumption.

In a typical standalone VoIP phone, one DSP handles the voice-processing functions (voice compression, acoustic echo cancellation, etc.) while the other deals with the telephony functions such as dialing, line echo cancellation, caller ID detection, high-speed modem, etc. In such an application, the power of the ARM7TDMI allows it to run the VoIP protocol stack as well as all the system control tasks.

Atmel provides the AT75C310 with three levels of software modules:

- · A special port of the Linux kernel as the proposed operating system
- A comprehensive set of tunable DSP algorithms for modems and voice processing, tailored to be run by the DSP subsystems
- A broad range of application-level software modules such as H323 telephony or POP-3/SMTP e-mail services



Smart Internet Appliance Processor (SIAP<sup>™</sup>)

# AT75C310 – CPU Peripherals

Rev. 1369A-01/01





# AT75C310 Pin Configuration Table 1. AT75C310 Pinout in 160-lead PQFP Package

| Table | 1. AT75C310 FILIO |
|-------|-------------------|
| Pin   | Signal Name       |
| 1     | VDD               |
| 2     | D11               |
| 3     | NCE3              |
| 4     | VSS               |
| 5     | NDOE              |
| 6     | D12               |
| 7     | D13               |
| 8     | NWE0              |
| 9     | D14               |
| 10    | VSS               |
| 11    | VDD               |
| 12    | NWE1              |
| 13    | D15               |
| 14    | NDWE              |
| 15    | VDD               |
| 16    | VDD               |
| 17    | VSS               |
| 18    | VSS               |
| 19    | VDD               |
| 20    | MOSI              |
| 21    | MISO              |
| 22    | SPCK              |
| 23    | NPCSS             |
| 24    | RXDA              |
| 25    | TXDA              |
| 26    | VSS               |
| 27    | VDD               |
| 28    | NRTSA             |
| 29    | NCTSA             |
| 30    | NDTRA             |
| 31    | NDSRA/BOOTN       |
| 32    | VSS               |
| 33    | VDD               |
| 34    | NDCDA             |
| 35    | TXDB              |
| 36    | RXDB              |
| 37    | VDD               |
| 38    | PB7/NCE1          |
| 39    | VSS               |
| 40    | VSS               |
|       |                   |

| PQFP Package |  |  |  |
|--------------|--|--|--|
| Signal Name  |  |  |  |
| VSS          |  |  |  |
| PB6/NWDOVF   |  |  |  |
| PB5/NRIA     |  |  |  |
| PB4          |  |  |  |
| VSS          |  |  |  |
| VDD          |  |  |  |
| PB3          |  |  |  |
| RESET        |  |  |  |
| VDD          |  |  |  |
| IRQ0         |  |  |  |
| PB2/TIOB1    |  |  |  |
| PB9          |  |  |  |
| PB1/TIOA1    |  |  |  |
| PB8/NCE2     |  |  |  |
| PB0/TCLK1    |  |  |  |
| VDD          |  |  |  |
| XREF80       |  |  |  |
| VSS          |  |  |  |
| XTALIN       |  |  |  |
| XTALOUT      |  |  |  |
| VSS          |  |  |  |
| XREF96       |  |  |  |
| VDD          |  |  |  |
| TST          |  |  |  |
| NTRST        |  |  |  |
| ТСК          |  |  |  |
| TMS          |  |  |  |
| TDI          |  |  |  |
| TDO          |  |  |  |
| VSS          |  |  |  |
| PA0/OakAIN0  |  |  |  |
| PA1/OakAIN1  |  |  |  |
| PA2/OakAOUT0 |  |  |  |
| PA3/OakAOUT1 |  |  |  |
| VSS          |  |  |  |
| VDD          |  |  |  |
| PA4/OakBIN0  |  |  |  |
| PA5/OakBIN1  |  |  |  |
| PA6/OakBOUT0 |  |  |  |
| PA7/OakBOUT1 |  |  |  |
|              |  |  |  |

| Pin | Signal Name |
|-----|-------------|
| 81  | VDD         |
| 82  | PA8/TCLK0   |
| 83  | PA9/TIOA0   |
| 84  | VSS         |
| 85  | PA10/TIOB0  |
| 86  | PA11/SCLKA  |
| 87  | VSS         |
| 88  | PA12/NPCS1  |
| 89  | VDD         |
| 90  | VSS         |
| 91  | VDD         |
| 92  | NREQ        |
| 93  | FIQ         |
| 94  | NGNT        |
| 95  | VSS         |
| 96  | VDD         |
| 97  | SCLKA       |
| 98  | FSA         |
| 99  | STXA        |
| 100 | SRXA        |
| 101 | A0          |
| 102 | A1          |
| 103 | A2          |
| 104 | A3          |
| 105 | VDD         |
| 106 | A4          |
| 107 | A5          |
| 108 | A6          |
| 109 | A7          |
| 110 | VDD         |
| 111 | VSS         |
| 112 | A8          |
| 113 | A9          |
| 114 | A10         |
| 115 | A11         |
| 116 | A12         |
| 117 | A13         |
| 118 | A14         |
| 119 | A15         |
| 120 | VSS         |
|     |             |

| Pin | Signal Name |  |  |
|-----|-------------|--|--|
| 121 | VSS         |  |  |
| 122 | A16         |  |  |
| 123 | A17         |  |  |
| 124 | VDD         |  |  |
| 125 | VSS         |  |  |
| 126 | A18         |  |  |
| 127 | A19         |  |  |
| 128 | A20         |  |  |
| 129 | A21         |  |  |
| 130 | VDD         |  |  |
| 131 | VSS         |  |  |
| 132 | D0          |  |  |
| 133 | NCAS0       |  |  |
| 134 | D1          |  |  |
| 135 | D2          |  |  |
| 136 | NCAS1       |  |  |
| 137 | D3          |  |  |
| 138 | VSS         |  |  |
| 139 | NRAS0       |  |  |
| 140 | D4          |  |  |
| 141 | NRAS1       |  |  |
| 142 | VSS         |  |  |
| 143 | VDD         |  |  |
| 144 | D5          |  |  |
| 145 | SRXB        |  |  |
| 146 | STXB        |  |  |
| 147 | D6          |  |  |
| 148 | FSB         |  |  |
| 149 | VDD         |  |  |
| 150 | VSS         |  |  |
| 151 | D7          |  |  |
| 152 | SCLKB       |  |  |
| 153 | D8          |  |  |
| 154 | NSOE        |  |  |
| 155 | VDD         |  |  |
| 156 | VSS         |  |  |
| 157 | NCE0        |  |  |
| 158 | D9          |  |  |
| 159 | D10         |  |  |
| 160 | VDD         |  |  |

# AT75C310 Pin Description

### Table 2. AT75C310 Pin Description

| Block                          | Pin Name     | Туре | Function                                                    |  |
|--------------------------------|--------------|------|-------------------------------------------------------------|--|
| A[21:0]                        |              | 0    | Address Bus                                                 |  |
|                                | D[15:0]      | I/O  | Data Bus                                                    |  |
| Common Bus                     | NREQ         | I    | Bus Request                                                 |  |
|                                | NGNT         | 0    | Bus Grant                                                   |  |
|                                | NRAS[1:0]    | 0    | Row Address Strobe                                          |  |
| Dynamic Memory                 | NCAS[1:0]    | 0    | Column Address Strobe                                       |  |
| Controller                     | NDWE         | 0    | DRAM Write Enable                                           |  |
|                                | NDOE         | 0    | DRAM Output Enable                                          |  |
|                                | NCE[3:0]     | 0    | Chip Selects                                                |  |
| Static Memory<br>Controller    | NWE[1:0]     | 0    | Byte Select/Write Enable                                    |  |
|                                | NSOE         | 0    | SRAM Output Enable                                          |  |
| I/O Port A                     | PA[12:0]     | I/O  | General Purpose I/O Lines. Multiplexed with peripheral I/Os |  |
| I/O Port B                     | PB[9:0]      | I/O  | General Purpose I/O Lines. Multiplexed with peripheral I/Os |  |
| DCD Cubayatam A                | OakAIN[1:0]  | Ι    | OakDSPCore A User Inputs                                    |  |
| DSP Subsystem A                | OakAOUT[1:0] | 0    | OakDSPCore A User Outputs                                   |  |
| DSP Subsystem B                | OakBIN[1:0]  | I    | OakDSPCore B User Inputs                                    |  |
| DSF Subsystem B                | OakBOUT[1:0] | 0    | OakDSPCore B User Outputs                                   |  |
|                                | TCLK0        | Ι    | Timer 0 External Clock                                      |  |
| Timer/Counter 0                | TIOA0        | I/O  | Timer 0 Signal A                                            |  |
|                                | TIOB0        | I/O  | Timer 0 Signal B                                            |  |
|                                | TCLK1        | Ι    | Timer 1 External Clock                                      |  |
| Timer/Counter 1                | TIOA1        | I/O  | Timer 1 Signal A                                            |  |
|                                | TIOB1        | I/O  | Timer 1 Signal B                                            |  |
| Watchdog                       | NWDOVF       | 0    | Watchdog Overflow                                           |  |
|                                | MISO         | I/O  | Master In/Slave Out                                         |  |
|                                | MOSI         | I/O  | Master Out/Slave In                                         |  |
| Serial Peripheral<br>Interface | SPCK         | I/O  | Serial Clock                                                |  |
|                                | NPCSS        | I/O  | Chip Select/Slave Select                                    |  |
|                                | NPSC1        | 0    | Optional SPI Chip Select 1                                  |  |





# Table 2. AT75C310 Pin Description (Continued)

| Block             | Pin Name    | Туре | Function                      |  |
|-------------------|-------------|------|-------------------------------|--|
|                   | RXDA        |      | Receive Data                  |  |
|                   | TXDA        | 0    | Transmit Data                 |  |
|                   | NRTSA       | 0    | Ready to Send                 |  |
|                   | NCTSA       | I    | Clear To Send                 |  |
| USART A           | NDTRA       | 0    | Data Terminal Ready           |  |
|                   | NDSRA/BOOTN | I    | Data Set Ready                |  |
|                   | NDCDA       | I    | Data Carrier Detect           |  |
|                   | NRIA        | I    | Ring Indicator                |  |
|                   | SCLKA       | I/O  | Serial Clock                  |  |
|                   | RXDB        | I    | Receive Data                  |  |
| USART B           | TXDB        | 0    | Transmit Data                 |  |
|                   | NTRST       | I    | JTAG Test Reset               |  |
|                   | ТСК         | I    | JTAG Test Clock               |  |
| JTAG Interface    | TMS         | I    | JTAG Test Mode Select         |  |
|                   | TDI         | I    | JTAG Test Data Input          |  |
|                   | TDO         | 0    | JTAG Test Data Output         |  |
|                   | SCLKA       | I/O  | Codec Serial Clock            |  |
| Codec Interface A | FSA         | I/O  | Frame Sync Pulse              |  |
| Codec interface A | STXA        | 0    | Transmit Data to Codec        |  |
|                   | SRXA        | I    | Receive Data from Codec       |  |
|                   | SCLKB       | I/O  | Codec Serial Clock            |  |
| Codec Interface B | FSB         | I/O  | Frame Sync Pulse              |  |
| Codec interface B | STXB        | 0    | Transmit Data to Codec        |  |
|                   | SRXB        | I    | Receive Data from Codec       |  |
|                   | RESET       | I    | Master Reset                  |  |
| Missellensen      | FIQ/LOWP    | I    | Fast Interrupt/Low Power      |  |
|                   | IRQ0        | I    | External Interrupt request    |  |
|                   | XREF96      | I    | External 96 MHz PLL Reference |  |
| Miscellaneous     | XREF80      | I    | External 80 MHZ PLL Reference |  |
|                   | XTALIN      | I    | External Crystal Input        |  |
|                   | XTALOUT     | 0    | External Crystal Output       |  |
|                   | TST         | I    | Test Mode                     |  |

# **Block Diagram**

Figure 1. AT75C310 Block Diagram







# **Architectural Overview**

The AT75C310 architecture consists of two main buses, the Advanced System Bus (ASB) and the Advanced Peripheral Bus (APB).

The ASB is designed for maximum performance. It interfaces the processor with the on-chip DSP subsystems and the external memories and devices by means of the External Bus Interface (EBI).

The APB is designed for accesses to on-chip peripherals and is optimized for low power consumption. The AMBA<sup>TM</sup> Bridge provides an interface between the ASB and the APB.

An on-chip Peripheral Data Controller (PDC) transfers data between the on-chip USARTs and the memories without processor intervention. Most importantly, the PDC removes the processor interrupt handling overhead and significantly reduces the number of clock cycles required for a data transfer. It can transfer up to 64K contiguous bytes without reprogramming the starting address. As a result, microcontroller performance is increased and power consumption reduced.

The AT75C310 peripherals are designed to be programmed with a minimum number of instructions. Each peripheral has a 16 KB address space allocated in the upper part of the address space. The peripheral register set is composed of control, mode, data, status and interrupt registers.

To maximize the efficiency of bit manipulation, frequentlywritten registers are mapped into three memory locations. The first address is used to set the individual register bits, the second resets the bits and the third address reads the value stored in the register. A bit can be set or reset by writing a one to the corresponding position at the appropriate address. Writing a zero has no effect. Individual bits can thus be modified without having to use costly read-modifywrite and complex bit-manipulation instructions, and without having to store-disable-restore the interrupt state.

All external signals of the on-chip peripherals are controlled by the parallel I/O controllers. The PIO controllers can be programmed to insert an input filter on each pin or to generate an interrupt on a signal change. After reset, the user must carefully program the PIO controllers in order to define which peripheral signals are connected with off-chip logic.

The ARM7TDMI processor operates in little-endian mode in the AT75C310. The processor's internal architecture and the ARM and Thumb instruction sets are described in the-Atmel ARM7TDMI datasheet, literature number 0673. The memory map and the on-chip peripherals are described in this datasheet. The DSP subsystems are described in the datasheet entitled "AT75C310 DSP Subsystem", literature number 1368. Electrical characteristics are documented in a separate datasheet entitled "AT75C310 Electrical and Mechanical Characteristics", literature number 1370.

# **PDC: Peripheral Data Controller**

The AT75C310 has a four-channel PDC dedicated to the two on-chip USARTs. One PDC channel is connected to the receiving channel and one to the transmitting channel of each USART.

The user interface of a PDC channel is integrated in the memory space of each USART channel. It contains a 32-bit address pointer register and a 16-bit count register. When the programmed number of bytes is transferred, an end of transfer interrupt is generated by the corresponding USART. For more details on PDC operation and programming, see the section "USART: Universal Synchronous/Asynchronous Receiver/Transmitter" on page 53.

# **Memory Map**

The memory map is divided into memory regions of 64 megabytes. The top seven memory regions are reserved and subdivided for internal memory blocks or peripherals within the AT75C310. The AT75C310 can define up to six other active external memory regions by means of the static memory controller and DRAM memory controller.

The memory map assumes default values on reset. External memory regions can be reprogrammed to other base addresses. For details, see the sections "SMC: Static Memory Controller" on page 15 and "DMC: Dynamic Memory Controller" on page 24. It should be noted that the internal memory regions have fixed locations that cannot be reprogrammed. There are no hardware locks to prevent incorrect programming of the regions. Programming two or more regions to have the same base address results in undefined behavior.

The ARM reset vector with address 0x00000000 is mapped to internal ROM or external memory depending on the signal pin NDSRA/BOOTN. After booting, the ROM region can be disabled and some external memory such as DRAM or Flash can be mapped to the bottom of the memory map by programming SMC\_CS0 or DMC\_MR0.

| Table 3. | Memory | Мар |
|----------|--------|-----|
|----------|--------|-----|

| Default Base Address | Region Type       | Normal Mode                           |  |
|----------------------|-------------------|---------------------------------------|--|
| 0xFF000000           | Internal          | Peripherals                           |  |
| 0xFE000000           | Internal          | OAK B (24K x 16 Program SRAM)         |  |
| 0xFD000000           | Internal          | OAK A (24K x 16 Program SRAM)         |  |
| 0xFC000000           | Internal          | Reserved                              |  |
| 0xFB000000           | Internal          | Dual-port Mailbox for Oak B (2K x 16) |  |
| 0xFA000000           | Internal          | Dual-port Mailbox for Oak A (2K x 16) |  |
| 0xF9000000           | Internal          | Boot ROM (1K x 16)                    |  |
| 0x5000000            | External          | DMC_MR1                               |  |
| 0x4000000            | External          | DMC_MR0                               |  |
| 0x30000000           | External          | SMC_CS3                               |  |
| 0x20000000           | External          | SMC_CS2                               |  |
| 0x1000000            | External          | SMC_CS1                               |  |
|                      |                   |                                       |  |
| 0x0000000            | External/Internal | SMC_CS0                               |  |





# **Peripheral Memory Map**

The register maps for each peripheral are described in the corresponding sections of this datasheet. The peripheral memory map has 16KB reserved for each peripheral.

#### Table 4. Peripheral Memory Map

| Base Address | Peripheral | Description                   |
|--------------|------------|-------------------------------|
| 0xFF000000   | MODE       | Mode Controller               |
| 0xFF004000   | SMC        | Static Memory Controller      |
| 0xFF008000   | DMC        | DRAM Memory Controller        |
| 0xFF00C000   | PIO A      | Programmable I/O              |
| 0xFF010000   | PIO B      | Keypad PIO                    |
| 0xFF014000   | TC         | Timer/Counter Channels        |
| 0xFF018000   | USART A    | USART                         |
| 0xFF01C000   | USART B    | USART                         |
| 0xFF020000   | SPI        | Serial Peripheral Interface   |
| 0xFF024000   | Reserved   |                               |
| 0xFF028000   | WDT        | Watchdog Timer                |
| 0xFF030000   | AIC        | Advanced Interrupt Controller |



# Initialization

Reset initializes the user interface registers to their default states as defined in the peripheral sections of this datasheet and forces the ARM7TDMI to perform the next instruction fetch from address zero. Except for the program counter, the ARM core registers do not have defined reset states. When reset is active, the inputs of the AT75C310 must be held at valid logic levels.

There are three ways in which the AT75C310 can enter reset:

- 1. Hardware reset. Caused by asserting the RESET pin, e.g., at power-up.
- 2. Watchdog timer reset. The watchdog timer can be programmed so that if it is timed out, a pulse is generated that forces a chip reset.
- Software reset. There are two software resets which are asserted by writing to bits [11:10] of the AT75C310 mode register. SIAP\_MD[11] forces a software reset with RM set low and SIAP\_MD[10] forces a reset with RM set high.

#### **Reset Pin**

The reset pin should be asserted for a minimum of 10 clock cycles. However, if external DRAM is fitted, reset should be applied for the time interval specified by the DRAM datasheet, typically 200  $\mu$ s. The OakDSPCores are only released from reset by ARM program control.

When reset is released, the pin NDSRA/BOOTN is sampled to determine if the ARM should boot from internal ROM or from external memory connected to NCS0. The details of this boot operation are described in the section "Boot Mode" on page 11.

#### **Processor Synchronization**

The ARM and the OakDSPCore processors have their own PLLs and at power-on each processor has its own indeterminate lock period. To guarantee proper synchronization of inter-processor communication through the mailboxes, a specific reset sequence should be followed.

Once the ARM core is out of reset, it should set and clear the reset line of each OakDSPCore three times. This guarantees message synchronization between the ARM and the OakDSPCores.





### Clocking

The AT75C310 uses an external 16 MHz crystal (XCLK) and two on-chip PLLs to generate the internal clocks. One PLL generates a 96 MHz clock that is divided down to produce the ARM clocks and the other produces an 80 MHz clock used to generate the Oak and Codec interface clocks.

The ARM core runs at 24 MHz whereas the DSP subsystems run at 40 MHz.

Figure 2. AT75C310 Clock Circuitry Diagram

Note that there is a common synchronous mode where the ARM and OAK systems both run from the Oak PLL. This results in the ARM running at 20 MHz and the Oak at 40 MHz.

A block diagram of the clock circuitry can be seen below in Figure 2.



# **Boot Mode**

When the reset pin is deasserted, i.e., when the AT75C310 exits from reset state, the NDSRA/BOOTN pin is sampled. If NDSRA/BOOTN is high, the ARM starts fetching from address 0x00000000, which corresponds to the external memory. In a typical application, the external memory located at 0x00000000 is a nonvolatile memory containing the application.

If NDSRA/BOOTN is low, the internal boot ROM is remapped to 0x00000000 and the internal boot program is executed.

The boot program configures the USART A, waits for a sync pattern, undertakes handshake processes and copies all the incoming serial data into the Oak A internal program

memory. Note that this memory is in the ARM memory space whereas the Oak A memory is in reset. Following download, the ARM executes a jump and starts to fetch out of the Oak A program memory. The downloaded routine is typically more complex and faster and is able to program a true application into the Flash memory.

If the initial handshake process fails, the AT75C310 falls back into the normal boot mode, i.e., out of the external memory.

The assembly source code of the boot program is given in section "Assembly Source Code – Boot Program" on page 126.





# AT75C310 Mode Controller

The mode controller is a memory-mapped peripheral which sits on the APB. It is used to configure the mode in which the AT75C310 operates.

| Register<br>Address | Register<br>Name | Description              | Access     | Reset Value                                                         |
|---------------------|------------------|--------------------------|------------|---------------------------------------------------------------------|
| 0x0                 | SIAP_MD          | Mode Register            | Read/write | 0x00000001 if NDSRA/BOOTN is 1; else0x00000000                      |
| 0x4                 | SIAP_ID          | ID Register              | Read       | 0x00010001 for 240-lead package;<br>0x00000001 for 160-lead package |
| 0x8                 | SIAP_RST         | Reset Status<br>Register | Read/write | 0x0000001 after hard reset                                          |

#### Table 5. Mode Controller Registers Map

### **Mode Register**

#### Register Name: SIAP\_MD

| 31  | 30  | 29  | 28  | 27  | 26  | 25 | 24 |
|-----|-----|-----|-----|-----|-----|----|----|
| _   | -   | _   | -   | -   | -   | _  | -  |
| 23  | 22  | 21  | 20  | 19  | 18  | 17 | 16 |
| _   | _   | _   | _   | _   | _   | _  | _  |
| 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  |
| CRB | CRA | DBB | DBA | SW2 | SW1 | LP | CS |
| 7   | 6   | 5   | 4   | 3   | 2   | 1  | 0  |
| _   | LP  | CS  | IB  | IA  | RB  | RA | RM |

#### RM: Remap

When reset is released, this flag is set to the value of NDSRA/BOOTN. When RM is active low, the Boot ROM is mapped to 0x00000000. Subsequently, this flag can be set high by software so that the ROM mapping is disabled and another memory controller region (e.g., Flash) is mapped to location 0x00000000.

#### RA: OAKA Reset

This flag resets to active low so that the Oak A is held in reset. The Oak A is released from reset by asserting this flag high and then low three times. This generates the required reset sequence to the Oaks of 010101.

#### RB: OAKB Reset

This flag resets to active low so that Oak B is held in reset. The Oak B is released from reset by asserting this flag high and then low three times. This generates the required reset sequence to the Oaks of 010101.

#### • IA: Inhibit Oak A Clock

This flag resets to active low so that the Oak A clock is enabled. The Oak A clock is inhibited by asserting this flag high.

#### • IB: Inhibit Oak B Clock

This flag resets to active low so that the Oak B clock is enabled. The Oak B clock is inhibited by setting this flag high.

#### • CS: Synchronous Clock Mode

When high, the ARM, Oak A and Oak B run from the OakDSPCore clock, thus the ARM runs at 20 MHz and the OakDSPCores at 40 MHz. When low, the ARM and OakDSPCores run from asynchronous clocks.

• LP: Low Power Mode

When high, the ARM is clocked at the low-power frequency. The DMC clock is disabled so the DRAM refresh is also disabled. This field can only be set to high. Writing a zero to this field has no effect. Low-power mode can only be exited by a reset. See the section "Clocking" on page 10 for more details.

AT75C310

#### LPCS: Low Power Clock Select

This field is used to select a slower clock frequency for the ARM system clock. This field is sampled when the LP flag is changed from low to high. When the LP flag is low, this field is ignored. Once the LP flag has been set high, further changes to this field have no effect. See the section "Clocking" on page 10 for more details.

| LP | CS | Divisor | ACLK Frequency |
|----|----|---------|----------------|
| 0  | 0  | 1       | 8 MHz          |
| 0  | 1  | 32      | 500 kHz        |
| 1  | 0  | 128     | 125 kHz        |
| 1  | 1  | 1024    | 16 kHz         |

#### DBA: Oak A Debug Mode

This flag resets low. This bit should be set to enter Oak A debug mode (test-specific pins are multiplexed out on functional pins).

#### • DBB: Oak B Debug Mode

This flag resets low. This bit should be set to enter Oak B debug mode (test-specific pins are multiplexed out on functional pins).

#### CRA: Codec A Reset

This flag resets to active low so that the Codec A is held in reset. The Codec A is released from reset by asserting this flag high.

#### CRB: Codec B Reset

This flag resets to active low so that the Codec A is held in reset. The Codec A is released from reset by asserting this flag high.

#### SW1: Software Reset 1

Writing a one to this bit forces the AT75C310 into reset with RM set to zero.

#### • SW2: Software Reset 2

Writing a one to this bit forces the AT75C310 into reset with RM set to one.





# **ID Register**

**Register Name:** SIAP\_ID 31 30 29 28 27 26 25 24 \_ \_ \_ \_ \_ \_ \_ -23 22 21 20 19 18 17 16 \_ \_ \_ -----15 14 13 12 11 10 9 8 PKG \_ \_ \_ \_ \_ \_ \_ 7 6 5 4 3 2 1 0 \_ \_ \_ \_ \_ VERS VERS VERS

#### PKG: Package

This bit reflects the state of the data bus width signal DBW and indicates the AT75C310 package size, 1 for the 240lead PQFP option and 0 for the 160-lead PQFP option. The signal DBW is bonded to either power or ground depending on the package used during manufacturing.

#### • VERS[2:0]: Version

This flag indicates the version number of the AT75C310. This field is reset to 0 x 1.

#### **Reset Register**

| Register Name: | SIAP_RST |
|----------------|----------|
|----------------|----------|

| 31 | 30 | 29 | 28 | 27 | 26  | 25  | 24  |
|----|----|----|----|----|-----|-----|-----|
| _  | -  | _  | _  | _  | _   | _   | -   |
| 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16  |
| -  | _  | _  | _  | _  | _   | _   | -   |
| 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8   |
| _  | _  | _  | _  | _  | _   | _   | -   |
| 7  | 6  | 5  | 4  | 3  | 2   | 1   | 0   |
| _  | _  | _  | _  | _  | RST | RST | RST |

#### RST[2:0]: Reset

These bits indicate the cause of the last reset.

|   | RST |   | Reset Event    |
|---|-----|---|----------------|
| 0 | 0   | 1 | Hardware       |
| 0 | 1   | 0 | Watchdog Timer |
| 1 | 0   | 0 | Software       |

# **EBI: External Bus Interface**

The EBI generates the signals which control access to the external memory or peripheral devices. The EBI is fully programmable and can address up to 64 megabytes. Its main characteristic is to allow the connection of both static and dynamic memories on the same bus. The address and data lines are shared between static and dynamic devices whereas the control lines are distinct. The control lines are driven by two separate subsystems: the SMC (static memory controller) and the DMC (dynamic memory controller). The static devices include regular static memories and memory-mapped peripherals. The supported dynamic devices are mainly EDO RAMs.

#### **SMC: Static Memory Controller**

The static memory controller (SMC) is used by the AT75C310 to access external static memory devices. Static memory devices include external Flash, SRAM or peripherals.

The SMC provides a glueless memory interface to external memory using the common address and data bus and some dedicated control signals. The SMC is highly programmable and has up to 24 bits of address bus, a 32- or 16-bit data bus and up to four chip select lines. The SMC supports different access protocols allowing single clockcycle accesses. The SMC is programmed as an internal peripheral that has a standard APB bus interface and a set of memory-mapped registers. The SMC shares the external address and data buses with the DMC and any external bus master.

#### **External Memory Mapping**

The memory map associates the internal 32-bit address space with the external 24-bit address bus. The memory map is defined by programming the base address and page size of the external memories. Note that A2 - A23 is only significant for 32-bit memory and A1 - A23 for 16-bit memory.

If the physical memory-mapped device is smaller than the programmed page size, it wraps around and appears to be repeated within the page. The SMC correctly handles any valid access to the memory device within the page.

In the event of an access request to an address outside any programmed page, an abort signal is generated by the internal decoder. Two types of abort are possible: instruction prefetch abort and data abort. The corresponding exception vector addresses are 0x0000000C and 0x00000010. It is up to the system programmer to program the exception handling routine used in case of an abort.

If the AT75C310 is in internal boot mode, any chip select configured with a base address of zero will be disabled as the internal ROM is mapped to address zero.





#### Signal Interface Table 6. Signal Interface

| FPDRAM   | Description                                 | Туре | Notes                                           |
|----------|---------------------------------------------|------|-------------------------------------------------|
| A[23:0]  | Address bus                                 | 0    |                                                 |
| D[31:0]  | Data bus                                    | I/O  | D[15:0] used when Data Bus Width is 16          |
| NCE[3:0] | Active low chip enables                     | 0    | NCE[3] can be configured for LCD interface mode |
| NWE[3:0] | Active low byte select/write strobe signals | 0    |                                                 |
| NWR      | Active low write strobe signals             | 0    |                                                 |
| NSOE     | Active low read enable signal               | 0    |                                                 |
| NWAIT    | Active low wait signal                      | I    |                                                 |

#### Data Bus Width

A data bus width of 32 or 16 bits can be selected for each chip select. This option is controlled by the DBW field in the Chip Select Register (SMC\_CSR) of the corresponding chip select.

The AT75C310 always boots up with a data bus width of 16 bits set in SMC\_CSR0.

#### Byte-write or Byte-select Mode

Each chip select with a 32-/16-bit data bus operates with one or two different types of write mode:

- 1. Byte-write mode supports four (32-bit bus) or two (16-bit bus) byte writes and a single read signal.
- 2. Byte-select mode selects the appropriate byte(s) using four (32-bit bus) or two (16-bit bus) byte-select lines and separate read and write signals.

This option is controlled by the BAT field in SMC\_CSR for the corresponding chip select.

Byte-write access can be used to connect four 8-bit devices as a 32-bit memory page or two 8-bit devices as a 16-bit memory page.

For a 32-bit bus:

- The signal NWE0 is used as the write enable signal for byte 0.
- The signal NWE1 is used as the write enable signal for byte 1.
- The signal NWE2 is used as the write enable signal for byte 2.
- The signal NWE3 is used as the write enable signal for byte 3.
- The signal NSOE enables memory reads to all memory blocks.

For a 16-bit bus:

• The signal NWE0 is used as the write enable signal for byte 0.

- The signal NWE1 is used as the write enable signal for byte 1.
- The signal NSOE enables memory reads to all memory blocks.

Byte-select mode can be used to connect one 32-bit device or two 16-bit devices in a 32-bit memory page or one 16-bit device in a 16-bit memory page.

For a 32-bit bus:

- The signal NWE0 is used to select byte 0 for read and write operations.
- The signal NWE1 is used to select byte 1 for read and write operations.
- The signal NWE2 is used to select byte 2 for read and write operations.
- The signal NWE3 is used to select byte 3 for read and write operations.
- The signal NWR is used as the write enable signal for the memory block.
- The signal NSOE enables memory reads to the memory block.

For a 16-bit bus:

- The signal NWE0 is used to select byte 0 for read and write operations.
- The signal NWE1 is used to select byte 1 for read and write operations.
- The signal NWR is used as the write enable signal for the memory block.
- The signal NSOE enables memory reads to the memory block.

During boot, the number of external devices (number of active chip selects) and their configurations must be programmed as required. The chip select addresses that are programmed take effect immediately. Wait states also take effect immediately when they are programmed to optimize boot program execution.

#### **Read Protocols**

The SMC provides two alternative protocols for external memory read access: standard and early read. The difference between the two protocols lies in the timing of the NSOE (read cycle) waveform.

The protocol is selected by the DRP field in the memory control register (SMC\_MCR) and is valid for all memory devices. Standard read protocol is the default protocol after reset.

Standard Read Protocol

Standard read protocol implements a read cycle in which NSOE and the write strobes are similar. Both are active during the second half of the clock cycle. The first half of the clock cycle allows time to ensure completion of the previous access, as well as the output of address and NCE before the read cycle begins.

During a standard read protocol external memory access, NCE is set low and ADDR is valid at the beginning of the access, whereas NSOE goes low only in the second half of the master clock cycle to avoid bus conflict. The write strobes are the same in both protocols. The write strobes always go low in the second half of the master clock cycle.

Early Read Protocol

Early read protocol provides more time for a read access from the memory by asserting NSOE at the beginning of the clock cycle. In the case of successive read cycles in the same memory, NSOE remains active continuously. Since a read cycle normally limits the speed of operation of the external memory system, early read protocol allows a faster clock frequency to be used. However, an extra wait state is required in some cases to avoid contention on the external bus.

In early read protocol, an early read wait state is automatically inserted when an external write cycle is followed by a read cycle to allow time for the write cycle to end before the subsequent read cycle begins. This wait state is generated in addition to any other programmed wait states (i.e., data float wait). No wait state is added when a read cycle is followed by a write cycle, between consecutive accesses of the same type or between external and internal memory accesses. Early read wait states affect the external bus only. They do not affect internal bus timing.

#### Write Protocol

During a write cycle, the data becomes valid after the falling edge of the write strobe signal and remains valid after the rising edge of the write strobe. The external write strobe waveform (on the appropriate write strobe pin) is used to control the output data timing to guarantee this operation.

Thus, it is necessary to avoid excessive loading of the write strobe pins, which could delay the write signal too long and cause a contention with a subsequent read cycle in standard protocol. In early read protocol, the data can remain valid longer than in standard read protocol due to the additional wait cycle that follows a write access.

#### Wait States

The SMC can automatically insert wait states. The different types of wait states are:

- Standard wait states
- Data float wait states
- · External wait states
- · Chip select change wait states
- Early read wait states (see "Read Protocols" on page 17 for details)
- · Standard wait states

Each chip select can be programmed to insert one or more wait states during an access on the corresponding device. This is done by setting the WSE field in the corresponding SMC\_CSR. The number of cycles to insert is programmed in the NWS field in the same register. The correspondence between the number of standard wait states programmed and the number of cycles during which the write strobe pulse is held low is found in Table 7. For each additional wait state programmed, an additional cycle is added.

| Table 7. | Correspondence | Wait States/Number of Cy | cles |
|----------|----------------|--------------------------|------|
|----------|----------------|--------------------------|------|

| Wait States | Cycles |
|-------------|--------|
| 0           | 1/2    |
| 1           | 1      |

#### Data Float Wait State

Some memory devices are slow to release the external bus. For such devices, it is necessary to add wait states (data float waits) after a read access before starting a write access or a read access to a different external memory.

The data float output time (TDF) for each external memory device is programmed in the TDF field of the SMC\_CSR register for the corresponding chip select. The value (0 - 7 clock cycles) indicates the number of data float waits to be inserted and represents the time allowed for the data output to go high-impedance after the memory is disabled.

The SMC keeps track of the programmed external data float time even when making internal accesses, thus ensuring that the external memory system is not accessed while it is still busy.

Internal memory accesses and consecutive accesses to the same external memory do not have added data float wait states.

When data float wait states are being used, the SMC prevents the DMC or external master from accessing the external data bus.





#### • External Wait

The NWAIT input can be used to add wait states at any time NWAIT is active low and is detected on the rising edge of the clock. If NWAIT is low at the rising edge of the clock, the SMC adds a wait state and does not change the output signals.

Chip Select Change Wait States

A chip select wait state is automatically inserted when consecutive accesses are made to two different external memories and no wait states have been inserted. If wait states have been inserted (e.g., data float wait), then none are added.

#### LCD Interface Mode

NCE3 can be configured for use with an external LCD controller by setting the LCD bit in the SMC\_CSR3 register. Additionally, WSE must be set and NWS programmed with a value of 1 or more.

In LCD mode, NCE3 is shortened by one-half clock cycle at the leading and trailing edges, providing positive address setup and hold. For read cycles, the data is latched in the SMC as NCE3 is raised at the end of the access.

#### **SMC Register Map**

The SMC is programmed using the registers listed in Table 8. The memory control register (SMC\_MCR) is used to program the number of active chip selects and data read protocol. Four chip select registers (SMC\_CSR0 to SMC\_CSR3) are used to program the parameters for the individual external memories. Each SMC\_CSR must be programmed with a different base address even for unused chip selects. The AT75C310 resets such that SMC\_CSR0 is configured as having a 16-bit data bus.

|        | 5 1                         |               |            |             |
|--------|-----------------------------|---------------|------------|-------------|
| Offset | <b>Register Description</b> | Register Name | Access     | Reset State |
| 0x00   | Chip Select Register        | SMC_CSR0      | Read/write | 0x0000203D  |
| 0x04   | Chip Select Register        | SMC_CSR1      | Read/write | 0x10000000  |
| 0x08   | Chip Select Register        | SMC_CSR2      | Read/write | 0x20000000  |
| 0x0C   | Chip Select Register        | SMC_CSR3      | Read/write | 0x30000000  |
| 0x10   | Reserved                    | -             | -          | _           |
| 0x14   | Reserved                    | -             | -          | _           |
| 0x18   | Reserved                    | -             | -          | _           |
| 0x1C   | Reserved                    | -             | -          | _           |
| 0x20   | Reserved                    | _             | -          | _           |
| 0x24   | Memory Control Register     | SMC_MCR       | Read/write | 0           |

#### Table 8. SMC Register Map

# **SMC Chip Select Register**

| Register Name | SMC_C | SMC_CSR0SMC_CSR3 |     |     |     |    |       |
|---------------|-------|------------------|-----|-----|-----|----|-------|
| 31            | 30    | 29               | 28  | 27  | 26  | 25 | 24    |
|               |       |                  | E   | ЗА  |     |    |       |
| 23            | 22    | 21               | 20  | 19  | 18  | 17 | 16    |
|               | I     | ЗА               |     | -   | -   | _  | LCD   |
| 15            | 14    | 13               | 12  | 11  | 10  | 9  | 8     |
| -             | _     | CSEN             | BAT |     | TDF |    | PAGES |
| 7             | 6     | 5                | 4   | 3   | 2   | 1  | 0     |
| PAGES         | _     | WSE              |     | NWS |     | D  | BW    |

#### • DBW: Data Bus Width

| DE | 3W | Data Bus Width      |
|----|----|---------------------|
| 0  | 0  | Reserved            |
| 0  | 1  | 16-bit external bus |
| 1  | 0  | 32-bit external bus |
| 1  | 1  | Reserved            |

#### • WSE: Wait State Enable

# • NWS: Number of Wait States

This field is valid only if WSE is set.

|   | NWS |   | WSE | Wait States |
|---|-----|---|-----|-------------|
| х | х   | х | 0   | 0           |
| 0 | 0   | 0 | 1   | 1           |
| 0 | 0   | 1 | 1   | 2           |
| 0 | 1   | 0 | 1   | 3           |
| 0 | 1   | 1 | 1   | 4           |
| 1 | 0   | 0 | 1   | 5           |
| 1 | 0   | 1 | 1   | 6           |
| 1 | 1   | 0 | 1   | 7           |
| 1 | 1   | 1 | 1   | 8           |



#### • PAGES: Page Size

| PAGES |   | Page Size | Base<br>Address |
|-------|---|-----------|-----------------|
| 0     | 0 | 1 MB      | BA[31 - 20]     |
| 0     | 1 | 4 MB      | BA[31 - 22]     |
| 1     | 0 | 16 MB     | BA[31 - 24]     |
| 1     | 1 | Reserved  | _               |

#### • TDF: Data Float Output Time

|   | TDF |   | Cycles after Transfer |
|---|-----|---|-----------------------|
| 0 | 0   | 0 | 0                     |
| 0 | 0   | 1 | 1                     |
| 0 | 1   | 0 | 2                     |
| 0 | 1   | 1 | 3                     |
| 1 | 0   | 0 | 4                     |
| 1 | 0   | 1 | 5                     |
| 1 | 1   | 0 | 6                     |
| 1 | 1   | 1 | 7                     |

#### • BAT: Byte Access Mode

- 0 = Byte-write Mode
- 1 = Byte-select Mode
- CSEN: Chip Select Enable
   Active high

#### LCD: LCD Mode Enable

Active high. SMC\_CSR3 only.

#### • BA: Base Address

This field contains the high-order bits of the base address. If the page size is larger than 1 MB, then the unused bits of the base address are ignored by the SMC decoder.

# **SMC Memory Control Register**

| F | Register Name | : SMC_M | CR |     |    |    |    |    |
|---|---------------|---------|----|-----|----|----|----|----|
|   | 31            | 30      | 29 | 28  | 27 | 26 | 25 | 24 |
|   | _             | _       | _  | -   | _  | _  | _  | _  |
|   | 23            | 22      | 21 | 20  | 19 | 18 | 17 | 16 |
|   | _             | _       | _  | -   | _  | _  | _  | _  |
|   | 15            | 14      | 13 | 12  | 11 | 10 | 9  | 8  |
|   | -             | _       | _  | -   | _  | _  | _  | _  |
|   | 7             | 6       | 5  | 4   | 3  | 2  | 1  | 0  |
|   | _             | _       | _  | DRP | _  | _  | _  | _  |

#### • DRP: Data Read Protocol

0 = Standard Read Mode

1 = Early Read Mode





#### **Switching Waveforms**

Figure 3 shows a write to memory 0, followed by a write and a read to memory 1. SMC\_CSR0 is programmed for one wait state with BAT = 0 and DFT = 0. SMC\_CSR1 is programmed for zero wait states with BAT = 1 and

DFT = 0. SMC\_MCR is programmed for early reads from all memories.

The write to memory 0 is a 32-bit word access and, therefore, all four NWE strobes are active. As BAT = 0, they are configured as write strobes and have the same timing as NWR. As the access employs a single wait state, the write strobe pulse is one clock cycle long.

There is a chip select change wait state between the memory 0 write and the memory 1 write. The new address is output at the end of the memory 0 access but the strobes are delayed for one clock cycle.

The write to memory 1 is a half-word (16-bit) access to an odd half-word address and, therefore, NWE2 and NWE3 are active. As BAT = 1 they are configured as byte-select

Figure 3. Write to Memory 0, Write and Read to Memory 1

signals and have the same timing as NCE. As the access has no internal wait states, the write strobe pulse is onehalf clock cycle long. Data and address are driven until the write strobe rising edge is sensed at the SIAP pin to guarantee positive hold times.

There is an early read wait state between the memory 1 write and the memory 1 read to provide time for the AT75C310 to disable the output data before the memory is read. If the read was normal mode, i.e., not early, the NSOE strobe would not fall until the rising edge of BCLK and no wait state would be inserted. If the write and early read were to different memories, then the early read wait state is not required as a chip select wait state will be implemented.

The read from memory 1 is a byte access to an address with a byte offset of two and, therefore, only NWE2 is active.



Figure 4 shows a write and a read to memory 0, followed by a read and a write to memory 1. SMC\_CSR0 is programmed for zero wait states with BAT = 0 and DFT = 0. SMC CSR1 is programmed for zero wait states with

BAT = 1 and DFT = 1. SMC\_MCR is programmed for normal reads from all memories

The write to memory 0 is a byte access and, therefore, only one NWE strobe is active. As BAT = 0, they are configured as write strobes and have the same timing as NWR.

The memory 0 read immediately follows the write as early reads are not configured and an early read wait state is not required. As early reads are not configured, the read strobe pulse is one-half clock cycle long.

There is a chip select change wait state between the memory 0 write and the memory 1 read. The new address is output at the end of the memory 0 access but the strobes are delayed for one clock cycle.

The write to memory 1 is a half-word (16-bit) access to an even half-word address and, therefore, NWE0 and NWE1 are active. As BAT = 1, they are configured as byte select signals and have the same timing as NCE.

As DFT = 1 for memory 1, a wait state is implemented between the read and write to provide time for the memory to stop driving the data bus. DFT wait states are only implemented at the end of read accesses.

The read from memory 1 is a byte access to an address with a byte offset of two and, therefore, only NWE2 is active.



#### Figure 4. Write and Read to Memory 0, Read and Write to Memory 1



### **DMC: Dynamic Memory Controller**

The ARM can access external DRAM by means of the DRAM memory controller. The DMC sits on the ASB bus and provides a glueless memory interface to external EDO DRAM using the common address and data buses.

The AT75C310 supports two DRAM memory regions, each with its own RAS signal. Both DRAM regions share the same CAS, OE, WE, address and data signals.

The DRAM controller is programmed as an internal peripheral that has a standard APB bus interface and a set of memory-mapped registers.

The DMC is designed to operate with extended data-out (EDO) DRAM. It supports two 16-MByte address spaces and a programmable 16- or 32-bit data bus. The controller multiplexes the processor address to form DRAM row and column addresses. The row and column addresses can be configured to support various combinations of DRAM memory size, page size and data bus width.

The DMC supports:

- One or two DRAM memory regions
- DRAM memory region size of 2, 4, 8 or 16 megabytes
- DRAM page size of 256, 512, 1024 or 2048 columns
- Up to 15 row- and 11 column-address bits
- · Asymmetric row and column addressing
- · 16- or 32-bit DRAM data bus
- Automatic page breaking of burst accesses
- · Automatic CAS-before-RAS refresh on timer trigger
- · Automatic power-up initialization sequence

#### **DMC Operation**

The DMC multiplexes the ASB address to DRAM row and column addresses. The column address must be between eight and eleven bits. The row address is the required number of higher-order bits to support all combinations of permitted page- and memory-region sizes and both data bus widths.

The DMC automatically inserts precharge and RAS cycles and supplies an updated row address to the DRAM when a sequential burst access from an ASB bus master crosses a

DRAM page boundary. The necessary number of wait states is inserted to hold the bus master during the precharge and RAS cycles.

The DMC performs a CAS-before-RAS refresh cycle on both DRAM memory regions on the rising edge of a trigger signal from the AT75C310 on-chip timer. If the DMC is performing a DRAM access when the trigger occurs, the access will finish before the refresh operation is performed. In the case of a burst access, the refresh is not performed until the end of the burst.

The DMC is capable of limiting the length of a burst access if a refresh trigger has been received. If the feature is enabled, the DMC performs the refresh operation once it has been pending for 32 accesses in a burst sequence.

The DMC includes the functionality to interface the 32-bit ASB data bus with a 16-bit DRAM data bus. It automatically performs two accesses to the DRAM to service a 32-bit access from the ASB.

#### **Initialization Sequence**

The DMC performs eight CAS-before-RAS refresh operations to both DRAM banks at the end of the AT75C310 reset pulse. The processor is not required to perform any DRAM initialization operations. However, it is required to initialize the DMC.

#### **Data Alignment**

The DMC only supports accesses to the appropriate data boundary, i.e., word accesses must be word-aligned and half-word accesses must be half-word-aligned. Misaligned accesses will be ignored by the DMC, and the AMBA decoder will therefore flag an abort to the appropriate ASB bus master.

The ARM processor does not guarantee the level of the bottom two address bits for an instruction access in ARM state or the bottom address bit for an instruction fetch in Thumb state. Therefore, the DMC will service misaligned instruction fetches and force alignment, e.g., a 16-bit instruction fetch from address 0x00000003 is performed as a 16-bit read of address 0x00000002.

| Register Offset | Register Description                 | Register Name | Access     |
|-----------------|--------------------------------------|---------------|------------|
| 0x0             | DRAM Region 0 Configuration Register | DMC_MR0       | Read/write |
| 0x4             | DRAM Region 1 Configuration Register | DMC_MR1       | Read/write |
| 0x8             | DRAM Common Configuration Register   | DMC_CR        | Read/write |

Table 9. DMC Register Map

# **DRAM Memory Region Configuration Register**

For each of the two DRAM memory regions there is a memory-mapped register.

Register Name: DMC\_MR0..DMC\_MR1

Reset value of DMC\_MR0 is 0x40000000; reset value of DMC\_MR1 is 0x50000000

| 31 | 30 | 29 | 28  | 27 | 26 | 25 | 24  |
|----|----|----|-----|----|----|----|-----|
|    |    |    | E   | ЗА |    |    |     |
| 23 | 22 | 21 | 20  | 19 | 18 | 17 | 16  |
|    | BA |    | _   | -  | _  | _  | -   |
| 15 | 14 | 13 | 12  | 11 | 10 | 9  | 8   |
| -  | _  | _  | _   | -  | _  | _  | _   |
| 7  | 6  | 5  | 4   | 3  | 2  | 1  | 0   |
| -  | -  | _  | , c | SZ | Р  | S  | EMR |

#### • EMR: Enable Memory Region

When low, the memory region is not enabled; any access to this region will generate an abort.

#### • PS: Page Size

This field should be set to the number of column address lines that are required by the external DRAM. It also indicates the number of columns per page. The controller breaks sequential bursts on page boundaries.

| Р | S | Columns | No. Column Address Lines |
|---|---|---------|--------------------------|
| 0 | 0 | 256     | 8                        |
| 0 | 1 | 512     | 9                        |
| 1 | 0 | 1024    | 10                       |
| 1 | 1 | 2048    | 11                       |

#### SZ: Size

This field indicates the size of the memory region.

| S | Z | Size of Memory Region |
|---|---|-----------------------|
| 0 | 0 | 2 MB                  |
| 0 | 1 | 4 MB                  |
| 1 | 0 | 8 MB                  |
| 1 | 1 | 16 MB                 |

#### BA: Base Address

This field indicates the base address of the memory region. It should be programmed with the top 11 bits of the required base address. The number of bits used for address decoding is dependent on the SZ field.

| SZ    | BA Bits Used |
|-------|--------------|
| 2 MB  | BA[31:21]    |
| 4 MB  | BA[31:22]    |
| 8 MB  | BA[31:23]    |
| 16 MB | BA[31:24]    |





# DRAM Common Configuration Register (DMC\_CR)

The Common Configuration Register defines parameters which are common to the two DRAM regions.

Register Name: DMC\_CR

Reset Value is 0x00000000

| 31 | 30 | 29 | 28 | 27 | 26  | 25  | 24  |
|----|----|----|----|----|-----|-----|-----|
| _  | -  | _  | _  | -  | _   | _   | -   |
| 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16  |
| -  | -  | _  | _  | _  | _   | _   | -   |
| 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8   |
| -  | -  |    | -  | -  |     | -   | -   |
| 7  | 6  | 5  | 4  | 3  | 2   | 1   | 0   |
| -  | -  | _  | _  | -  | ROR | BBR | DBW |

#### • DBW: Data Bus Width

When high, the DRAM data bus is 32 bits wide. When low, the DRAM data bus is only 16 bits wide. The DMC splits 32bit transfers into two 16-bit transfers which are transparent to the ASB.

#### BBR: Break Burst for Refresh

When this flag is high, the controller breaks long burst accesses every 32 CAS cycles if a refresh cycle is pending in order to allow the refresh cycle to be performed. This prevents excessively long bursts from delaying refresh cycles.

#### ROR: RAS-only Refresh

When high, the CAS signal is held inactive (high) during normal DRAM accesses, thereby generating a RAS-only Refresh cycle. This feature allows software to generate the row address and initiate the refresh cycle. When low, memory operations behave as normal and CAS is not inhibited.

#### DRAM Interface

#### Table 10. DRAM Interface

| FPDRAM               | Description              | Туре | Notes                                                                                           |
|----------------------|--------------------------|------|-------------------------------------------------------------------------------------------------|
| NRAS[1:0]            | :0] Row Address Strobe O |      | One strobe per DRAM region. Common to four bytes in each region                                 |
| NCAS[3:0]            | Column Address<br>Strobe | 0    | One strobe per byte. Common to both DRAM regions. Only NCAS[1:0] used when Data Bus Width is 16 |
| NWE                  | Write Enable             | 0    | Common to both regions                                                                          |
| NOE                  | NOE Output Enable O      |      | Common to both regions                                                                          |
| A[14:0]              | Address Bus              | 0    | Multiplexed row and column addresses                                                            |
| D[31:0] Data Bus I/O |                          | I/O  | D[15:0] used when Data Bus Width is 16                                                          |

### **Dynamic Memory Accesses**

Figure 5 and Figure 6 describe the different bus operations that can be performed by DMC.

#### Write Access Followed by Burst Read Access

Figure 5 shows a write to DRAM0 followed by a burst of two reads from the same device.

The write access takes two clock cycles. During the first cycle, the row address is output and the RAS strobe is asserted. In the next cycle, the column address is output and the CAS strobes are asserted. The read is a half-word (16-bit) access to an odd half-word address so only CAS2 and CAS3 are active.

The read access is not sequential to the write access (regardless of the addresses) and the RAS strobe is therefore raised for a precharge cycle between the accesses.

The read accesses take two clock cycles to read the first word of data and one additional clock cycle for the second word. The row address and RAS are asserted in the same manner as for the read access. The column address and CAS strobes are asserted earlier for a read access than for a write access in order to provide time for the data to read the processor core. The read accesses shown are word (32-bit) accesses and all four CAS strobes are therefore active.

The DMC asserts BWAIT to the ARM during the row address and precharge cycles.



#### Figure 5. Write to DRAM0 Waveform





# Read and Write Accesses Followed by CAS before RAS Refresh

Figure 6 shows a read access followed by a write. As the accesses are to different devices, there is no need for a precharge cycle.

The read is a byte access (one CAS strobe is active) and the write is a half-word access (two CAS strobes are active).

The CAS before RAS refresh cycle refreshes all DRAM devices controlled by the DMC. All RAS and CAS strobes are therefore active.





# **AIC: Advanced Interrupt Controller**

The AT75C310 has an eight-level priority, individually maskable interrupt controller. This feature substantially reduces the software and real-time overhead in handling internal and external interrupts.

The interrupt controller is connected to the NFIQ (fast interrupt request) and the NIRQ (standard interrupt request) inputs of the ARM7TDMI processor. The processor's NFIQ line can only be asserted by the external fast interrupt request input FIQ. The NIRQ line can be asserted by the interrupts generated by the on-chip peripherals and the external interrupt request lines IRQ0 and FIQ.

Figure 7. Interrupt Controller Block Diagram

The eight-level priority encoder allows the customer to define the priority between the different NIRQ interrupt sources.

Internal sources are programmed to be level-sensitive or edge-triggered. External sources can be programmed to be positive- or negative-edge triggered or high- or low-level sensitive.

The interrupt sources are listed in Table 11 and the AIC programmable registers in Table 12.



Note: After a hardware reset, the AIC pins are controlled by the PIO controller. They must be configured to be controlled by the peripheral before being used.





Table 11. AIC Interrupt Sources

| Interrupt Source | Interrupt Name | Interrupt Description                |
|------------------|----------------|--------------------------------------|
| 0                | FIQ/LOWP       | Fast interrupt (external), low-power |
| 1                | WDIRQ          | Watchdog                             |
| 2                | SWIRQ          | Software (Generated by AIC)          |
| 3                | UAIRQ          | USART A                              |
| 4                | TCOIRQ         | Timer/Counter0                       |
| 5                | TC1IRQ         | Timer/Counter1                       |
| 6                | TC2IRQ         | Timer/Counter2                       |
| 7                | PIOAIRQ        | PIO A                                |
| 8                | LCDIRQ         | LCD Controller                       |
| 9                | SPIIRQ         | SPI                                  |
| 10               | IRQ0           | External 0                           |
| 11               | _              | Reserved                             |
| 12               | OAKIRQ         | OAK A Semaphore                      |
| 13               | OAKBIRQ        | OAK B Semaphore                      |
| 14               | UBIRQ          | USART B                              |
| 15               | PIOBIRQ        | PIO B                                |
| 16               | _              | Reserved                             |
| 17               | _              | Reserved                             |
| 18               | _              | Reserved                             |
| 19               | _              | Reserved                             |
| 20               | _              | Reserved                             |
| 21               | _              | Reserved                             |
| 22               | _              | Reserved                             |
| 23               | _              | Reserved                             |
| 24               | _              | Reserved                             |
| 25               | -              | Reserved                             |
| 26               | _              | Reserved                             |
| 27               | _              | Reserved                             |
| 28               | -              | Reserved                             |
| 29               | _              | Reserved                             |
| 30               | _              | Reserved                             |
| 31               | _              | Reserved                             |



### **Priority Controller**

The NIRQ line is controlled by an eight-level priority encoder. Each source has a programmable priority level of 7 to 0. Level 7 is the highest priority and level 0 the lowest.

When the AIC receives more than one unmasked interrupt at a time, the interrupt with the highest priority is serviced first. If both interrupts have equal priority, the interrupt with the lowest interrupt source number is serviced first. Interrupt source numbers are given in Table 11.

The current priority level is defined as the priority level of the current interrupt at the time the register AIC\_IVR is read (the interrupt which will be serviced).

If a higher priority unmasked interrupt occurs and an interrupt already exists, there are two possible outcomes depending on whether the AIC\_IVR has been read.

- 1. If the NIRQ line has been asserted but the AIC\_IVR has not been read, then the processor will read the new higher priority interrupt handler address in the AIC\_IVR register and the current interrupt level is updated.
- 2. If the processor has already read the AIC\_IVR, then the NIRQ line is reasserted. When the processor has authorized nested interrupts to occur and reads the AIC\_IVR again, it reads the new, higher-priority interrupt handler address. At the same time, the current priority value is pushed onto a first-in lastout stack and the current priority is updated to the higher priority.

When the End of Interrupt Command Register (AIC\_EOICR) is written, the current interrupt level is updated with the last stored interrupt level from the stack (if any). Hence, at the end of a higher priority interrupt, the AIC returns to the previous state corresponding to the preceding lower priority interrupt which had been interrupted.

#### **Interrupt Handling**

The interrupt handler must read the AIC\_IVR as soon as possible. This de-asserts the NIRQ request to the processor and clears the interrupt in case it is programmed to be edge-triggered. This permits the AIC to assert the NIRQ line again when a higher-priority unmasked interrupt occurs.

At the end of the interrupt service routine, the End of Interrupt Command Register (AIC\_EOICR) must be written. This allows pending interrupts to be serviced.

#### **Interrupt Masking**

Each interrupt source, including FIQ, can be enabled or disabled using the command registers AIC\_IECR and AIC\_IDCR. The interrupt mask can be read in the read-only register AIC\_IMR. A disabled interrupt does not affect the servicing of other interrupts.

#### Interrupt Clearing and Setting

All interrupt sources which are programmed to be edgetriggered (including FIQ) can be individually set or cleared by writing to the registers AIC\_ISCR and AIC\_ICCR, respectively. This function of the interrupt controller is available for auto-test or software debug purposes.

#### Fast Interrupt Request

The external FIQ line is the only source which can raise a fast interrupt request to the processor. Therefore, it has no priority controller.

The external FIQ line can be programmed to be positive- or negative-edge triggered or high- or low-level sensitive in the AIC\_SMR0 register.

The interrupt handler can be stored starting from address 0x0000001C as described in the Atmel ARM7TDMI datasheet, literature number 0673.

#### **Software Interrupt**

Interrupt source 1 of the AIC is a software interrupt. It must be programmed to be edge-triggered in order to set or clear it by writing to the AIC\_ISCR and AIC\_ICCR.

This is independent of the SWI instruction of the ARM7TDMI processor.

#### **Standard Interrupt Sequence**

The following conditions are assumed:

- The AIC has been programmed and interrupts are enabled.
- The instruction at address 0x18 (IRQ exception vector address) jumps into a default handler which reads AIC\_IVR and then jumps to the specific service routine for the read interrupt number.

When NIRQ is asserted, if the bit "I" of CPSR is 0, the sequence is:

- The CPSR is stored in SPSR\_irq, the current value of the Program Counter is loaded in the IRQ link register (R14\_irq) and the Program Counter (R15) is loaded with 0x18. In the following cycle during fetch at address 0x1C, the ARM core adjusts R14\_irq, decrementing it by 4.
- 2. The ARM core enters IRQ mode if it is not already.
- 3. When the instruction at 0x18 is executed, the Program Counter is loaded with the start address of the default interrupt handler.
- 4. The previous interrupt priority level is stored onto a stack. Note that if no interrupt was active, the previous interrupt priority will be zero.
- 5. The AIC\_IVR register is read causing the IRQ request to be cancelled and the current interrupt priority is updated. Any registers that may be used can be stored onto the stack at this point if required. The





code then checks the interrupt number and branches to the required service routine.

- 6. The service routine should start by saving the Link Register (R14\_irq) and the SPSR (SPSR\_irq). Note that the Link Register must be decremented by four when it is saved if it is to be restored directly into the Program Counter at the end of the interrupt. Alternatively, this can be done at the start of the default handler.
- 7. Further interrupts can then be unmasked by clearing the "I" bit in the CPSR, allowing re-assertion of the NIRQ to be taken into account by the core. This occurs if an interrupt with a higher priority than the current one occurs.
- 8. The Interrupt Handler then proceeds as required, saving the registers which will be used and restoring them at the end. During this phase, an interrupt of priority higher than the current level restarts the sequence from step 1. Note that if the interrupt is programmed to be level sensitive, the source of the interrupt must be cleared during this phase.
- 9. The "I" bit in the CPSR must be set in order to mask interrupts before exiting to ensure that the interrupt is completed in an orderly manner.
- 10. The service routine should then branch to the common exit routine.
- 11. The stored priority level is fetched (from a stack) and witten to the End Of Interrupt Command Register (AIC\_EOICR) in order to indicate to the AIC that the current interrupt is finished. This restores the previous current level if one existed. If another interrupt is pending with lower or equal priority than the old current level but with higher priority than the new current level, the NIRQ line is re-asserted. The interrupt sequence does not immediately start because the "I" bit is set in the core.
- 12. The SPSR (SPSR\_irq) is restored. Finally, the saved value of the Link Register is restored directly into the PC. This has the effect of returning from the interrupt to whatever was being executed before and of loading the CPSR with the stored SPSR, masking or unmasking the interrupts depending on the state saved in the SPSR (the previous state of the ARM core).

Note that the "I" bit in the SPSR is significant. If it is set, it indicates that the ARM core was just about to mask IRQ interrupts when the mask instruction was interrupted. Hence, when the SPSR is restored, the mask instruction is completed (IRQ is masked).

### **Fast Interrupt Sequence**

It is assumed that:

- The AIC has been programmed and the fast interrupt is enabled.
- The instruction at address 0x1C (FIQ exception vector address) is a branch to an FIQ service routine or the first instruction of the FIQ routine

Nested fast interrupts are not needed by the user.

When NFIQ is asserted, if the bit "F" of CPSR is 0, the sequence is:

- The CPSR is stored in SPSR\_fiq, the current value of the Program Counter is loaded in the FIQ link register (R14\_fiq) and the Program Counter (R15) is loaded with 0x1C. In the following cycle, during fetch at address 0x20, the ARM core adjusts R14\_fiq, decrementing it by four.
- 2. The ARM core enters FIQ mode and starts executing the instruction at address 0x1c, which may be a branch or the first service routine instruction.
- 3. The AIC\_FVR register is read. This results in the cancellation of the FIQ request and returns 0x0.
- 4. The previous step has the effect of branching to the corresponding interrupt service routine. It is not necessary to save the Link Register (R14\_fiq) and the SPSR (SPSR\_fiq) if nested fast interrupts are not needed.
- 5. The Interrupt Handler then proceeds as required. It is not necessary to save registers R8 to R13 because FIQ mode has its own dedicated registers and the user R8 to R13 are banked. The other registers, R0 to R7, must be saved before being used, and restored at the end (before the next step). Note that if the fast interrupt is programmed to be level sensitive, the source of the interrupt must be cleared during this phase in order to de-assert the NFIQ line.
- 6. Finally, the Link Register (R14\_fiq) is restored into the PC after decrementing it by 4 (with instruction sub pc, Ir, #4 for example). This has the effect of returning from the interrupt to whatever was being executed before, and of loading the CPSR with the SPSR, masking or unmasking the fast interrupt depending on the state saved in the SPSR.

Note that the "F" bit in the SPSR is significant. If it is set, it indicates that the ARM core was just about to mask FIQ interrupts when the mask instruction was interrupted. Hence, when the SPSR is restored, the interrupted instruction is completed (FIQ is masked).



## **AIC User Interface**

Base Address: 0xFF030000

Table 12. AIC Memory Map

| Offset | Register Description               | Register Name | Access     | Reset State  |
|--------|------------------------------------|---------------|------------|--------------|
| 0x000  | Source Mode Register 0             | AIC_SMR0      | Read/write | 0            |
| 0x004  | Source Mode Register 1             | AIC_SMR1      | Read/write | 0            |
| _      | _                                  | _             | Read/write | 0            |
| 0x07C  | Source Mode Register 31            | AIC_SMR31     | Read/write | 0            |
| 0x080  | Reserved                           | _             | _          | _            |
| 0x084  | Reserved                           | _             | _          | _            |
| _      | Reserved                           | _             | _          | _            |
| 0x0FC  | Reserved                           | _             | _          | _            |
| 0x100  | IRQ Vector Register                | AIC_IVR       | Read-only  | 0            |
| 0x104  | FIQ Vector Register                | AIC_FVR       | Read-only  | 0            |
| 0x108  | Interrupt Status Register          | AIC_ISR       | Read-only  | 0            |
| 0x10C  | Interrupt Pending Register         | AIC_IPR       | Read-only  | (see Note 1) |
| 0x110  | Interrupt Mask Register            | AIC_IMR       | Read-only  | 0            |
| 0x114  | Core Interrupt Status Register     | AIC_CISR      | Read-only  | 0            |
| 0x118  | Reserved                           | _             | _          | _            |
| 0x11C  | Reserved                           | _             | _          | _            |
| 0x120  | Interrupt Enable Command Register  | AIC_IECR      | Write-only | _            |
| 0x124  | Interrupt Disable Command Register | AIC_IDCR      | Write-only | _            |
| 0x128  | Interrupt Clear Command Register   | AIC_ICCR      | Write-only | _            |
| 0x12C  | Interrupt Set Command Register     | AIC_ISCR      | Write-only | _            |
| 0x130  | End of Interrupt Command Register  | AIC_EOICR     | Write-only | _            |

Note: 1. The reset value of this register depends on the level of the external IRQ lines. All other sources are cleared at reset.





### **AIC Source Mode Register**

| Register Name<br>Access Type:<br>Reset Value: |     | AIC_SMR0AIC_SMR31<br>Read/write<br>0 |    |    |    |       |    |  |  |
|-----------------------------------------------|-----|--------------------------------------|----|----|----|-------|----|--|--|
| 31                                            | 30  | 29                                   | 28 | 27 | 26 | 25    | 24 |  |  |
| -                                             | _   | -                                    | -  | -  | _  | -     | -  |  |  |
| 23                                            | 22  | 21                                   | 20 | 19 | 18 | 17    | 16 |  |  |
| -                                             | _   | -                                    | -  | -  | -  | -     | -  |  |  |
| 15                                            | 14  | 13                                   | 12 | 11 | 10 | 9     | 8  |  |  |
| _                                             | _   | -                                    | _  | -  | -  | -     | -  |  |  |
| 7                                             | 6   | 5                                    | 4  | 3  | 2  | 1     | 0  |  |  |
| -                                             | SRC | SRCTYPE                              |    | -  |    | PRIOR |    |  |  |

#### • PRIOR: Priority Level

Programs the priority level for all sources except source 0 (FIQ). The priority level can be between 0 (lowest) and 7 (highest). The priority level is not used for the FIQ in the SMR0.

#### • SRCTYPE: Interrupt Source Type

Programs the input to be positive- or negative-edge triggered or positive- or negative-level sensitive. The active level or edge is not programmable for the internal sources.

| SRC | ГҮРЕ | Internal Sources | External Sources        |  |
|-----|------|------------------|-------------------------|--|
| 0   | 0    | Level-sensitive  | Low-level sensitive     |  |
| 0   | 1    | Edge-triggered   | Negative-edge triggered |  |
| 1   | 0    | Level-sensitive  | High-level sensitive    |  |
| 1   | 1    | Edge-triggered   | Positive-edge triggered |  |

### **AIC Interrupt Vector Register**

| Register Name:<br>Access Type:<br>Reset Value: | AIC_IVR<br>Read-only<br>0 | ,  |    |    |    |    |    |
|------------------------------------------------|---------------------------|----|----|----|----|----|----|
| 31                                             | 30                        | 29 | 28 | 27 | 26 | 25 | 24 |
| -                                              | -                         | -  | -  | -  | -  | -  | -  |
| 23                                             | 22                        | 21 | 20 | 19 | 18 | 17 | 16 |
| -                                              | -                         | -  | -  | -  | -  | -  | -  |
| 15                                             | 14                        | 13 | 12 | 11 | 10 | 9  | 8  |
| -                                              | -                         | -  | -  | -  | -  | -  | -  |
| 7                                              | 6                         | 5  | 4  | 3  | 2  | 1  | 0  |
| PRIOR IRQID                                    |                           |    |    |    |    |    |    |

#### PRIOR

Interrupt priority

IRQID

Active interrupt number. Used to select required service routine.

# **AIC FIQ Vector Register**

| Register Name:<br>Access Type:<br>Reset Value:     | AIC_FVR<br>Read-only<br>0                             |                          |                    |                    |                |                   |                   |
|----------------------------------------------------|-------------------------------------------------------|--------------------------|--------------------|--------------------|----------------|-------------------|-------------------|
| 31                                                 | 30                                                    | 29                       | 28                 | 27                 | 26             | 25                | 24                |
|                                                    |                                                       |                          | FI                 | QV                 |                |                   |                   |
| 23                                                 | 22                                                    | 21                       | 20                 | 19<br>QV           | 18             | 17                | 16                |
|                                                    |                                                       |                          |                    |                    | 10             |                   |                   |
| 15                                                 | 14                                                    | 13                       | 12                 | 11<br>QV           | 10             | 9                 | 8                 |
|                                                    |                                                       |                          |                    |                    |                |                   |                   |
| 7                                                  | 6                                                     | 5                        | 4                  | 3<br>QV            | 2              | 1                 | 0                 |
| AIC Interrupt S                                    | 10103 1159131                                         |                          |                    |                    |                |                   |                   |
| ccess Type:                                        | AIC_ISR<br>Read-only<br>0                             |                          |                    |                    |                |                   |                   |
| ccess Type:                                        | AIC_ISR<br>Read-only                                  | 29                       | 28                 | 27                 | 26             | 25                | 24                |
| Access Type:<br>Reset Value:                       | AIC_ISR<br>Read-only<br>0                             |                          | 28                 | 27                 | 26             | 25<br>-           | 24                |
| Access Type:<br>Reset Value:<br>31                 | AIC_ISR<br>Read-only<br>0<br>30                       | 29                       | - 20               | -<br>19            | 1              | - 17              | -<br>16           |
| Access Type:<br>Reset Value:<br>31<br>-            | AIC_ISR<br>Read-only<br>0<br>30<br>-                  | 29                       | -                  | -                  | -              | -                 | -                 |
| Access Type:<br>Reset Value:<br>31<br>-<br>23      | AIC_ISR<br>Read-only<br>0<br>30<br>-<br>22            | 29<br>-<br>21            | - 20               | -<br>19            | - 18           | - 17              | -<br>16           |
| Access Type:<br>Reset Value:<br>31<br>-<br>23<br>- | AIC_ISR<br>Read-only<br>0<br>30<br>-<br>22<br>-       | 29<br>-<br>21<br>-       | -<br>20<br>-       | -<br>19<br>-       | -  <br>18<br>- | -<br>17<br>-      | -<br>16<br>-      |
| - 23<br>- 15                                       | AIC_ISR<br>Read-only<br>0<br>30<br>-<br>22<br>-<br>14 | 29<br>-<br>21<br>-<br>13 | -<br>20<br>-<br>12 | -<br>19<br>-<br>11 | - 18<br>- 10   | -<br>17<br>-<br>9 | -<br>16<br>-<br>8 |

#### • PRIOR

Interrupt priority

#### IRQID

Active interrupt number. Used to select required service routine.





# **AIC Interrupt Pending Register**

| Register Name:<br>Access Type:<br>Reset Value: | AIC_IPR<br>Read-on<br>Undefine | ly      |         |       |       |        |        |
|------------------------------------------------|--------------------------------|---------|---------|-------|-------|--------|--------|
| 31                                             | 30                             | 29      | 28      | 27    | 26    | 25     | 24     |
| -                                              | _                              | _       | -       | -     | -     | _      | _      |
| 23                                             | 22                             | 21      | 20      | 19    | 18    | 17     | 16     |
| -                                              | _                              | _       | -       | -     | -     | _      | -      |
| 15                                             | 14                             | 13      | 12      | 11    | 10    | 9      | 8      |
| PIOBIRQ                                        | UBIRQ                          | OAKBIRQ | OAKAIRQ | -     | IRQ0  | SPIIRQ | LCDIRQ |
| 7                                              | 6                              | 5       | 4       | 3     | 2     | 1      | 0      |
| PIOAIRQ                                        | TC2IRQ                         | TC1IRQ  | TC0IRQ  | UAIRQ | SWIRQ | WDIRQ  | FIQ    |

#### • Interrupt Pending

0 = Corresponding interrupt is inactive

1 = Corresponding interrupt is pending

### **AIC Interrupt Mask Register**

| Register Name<br>Access Type:<br>Reset Value: | : AIC_IMF<br>Read-on<br>0 |         |         |       |       |        |        |
|-----------------------------------------------|---------------------------|---------|---------|-------|-------|--------|--------|
| 31                                            | 30                        | 29      | 28      | 27    | 26    | 25     | 24     |
| _                                             | _                         | -       | -       | _     | -     | _      | -      |
| 23                                            | 22                        | 21      | 20      | 19    | 18    | 17     | 16     |
| _                                             | _                         | -       | -       | _     | -     | _      | _      |
| 15                                            | 14                        | 13      | 12      | 11    | 10    | 9      | 8      |
| PIOBIRQ                                       | UBIRQ                     | OAKBIRQ | OAKAIRQ | _     | IRQ0  | SPIIRQ | LCDIRQ |
| 7                                             | 6                         | 5       | 4       | 3     | 2     | 1      | 0      |
| PIOAIRQ                                       | TC2IRQ                    | TC1IRQ  | TC0IRQ  | UAIRQ | SWIRQ | WDIRQ  | FIQ    |

#### Interrupt Mask

0 = Corresponding interrupt is disabled

1 = Corresponding interrupt is enabled

# **AIC Core Interrupt Status Register**

| Register Name<br>Access Type:<br>Reset Value: | : AIC_CIS<br>Read-on<br>0 |    |    |    |    |      |      |
|-----------------------------------------------|---------------------------|----|----|----|----|------|------|
| 31                                            | 30                        | 29 | 28 | 27 | 26 | 25   | 24   |
| -                                             | _                         | _  | _  | -  | -  | _    | _    |
| 23                                            | 22                        | 21 | 20 | 19 | 18 | 17   | 16   |
| -                                             | _                         | _  | _  | -  | -  | _    | _    |
| 15                                            | 14                        | 13 | 12 | 11 | 10 | 9    | 8    |
| -                                             | _                         | _  | -  | -  | -  | -    | _    |
| 7                                             | 6                         | 5  | 4  | 3  | 2  | 1    | 0    |
| _                                             | _                         | -  | -  | _  | -  | NIRQ | NFIQ |

### • NFIQ: NFIQ Status

0 = NFIQ line inactive

1 = NFIQ line active

## • NIRQ: NIRQ Status

0 = NIRQ line inactive

1 = NIRQ line active

# AIC Interrupt Enable Command Register

| Register Name<br>Access Type: | AIC_IEC<br>Write-on |    |    |
|-------------------------------|---------------------|----|----|
| 31                            | 30                  | 29 | 28 |
| -                             | _                   | -  | -  |

| _  | -  | _  | _  | -  | _  | _    | -    |
|----|----|----|----|----|----|------|------|
| 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| -  | -  | -  | -  | -  | -  | -    | -    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    |
| -  | -  |    |    | -  |    |      | -    |
| 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0    |
| -  | -  | _  | _  | -  | _  | NIRQ | NFIQ |

27

26

25

24

## • NFIQ: NFIQ Status

0 = NFIQ line inactive

1 = NFIQ line active

## • NIRQ: NIRQ Status

0 = NIRQ line inactive

1 = NIRQ line active





# **AIC Interrupt Disable Command Register**

| Register Name<br>Access Type: | e: AIC_IDC<br>Write-on |    |    |    |    |      |      |
|-------------------------------|------------------------|----|----|----|----|------|------|
| 31                            | 30                     | 29 | 28 | 27 | 26 | 25   | 24   |
| -                             | -                      | -  | -  | -  | -  | -    | -    |
| 23                            | 22                     | 21 | 20 | 19 | 18 | 17   | 16   |
| -                             | -                      | -  | -  | -  | -  | -    | -    |
| 15                            | 14                     | 13 | 12 | 11 | 10 | 9    | 8    |
| _                             | _                      | -  | -  | -  | _  | _    | _    |
| 7                             | 6                      | 5  | 4  | 3  | 2  | 1    | 0    |
| _                             | _                      | -  | -  | _  | -  | NIRQ | NFIQ |

#### NFIQ: NFIQ Status

0 = NFIQ line inactive

1 = NFIQ line active

## NIRQ: NIRQ Status

0 = NIRQ line inactive

1 = NIRQ line active

# AIC Interrupt Clear Command Register

| <b>Register Name:</b> | AIC_ICCR   |  |
|-----------------------|------------|--|
| Access Type:          | Write-only |  |

| 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24   |
|----|----|----|----|----|----|------|------|
| -  | _  | _  | -  | -  | —  | —    | -    |
| 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
| _  | _  | _  | -  | -  | _  | _    | _    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    |
| -  | -  | -  | -  | -  | -  | -    | -    |
| 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0    |
| _  | _  | _  | _  | _  | _  | NIRQ | NFIQ |

## NFIQ: NFIQ Status

0 = NFIQ line inactive

1 = NFIQ line active

• NIRQ: NIRQ Status

0 = NIRQ line inactive

1 = NIRQ line active

# **AIC Interrupt Set Command Register**

| Register Name<br>Access Type: | e: AIC_ISC<br>Write-on |    |    |    |    |      |      |
|-------------------------------|------------------------|----|----|----|----|------|------|
| 31                            | 30                     | 29 | 28 | 27 | 26 | 25   | 24   |
| _                             | _                      | -  | -  | -  | -  | _    | _    |
| 23                            | 22                     | 21 | 20 | 19 | 18 | 17   | 16   |
| _                             | _                      | -  | -  | -  | -  | _    | _    |
| 15                            | 14                     | 13 | 12 | 11 | 10 | 9    | 8    |
| _                             | _                      | _  | -  | -  | -  | -    | _    |
| 7                             | 6                      | 5  | 4  | 3  | 2  | 1    | 0    |
| -                             | _                      | -  | -  | _  | -  | NIRQ | NFIQ |

### • NFIQ: NFIQ Status

0 = NFIQ line inactive

1 = NFIQ line active

## NIRQ: NIRQ Status

0 = NIRQ line inactive

1 = NIRQ line active

# AIC End of Interrupt Command Register

| Register Name<br>Access Type: | : AIC_EO<br>Write-on |    |    |    |    |    |    |
|-------------------------------|----------------------|----|----|----|----|----|----|
| 31                            | 30                   | 29 | 28 | 27 | 26 | 25 | 24 |
| -                             | -                    | -  | -  | -  | -  | -  | -  |
| 23                            | 22                   | 21 | 20 | 19 | 18 | 17 | 16 |
| -                             | -                    | -  | -  | -  | -  | _  | -  |
| 15                            | 14                   | 13 | 12 | 11 | 10 | 9  | 8  |
| -                             | -                    | -  | -  | -  | -  | _  | -  |
| 7                             | 6                    | 5  | 4  | 3  | 2  | 1  | 0  |
| -                             | _                    | -  | -  | -  | -  | _  | -  |

The End of Interrupt Command Register is used by the interrupt routine to indicate that the interrupt handling is complete. Any value can be written because it is only necessary to make a write to this register location to signal the end of interrupt handling. The value written is taken by the AIC and used as the new interrupt priority level, i.e., if no interrupt was active when the current routine was entered, zero is written. If an interrupt was active and interrupt nesting is enabled, the value written should be the priority and interrupt number of the previous interrupt.





# **PIO: Parallel I/O Controller**

The AT75C310 has 23 programmable I/O lines. Three pins on the AT75C310 are dedicated as general-purpose I/O pins. Other I/O lines are multiplexed with an external signal of a peripheral to optimize the use of available package pins. Refer to Table 13 and Table 14 on page 42. These lines are controlled by two separate and identical PIO controllers, PIO A and PIO B. Each PIO controller also provides an internal interrupt signal to the AIC.

#### **Multiplexed I/O Lines**

Most I/O lines are multiplexed with an I/O signal of a peripheral. After reset, the pin is controlled by the PIO controller and is in input mode.

When a peripheral signal is not used in an application, the corresponding pin can be used as a parallel I/O. Each parallel I/O line is bi-directional, whether the peripheral defines the signal as input or output. Figure 8 shows the multiplexing of the peripheral signals with parallel I/O signals.

If a pin is multiplexed between the PIO controller and a peripheral, the pin is controlled by the registers PIO\_PER (PIO Enable) and PIO\_PDR (PIO Disable). The register PIO\_PSR (PIO Status) indicates whether the pin is controlled by the corresponding peripheral or by the PIO controller.

If a pin is a general-purpose parallel I/O pin (not multiplexed with a peripheral), PIO\_PER and PIO\_PDR have no effect and PIO\_PSR returns 1 for the bits corresponding to these pins.

When the PIO is selected, the peripheral input line is connected to zero.

#### **Output Selection**

The user can enable each individual I/O signal as an output with the registers PIO\_OER (Output Enable) and PIO\_ODR (Output Disable). The output status of the I/O signals can be read in the register PIO\_OSR (Output Status). The direction defined has an effect only if the pin is configured to be controlled by the PIO controller.

#### I/O Levels

Each pin can be configured to be driven high or low. The level is defined in four different ways, according to the following conditions:

- If a pin is controlled by the PIO Controller and is defined as an output (see "Output Selection" above), the level is programmed using the registers PIO\_SODR (Set Output Data) and PIO\_CODR (Clear Output Data). In this case, the programmed value can be read in PIO\_ODSR (Output Data Status).
- 2. If a pin is controlled by the PIO controller and is not defined as an output, the level is determined by the external circuit.
- 3. If a pin is not controlled by the PIO controller, the state of the pin is defined by the peripheral.
- 4. In all cases, the level on the pin can be read in the register PIO\_PDSR (Pin Data Status).

#### Filters

Optional input glitch filtering is available on each pin and is controlled by the registers PIO\_IFER (Input Filter Enable) and PIO\_IFDR (Input Filter Disable). Input glitch filtering can be selected whether the pin is used for its peripheral function or as a parallel I/O line. The register PIO\_IFSR (Input Filter Status) indicates whether or not the filter is activated for each pin.

#### Interrupts

Each parallel I/O can be programmed to generate an interrupt when a level change occurs. This is controlled by the PIO\_IER (Interrupt Enable) and PIO\_IDR (Interrupt Disable) registers which enable/disable the I/O interrupt by setting/clearing the corresponding bit in the PIO\_IMR. When a change in level occurs, the corresponding bit in the PIO\_ISR (Interrupt Status) is set whether the pin is used as a PIO or a peripheral and whether it is defined as input or output. If the corresponding interrupt in PIO\_IMR (Interrupt Mask) is enabled, the PIO interrupt is asserted.

When PIO\_ISR is read, the register is automatically cleared.

#### **User Interface**

Each individual I/O is associated with a bit position in the Parallel I/O User Interface Registers. Each of these registers is 32 bits wide. If a parallel I/O line is not defined, writing to the corresponding bits has no effect. Undefined bits read as zero. Figure 8. Parallel I/O Multiplexed with a Bi-directional Signal PIO\_OSR 1 Pad Output Enable Peripheral Output Enable 0 PIO\_PSR PIO\_ODSR 1 Pad Output Peripheral 0 Pad . Output Pad Input 0 Peripheral Input 1 Ŧ PIO\_PSR PIO\_PDSR Event Detection PIO\_ISR PIO\_IMR PIOIRQ

AT75C310

/\_





| PIO Controller A             |           | Peripheral |                            |                  |             |               |
|------------------------------|-----------|------------|----------------------------|------------------|-------------|---------------|
| Bit<br>Number <sup>(1)</sup> | Port Name | Port Name  | Signal Description         | Signal Direction | Reset State | Pin<br>Number |
| 0                            | PA0       | OAKAIN0    | OakDSPCore A User Input    | Input            | PIO         | 71            |
| 1                            | PA1       | OAKAIN1    | OakDSPCore A User Input    | Input            | PIO         | 72            |
| 2                            | PA2       | OAKAOUT0   | OakDSPCore A User Output   | Output           | PIO         | 73            |
| 3                            | PA3       | OAKAOUT1   | OakDSPCore A User Output   | Output           | PIO         | 74            |
| 4                            | PA4       | OAKBIN0    | OakDSPCore B User Input    | Input            | PIO         | 77            |
| 5                            | PA5       | OAKBIN1    | OakDSPCore B User Input    | Input            | PIO         | 78            |
| 6                            | PA6       | OAKBOUT0   | OakDSPCore B User Output   | Output           | PIO         | 79            |
| 7                            | PA7       | OAKBOUT1   | OakDSPCore B User Output   | Output           | PIO         | 80            |
| 8                            | PA8       | TCLK0      | Timer 0 External Clock     | Input            | PIO         | 82            |
| 9                            | PA9       | TIOA0      | Timer 0 Signal A           | Input/Output     | PIO         | 83            |
| 10                           | PA10      | TIOB0      | Timer 0 Signal B           | Input/Output     | PIO         | 85            |
| 11                           | PA11      | SCLKA      | Serial Clock               | Input/Output     | PIO         | 86            |
| 12                           | PA12      | NPCS1      | Optional SPI Chip Select 1 | Output           | PIO         | 88            |

#### Table 13. PIO Controller A Connection Table

Note: 1. Bit number refers to the data bit which corresponds to this signal in each of the User Interface registers.

### Table 14. PIO Controller B Connection Table

| PIO Controller B Peripheral  |           |           |                        |                  |             |               |
|------------------------------|-----------|-----------|------------------------|------------------|-------------|---------------|
| Bit<br>Number <sup>(1)</sup> | Port Name | Port Name | Signal Description     | Signal Direction | Reset State | Pin<br>Number |
| 0                            | PB0       | TCLK1     | Timer 1 External Clock | Input            | PIO         | 55            |
| 1                            | PB1       | TIOA1     | Timer 1 Signal A       | Input/Output     | PIO         | 53            |
| 2                            | PB2       | TIOB1     | Timer 1 Signal B       | Input/Output     | PIO         | 51            |
| 3                            | PB3       | _         | _                      | _                | PIO         | 47            |
| 4                            | PB4       | _         | _                      | _                | PIO         | 44            |
| 5                            | PB5       | NRIA      | Ring Indicator         | Input            | PIO         | 43            |
| 6                            | PB6       | NWDOVF    | Watchdog Overflow      | Output           | PIO         | 42            |
| 7                            | PB7       | NCE1      | Chip Select            | Output           | PIO         | 38            |
| 8                            | PB8       | NCE2      | Chip Select            | Output           | PIO         | 54            |
| 9                            | PB9       | _         | _                      | _                | PIO         | 52            |

Note: 1. Bit number refers to the data bit which corresponds to this signal in each of the User Interface registers.

### **PIO User Interface**

PIO Controller A Base Address: 0xFF00C000 PIO Controller B Base Address: 0xFF010000

| Table 15. P | PIO Controller | Memory Map |
|-------------|----------------|------------|
|-------------|----------------|------------|

| Offset | Register Description          | Register Name | Access     | Reset State |
|--------|-------------------------------|---------------|------------|-------------|
| 0x00   | PIO Enable Register           | PIO_PER       | Write-only | -           |
| 0x04   | PIO Disable Register          | PIO_PDR       | Write-only | -           |
| 0x08   | PIO Status Register           | PIO_PSR       | Read-only  | -           |
| 0x0C   | Reserved                      | -             | _          | -           |
| 0x10   | Output Enable Register        | PIO_OER       | Write-only | -           |
| 0x14   | Output Disable Register       | PIO_ODR       | Write-only | -           |
| 0x18   | Output Status Register        | PIO_OSR       | Read-only  | 0x0         |
| 0x1C   | Reserved                      | _             | _          | -           |
| 0x20   | Input Filter Enable Register  | PIO_IFER      | Write-only | -           |
| 0x24   | Input Filter Disable Register | PIO_IFDR      | Write-only | -           |
| 0x28   | Input Filter Status Register  | PIO_IFSR      | Read-only  | 0x0         |
| 0x2C   | Reserved                      | -             | _          | -           |
| 0x30   | Set Output Data Register      | PIO_SODR      | Write-only | -           |
| 0x34   | Clear Output Data Register    | PIO_CODR      | Write-only | _           |
| 0x38   | Output Data Status Register   | PIO_ODSR      | Read-only  | 0x0         |
| 0x3C   | Pin Data Status Register      | PIO_PDSR      | Read-only  | See Note 1  |
| 0x40   | Interrupt Enable Register     | PIO_IER       | Write-only | -           |
| 0x44   | Interrupt Disable Register    | PIO_IDR       | Write-only | -           |
| 0x48   | Interrupt Mask Register       | PIO_IMR       | Read-only  | -           |
| 0x4C   | Interrupt Status Register     | PIO_ISR       | Read-only  | See Note 2  |

Notes: 1. The reset value of this register depends on the level of the external pins at reset.

2. This register is cleared at reset. However, the first read of the register can give a value not equal to zero if any changes have occurred on any pins between the reset and the read.





# **PIO Enable Register**

| Register Name<br>Access Type: | : PIO_PE<br>Write-on |     |     |     |     |     |     |
|-------------------------------|----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                   | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                  | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                   | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                  | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                   | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                  | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                    | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                   | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to enable individual pins to be controlled by the PIO controller instead of the associated peripheral. When the PIO is enabled, the associated peripheral (if any) is held at logic zero.

1 = Enables the PIO to control the corresponding pin (disables peripheral control of the pin).

0 = No effect.

# **PIO Disable Register**

| Register Name<br>Access Type: | : PIO_PD<br>Write-on |     |     |     |     |     |     |
|-------------------------------|----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                   | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                  | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                   | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                  | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                   | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                  | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                    | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                   | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to disable PIO control of individual pins. When the PIO control is disabled, the normal peripheral function is enabled on the corresponding pin.

1 = Disables PIO control (enables peripheral control) on the corresponding pin.

0 = No effect.

# **PIO Status Register**

| <b>Register Name:</b> | PIO_PSR   |
|-----------------------|-----------|
| Access Type:          | Read-only |

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P31 | P30 | P29 | P28 | P27 | P26 | P25 | P24 |
| 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 |
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   |
| P15 | P14 | P13 | P12 | P11 | P10 | P9  | P8  |
| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| P7  | P6  | P5  | P4  | P3  | P2  | P1  | P0  |

This register indicates which pins are enabled for PIO control. This register is updated when PIO lines are enabled or disabled.

1 = PIO is active on the corresponding line (peripheral is inactive).

0 = PIO is inactive on the corresponding line (peripheral is active).

# **PIO Output Enable Register**

| Register Name<br>Access Type: | : PIO_OE<br>Write-on |     |     |     |     |     |     |
|-------------------------------|----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                   | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                  | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                   | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                  | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                   | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                  | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                    | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                   | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to enable PIO output drivers. If the pin is driven by a peripheral, this has no effect on the pin, but the information is stored. The register is programmed as follows:

1 = Enables the PIO output on the corresponding pin.

0 = No effect.





# **PIO Output Disable Register**

| Register Name:<br>Access Type: | PIO_OD<br>Write-on |     |     |     |     |     |     |
|--------------------------------|--------------------|-----|-----|-----|-----|-----|-----|
| 31                             | 30                 | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                            | P30                | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                             | 22                 | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                            | P22                | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                             | 14                 | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                            | P14                | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                              | 6                  | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                             | P6                 | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to disable PIO output drivers. If the pin is driven by the peripheral, this has no effect on the pin, but the information is stored. The register is programmed as follows:

1 = Disables the PIO output on the corresponding pin.

0 = No effect.

# **PIO Output Status Register**

| Register Name<br>Access Type:<br>Reset Value: | : PIO_OSI<br>Read-on<br>0 |     |     |     |     |     |     |
|-----------------------------------------------|---------------------------|-----|-----|-----|-----|-----|-----|
| 31                                            | 30                        | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                           | P30                       | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                            | 22                        | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                           | P22                       | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                            | 14                        | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                           | P14                       | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                             | 6                         | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                            | P6                        | P5  | P4  | P3  | P2  | P1  | P0  |

This register shows the PIO pin control (output enable) status which is programmed in PIO\_OER and PIO ODR. The defined value is effective only if the pin is controlled by the PIO. The register reads as follows:

1 = The corresponding PIO is output on this line.

0 = The corresponding PIO is input on this line.



# **PIO Input Filter Enable Register**

| Register Name<br>Access Type: | : PIO_IFE<br>Write-on |     |     |     |     |     |     |
|-------------------------------|-----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                    | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                   | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                    | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                   | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                    | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                   | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                     | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                    | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to enable input glitch filters. It affects the pin whether or not the PIO is enabled. The register is programmed as follows:

1 = Enables the glitch filter on the corresponding pin.

0 = No effect.

# **PIO Input Filter Disable Register**

| Register Name<br>Access Type: | : PIO_IFD<br>Write-on |     |     |     |     |     |     |
|-------------------------------|-----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                    | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                   | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                    | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                   | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                    | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                   | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                     | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                    | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to disable input glitch filters. It affects the pin whether or not the PIO is enabled. The register is programmed as follows:

1 = Disables the glitch filter on the corresponding pin.

0 = No effect.





# **PIO Input Filter Status Register**

| Register Name:<br>Access Type:<br>Reset Value: | PIO_IFS<br>Read-on<br>0 |     |     |     |     |     |     |
|------------------------------------------------|-------------------------|-----|-----|-----|-----|-----|-----|
| 31                                             | 30                      | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                            | P30                     | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                             | 22                      | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                            | P22                     | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                             | 14                      | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                            | P14                     | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                              | 6                       | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                             | P6                      | P5  | P4  | P3  | P2  | P1  | P0  |

This register indicates which pins have glitch filters selected. It is updated when PIO outputs are enabled or disabled by writing to PIO\_IFER or PIO\_IFDR.

1 = Filter is selected on the corresponding input (peripheral and PIO).

0 = Filter is not selected on the corresponding input.

# **PIO Set Output Data Register**

| Register Name<br>Access Type: | : PIO_SO<br>Write-on |     |     |     |     |     |     |
|-------------------------------|----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                   | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                  | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                   | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                  | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                   | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                  | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                    | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                   | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to set PIO output data. It affects the pin only if the corresponding PIO output line is enabled and if the pin is controlled by the PIO. Otherwise, the information is stored.

1 = PIO output data on the corresponding pin is set.

0 = No effect.



# **PIO Clear Output Data Register**

| Register Name:<br>Access Type: | PIO_CO<br>Write-on |     |     |     |     |     |     |
|--------------------------------|--------------------|-----|-----|-----|-----|-----|-----|
| 31                             | 30                 | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                            | P30                | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                             | 22                 | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                            | P22                | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                             | 14                 | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                            | P14                | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                              | 6                  | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                             | P6                 | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to clear PIO output data. It affects the pin only if the corresponding PIO output line is enabled and if the pin is controlled by the PIO. Otherwise, the information is stored.

1 = PIO output data on the corresponding pin is cleared.

0 = No effect.

# **PIO Output Data Status Register**

| Register Name<br>Access Type:<br>Reset Value: | :: PIO_OD<br>Read-or<br>0 |     |     |     |     |     |     |
|-----------------------------------------------|---------------------------|-----|-----|-----|-----|-----|-----|
| 31                                            | 30                        | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                           | P30                       | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                            | 22                        | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                           | P22                       | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                            | 14                        | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                           | P14                       | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                             | 6                         | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                            | P6                        | P5  | P4  | P3  | P2  | P1  | P0  |

This register shows the output data status which is programmed in PIO\_SODR or PIO\_CODR. The defined value is effective only if the pin is controlled by the PIO Controller and only if the pin is defined as an output.

1 = The output data for the corresponding line is programmed to 1.

0 = The output data for the corresponding line is programmed to 0.





# **PIO Pin Data Status Register**

| Register Name:<br>Access Type:<br>Reset Value: | PIO_PDSF<br>Read-only<br>Undefined |     |     |     |     |     |     |
|------------------------------------------------|------------------------------------|-----|-----|-----|-----|-----|-----|
| 31                                             | 30                                 | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                            | P30                                | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                             | 22                                 | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                            | P22                                | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                             | 14                                 | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                            | P14                                | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                              | 6                                  | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                             | P6                                 | P5  | P4  | P3  | P2  | P1  | P0  |

This register shows the state of the physical pin of the chip. The pin values are always valid, regardless of whether the pins are enabled as PIO, peripheral, input or output. The register reads as follows:

1 = The corresponding pin is at logic 1.

0 = The corresponding pin is at logic 0.

# **PIO Interrupt Enable Register**

| Register Name:<br>Access Type: | PIO_IEF<br>Write-on |     |     |     |     |     |     |
|--------------------------------|---------------------|-----|-----|-----|-----|-----|-----|
| 31                             | 30                  | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                            | P30                 | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                             | 22                  | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                            | P22                 | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                             | 14                  | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                            | P14                 | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                              | 6                   | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                             | P6                  | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to enable PIO interrupts on the corresponding pin. It has an effect whether PIO is enabled or not.

1 = Enables an interrupt when a change of logic level is detected on the corresponding pin.

0 = No effect.



# **PIO Interrupt Disable Register**

| Register Name<br>Access Type: | : PIO_IDF<br>Write-on |     |     |     |     |     |     |
|-------------------------------|-----------------------|-----|-----|-----|-----|-----|-----|
| 31                            | 30                    | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                           | P30                   | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                            | 22                    | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                           | P22                   | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                            | 14                    | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                           | P14                   | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                             | 6                     | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                            | P6                    | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to disable PIO interrupts on the corresponding pin. It has an effect whether the PIO is enabled or not.

1 = Disables the interrupt on the corresponding pin. Logic level changes are still detected.

0 = No effect.

# **PIO Interrupt Mask Register**

| Register Name<br>Access Type:<br>Reset Value: | : PIO_IMI<br>Read-or<br>0 |     |     |     |     |     |     |
|-----------------------------------------------|---------------------------|-----|-----|-----|-----|-----|-----|
| 31                                            | 30                        | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                           | P30                       | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                            | 22                        | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                           | P22                       | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                            | 14                        | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                           | P14                       | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                             | 6                         | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                            | P6                        | P5  | P4  | P3  | P2  | P1  | P0  |

This register shows which pins have interrupts enabled. It is updated when interrupts are enabled or disabled by writing to PIO\_IER or PIO\_IDR.

1 = Interrupt is enabled on the corresponding pin.

0 = Interrupt is not enabled on the corresponding pin.





# **PIO Interrupt Status Register**

| Register Name:<br>Access Type:<br>Reset Value: | PIO_ISR<br>Read-only<br>0 |     |     |     |     |     |     |
|------------------------------------------------|---------------------------|-----|-----|-----|-----|-----|-----|
| 31                                             | 30                        | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                            | P30                       | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                             | 22                        | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                            | P22                       | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                             | 14                        | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                            | P14                       | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                              | 6                         | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                             | P6                        | P5  | P4  | P3  | P2  | P1  | P0  |

This register indicates for each pin when a logic value change has been detected (rising or falling edge). This is valid whether the PIO is selected for the pin or not and whether the pin is an input or an output.

The register is reset to zero following a read, and at reset.

1 = At least one input change has been detected on the corresponding pin since the register was last read.

0 = No input change has been detected on the corresponding pin since the register was last read.



# USART: Universal Synchronous/Asynchronous Receiver/Transmitter

The AT75C310 provides two identical, full-duplex, universal synchronous/asynchronous receiver/transmitters as USART A and USART B. These peripherals sit on the APB bus but are also connected to the ASB bus and thus the external memory via the PDC.

The main features are:

- Programmable baud rate generator
- · Parity, framing and overrun error detection

- · Line break generation and detection
- Automatic echo, local loopback and remote loopback channel modes
- Multi-drop mode: address detection and generation
- Interrupt generation
- Two dedicated peripheral data controller channels
- 5-, 6-, 7-, 8- and 9-bit character length
- · Modem control and status lines



53



# **Pin Description**

Each USART channel has the following external signals:

| Table 16. | USART | External | Signals |
|-----------|-------|----------|---------|
|-----------|-------|----------|---------|

| Signal Name | Signal Description                                        | Туре |
|-------------|-----------------------------------------------------------|------|
| SCK         | USART Serial Clock. Can be configured as input or output. | I/O  |
| ТХД         | Transmit Serial Data                                      | 0    |
| RXD         | Receive Serial Data                                       | l    |
| NRTS        | Request to Send                                           | 0    |
| NCTS        | Clear to Send                                             | Ι    |
| NDTR        | Data Terminal Ready                                       | 0    |
| NDSR        | Data Set Ready                                            | I    |
| NDCD        | Data Carrier Detect                                       | I    |
| NRI         | Ring Indicator                                            | I    |

Note: After a hardware reset, the USART pins are deselected by default (see "PIO: Parallel I/O Controller" on page 40). The user must configure the PIO Controller before enabling the transmitter or receiver.

If the user selects one of the internal clocks, SCK can be configured as a PIO.

In addition, USART A signals NDSRA, NDCDA and NRIA are only available via the PIO A pins for the 160-lead PQFP package option.

### **Baud Rate Generator**

The baud rate generator provides the bit period clock (the baud rate clock) to both the receiver and the transmitter.

The baud rate generator can select between external and internal clock sources. The external clock source is SCK. The internal clock sources can be either the master clock ACLK or the master clock divided by 8 (ACLK/8).

Note: In all cases, if an external clock is used, the duration of each of its levels must be longer than the system clock (ACLK) period. The external clock frequency must be at least 2.5 times lower than the system clock.

When the USART is programmed to operate in asynchronous mode (SYNC = 0 in the Mode Register US\_MR), the selected clock is divided by 16 times the value (CD) written in US\_BRGR (Baud Rate Generator Register). If US\_BRGR is set to 0, the baud rate clock is disabled.

| Baud Rate | _ | Selected Clock |
|-----------|---|----------------|
|           | - | 16 x CD        |

When the USART is programmed to operate in synchronous mode (SYNC = 1) and the selected clock is internal (USCLKS[1] = 0 in the Mode Register US\_MR), the baud rate clock is the internal selected clock divided by the value written in US\_BRGR. If US\_BRGR is set to 0, the baud rate clock is disabled.

In synchronous mode with external clock selected (USCLKS[1] = 1), the clock is provided directly by the signal on the SCK pin. No division is active. The value written in US\_BRGR has no effect.

### Table 17. Clock Generator Table

| Required Baud Rate<br>(bps) | CD = 24 x 10 <sup>6</sup> /<br>16 x Baud Rate | Actual CD | Actual Baud Rate (bps) | Error (bps) | % Error |
|-----------------------------|-----------------------------------------------|-----------|------------------------|-------------|---------|
| 9600                        | 156.25                                        | 156       | 9615.4                 | 15.4        | 0.16    |
| 19200                       | 78.125                                        | 78        | 19230.8                | 30.8        | 0.16    |
| 38400                       | 39.06                                         | 39        | 38461.5                | 61.5        | 0.16    |
| 57600                       | 26.04                                         | 26        | 57692.3                | 92.3        | 0.16    |
| 115200                      | 13.02                                         | 13        | 115384.6               | 184.6       | 0.16    |

Notes: 1. CD = clock driver

2. For information on obtaining exact baud rates using the value of CD given above, the selected clock frequency must be 23,961,600 Hz (23.9616 MHz).







## Receiver

### **Asynchronous Receiver**

The USART is configured for asynchronous operation when SYNC = 0 (bit 7 of US\_MR). In asynchronous mode, the USART detects the start of a received character by sampling the RXD signal until it detects a valid start bit. A low level (space) on RXD is interpreted as a valid start bit if it is detected for more than seven cycles of the sampling clock, which is 16 times the baud rate. Hence, a space which is longer than 7/16 of the bit period is detected as a valid start bit. A space which is 7/16 of a bit period or shorter is ignored and the receiver continues to wait for a valid start bit.

When a valid start bit has been detected, the receiver samples the RXD at the theoretical mid-point of each bit. It is assumed that each bit lasts 16 cycles of the sampling clock (1-bit period) so the sampling point is eight cycles (0.5-bit periods) after the start of the bit. The first sampling point is therefore 24 cycles (1.5-bit periods) after the falling edge of the start bit was detected. Each subsequent bit is sampled 16 cycles (1-bit period) after the previous one.

#### Figure 11. Asynchronous Mode: Start Bit Detection



#### Figure 12. Asynchronous Mode: Character Reception





#### **Synchronous Receiver**

When configured for synchronous operation (SYNC = 1), the receiver samples the RXD signal on each rising edge of the baud rate clock. If a low level is detected, it is considered as a start. Data bits, parity bit and stop bit are sampled and the receiver waits for the next start bit. See the example in Figure 13.

#### **Receiver Ready**

When a complete character is received, it is transferred to the US\_RHR and the RXRDY status bit in US\_CSR is set. If US\_RHR has not been read since the last transfer, the OVRE status bit in US\_CSR is set.

### **Parity Error**

Each time a character is received, the receiver calculates the parity of the received data bits in accordance with the field PAR in US\_MR. It then compares the result with the received parity bit. If different, the parity error bit PARE in US\_CSR is set.

#### **Framing Error**

If a character is received with a stop bit at low level and with at least one data bit at high level, a framing error is generated. This sets FRAME in US\_CSR.

counter reaches 0, the TIMEOUT bit in US CSR is set. The

user can restart the wait for a first character with the

Duration = Value  $\times 4 \times Bit$  Period

STTTO (Start Time-out) bit in US\_CR.

Calculation of time-out duration:

#### Time-out

This function allows an idle condition on the RXD line to be detected. The maximum delay for which the USART should wait for a new character to arrive while the RXD line is inactive (high level) is programmed in US\_RTOR (Receiver Time-out). When this register is set to 0, no time-out is detected. Otherwise, the receiver waits for a first character and then initializes a counter which is decremented at each bit period and reloaded at each byte reception. When the

Figure 13. Synchronous Mode: Character Reception



### Transmitter

The transmitter has the same behavior in both synchronous and asynchronous operating modes. Start bit, data bits, parity bit and stop bits are serially shifted, lowest significant bit first, on the falling edge of the serial clock. See the example in Figure 14.

The number of data bits is selected in the CHRL field in US\_MR.

The parity bit is set according to the PAR field in US\_MR.

The number of stop bits is selected in the NBSTOP field in US\_MR.

When a character is written to US\_THR (Transmit Holding), it is transferred to the Shift Register as soon as it is empty. When the transfer occurs, the TXRDY bit in US\_CSR is set until a new character is written to US\_THR. If the Transmit Shift Register and US\_THR are both empty, the TXEMPTY bit in US\_CSR is set.

#### **Time-guard**

The time-guard function allows the transmitter to insert an idle state on the TXD line between two characters. The duration of the idle state is programmed in US\_TTGR

(Transmitter Time-guard). When this register is set to zero, no time-guard is generated. Otherwise, the transmitter holds a high level on TXD after each transmitted byte during the number of bit periods programmed in US\_TTGR.

| Idle state duration<br>between two characters | = | Time-guard<br>value | х | Bit<br>period |
|-----------------------------------------------|---|---------------------|---|---------------|
|                                               |   |                     |   |               |

#### Multi-drop Mode

When the field PAR in US\_MR equals 11X (binary value), the USART is configured to run in multi-drop mode. In this case, the parity error bit PARE in US\_CSR is set when data is detected with a parity bit set to identify an address byte. PARE is cleared with the Reset Status Bits Command (RSTSTA) in US\_CR. If the parity bit is detected low identifying a data byte, PARE is not set.

The transmitter sends an address byte (parity bit set) when a Send Address Command (SENDA) is written to US\_CR. In this case, the next byte written to US\_THR will be transmitted as an address. After this, any byte transmitted will have the parity bit cleared.

Figure 14. Synchronous and Asynchronous Modes: Character Transmission

Example: 8-bit, parity enabled 1 stop

**Baud Rate** Clock TXD Start D0 D1 D2 D3 D4 D5 D6 D7 Parity Stop Bit Bit Bit





# Break

A break condition is a low signal level which has a duration of at least one character (including start/stop bits and parity).

### **Transmit Break**

The transmitter generates a break condition on the TXD line when STTBRK is set in US\_CR (Control Register). In this case, the character present in the Transmit Shift Register is completed before the line is held low.

To cancel a break condition on the TXD line, the STPBRK command in US\_CR must be set. The USART completes a minimum break duration of one character length. The TXD line then returns to high level (idle state) for at least 12 bit periods to ensure that the end of break is correctly detected. Then the transmitter resumes normal operation.

The BREAK is managed like a character:

- The STTBRK and the STPBRK commands are performed only if the transmitter is ready (bit TXRDY = 1 in US\_CSR).
- The STTBRK command blocks the transmitter holding register (bit TXRDY is cleared in US\_CSR) until the break has started.
- A break is started when the Shift Register is empty (any previous character is fully transmitted). US\_CSR.TXEMPTY is cleared. The break blocks the transmitter shift register until it is completed (high level for at least 12 bit periods after the STPBRK command is requested).

In order to avoid unpredictable states:

- STTBRK and STPBRK commands must not be requested at the same time.
- Once an STTBRK command is requested, further STTBRK commands are ignored until the BREAK is ended (high level for at least 12 bit periods).
- All STPBRK commands requested without a previous STTBRK command are ignored.
- A byte written into the Transmit Holding Register while a break is pending but not started (bit TXRDY = 0 in US\_CSR) is ignored.
- It is not permitted to write new data in the Transmit Holding Register while a break is in progress (STPBRK has not been requested), even though TXRDY = 1 in US\_CSR.
- A new STTBRK command *must not* be issued until an existing break has ended (TXEMPTY = 1 in US\_CSR).

The standard break transmission sequence is:

- 1. Wait for the transmitter ready (US\_CSR.TXRDY = 1).
- 2. Send the STTBRK command (write 0x0200 to US\_CR).

- 3. Wait for the transmitter ready (bit TXRDY = 1 in US\_CSR).
- 4. Send the STPBRK command (write 0x0400 to US\_CR).

The next byte can then be sent:

- 5. Wait for the transmitter ready (bit TXRDY = 1 in US\_CSR).
- 6. Send the next byte (write byte to US THR).

Each of these steps can be scheduled by using the interrupt if the bit TXRDY in US\_IMR is set.

For character transmission, the USART channel must be enabled before sending a break.

### **Receive Break**

The receiver detects a break condition when all data, parity and stop bits are low. When the low stop bit is detected, the receiver asserts the RXBRK bit in US\_CSR. An end-ofreceive break is detected by a high level for at least 2/16 of a bit period in asynchronous operating mode or at least one sample in synchronous operating mode. RXBRK is also asserted when an end-of-break is detected.

Both the beginning and the end of a break can be detected by interrupt if the bit RXBRK in register US\_IMR is set.

## **Peripheral Data Controller**

Each USART channel is closely connected to a corresponding peripheral data controller channel. One is dedicated to the receiver. The other is dedicated to the transmitter.

Note: The PDC is disabled if 9-bit character length is selected (MODE9 = 1) in US\_MR.

The PDC channel is programmed using US\_TPR (Transmit Pointer) and US\_TCR (Transmit Counter) for the transmitter and US\_RPR (Receive Pointer) and US\_RCR (Receive Counter) for the receiver. The status of the PDC is given in US\_CSR by the ENDTX bit for the transmitter and by the ENDRX bit for the receiver.

The pointer registers (US\_TPR and US\_RPR) are used to store the address of the transmit or receive buffers. The counter registers (US\_TCR and US\_RCR) are used to store the size of these buffers.

The receiver data transfer is triggered by the RXRDY bit and the transmitter data transfer is triggered by TXRDY. When a transfer is performed, the counter is decremented and the pointer is incremented. When the counter reaches 0, the status bit is set (ENDRX for the receiver, ENDTX for the transmitter in US\_CSR) and can be programmed to generate an interrupt. Transfers are then disabled until a new non-zero counter value is programmed.

### **Interrupt Generation**

Each status bit in US\_CSR has a corresponding bit in US\_IER (Interrupt Enable) and US\_IDR (Interrupt Disable) which controls the generation of interrupts by asserting the USART interrupt line connected to the AIC. US\_IMR (Interrupt Mask Register) indicates the status of the corresponding bits.

When a bit is set in US\_CSR and the same bit is set in US\_IMR, the interrupt line is asserted.

### **Channel Modes**

The USART can be programmed to operate in three different test modes, using the field CHMODE in US\_MR.

Automatic echo mode allows bit-by-bit re-transmission. When a bit is received on the RXD line, it is sent to the TXD line. Programming the transmitter has no effect.

Local loopback mode allows the transmitted characters to be received. TXD and RXD pins are not used and the output of the transmitter is internally connected to the input of the receiver. The RXD pin level has no effect and the TXD pin is held high as in idle state.

Remote loopback mode directly connects the RXD pin to the TXD pin. The transmitter and the receiver are disabled and have no effect. This mode allows bit-by-bit re-transmission.

#### Figure 15. Channel Modes





# **Modem Control and Status Signals**

#### NCTS: Clear to Send

When low, this indicates that the modem or data set is ready to exchange data. The NCTS signal is a modem status input, conditions of which can be tested by the CPU reading bit 4 (CTS) of the Modem Status Register. Bit 4 is the complement of the NCTS signal. Bit 0 (DCTS) of the Modem Status Register indicates whether the NCTS input has changed state since the previous reading of the Modem Status Register. NCTS has no effect on the transmitter.

In FCM mode when the NCTS signal becomes inactive high, the transmission of the current character will be completed and transmission stops.

Note: Whenever the CTS bit of the Modem Status Register changes state, an interrupt is generated if the Modem Status interrupt is enabled.

#### NDCD: Data Carrier Detect

When low, this indicates that the data carrier has been detected by the modem or data set. The NDCD signal is a modem status input, the condition of which can be tested by the CPU reading bit 7 (DCD) of the Modem Status Register. Bit 7 is the complement of the NDCD signal. Bit 3 (DDCD) of the Modem Status Register indicates whether the NDCD input pin has changed since the previous read of the Modem Status Register. NDCD has no effect on the receiver.

Note: Whenever the DCD bit of the Modem Status Register changes state, an interrupt is generated if the Modem Status interrupt is enabled.

#### NDSR: Data Set Ready

When low, this informs the modem or data set the UART is ready to communicate. The NDSR signal is a modem status input, the condition of which can be tested by the CPU reading bit 5 (DSR) of the Modem Status Register. Bit 5 is the complement of the NDSR signal. Bit 1 (DDSR\_ of the Modem Status Register indicates whether the NDSR input has changed state since the previous read of the Modem Status Register.

Note: Whenever the DSSR bit of the Modem Status Register changes state, an interrupt is generated if the Modem Status Interrupt is enabled.

#### NDTR: Data Terminal Ready

When low, this informs the modem or data set that the UART is ready to communicate. The NDTR output signal can be set to active low by programming bit 0 (DTR) of the Modem Control Register to a high level. A Master Reset operation sets this signal to its inactive (high) state. Loop mode operation holds this signal in inactive state.

#### **NRI: Ring Indicator**

When low, this indicates that a telephone ringing signal has been received by the modem or data set. The NRI signal is a modem status input, the condition of which can be tested by the CPU reading bit 6 (RI) of the Modem Status Register. Bit 6 is the complement of the NRI signal. Bit 2 (TERI) of the Modem Status Register indicates whether the NRI input signal has changed from a low to a high state since the previous reading of the Modem Status Register.

Note: Whenever the RI bit of the Modem Status Register changes from a high to a low state, an interrupt is generated if the Modem Status interrupt is enabled.

#### **NRTS: Request to Send**

When low, this informs the modem or data set that the UART is ready to exchange data. The NRTS output signal can be set to active low by programming bit 1 (RTS) of the Modem Control Register. A Master Reset operation sets this signal to its inactive (high) state. In FCM mode when the last stop bit of a character is transmitted and the Transmit Holding Register is empty, then the hardware sets NRTS inactive high.

Note: Modem ctrl pins must be left high when not used.

# **USART User Interface**

| Base Address USART A: | 0xFF018000 |
|-----------------------|------------|
| Base Address USART B: | 0xFF01C000 |

| Offset | Register Description            | Register Name | Access     | Reset State         |
|--------|---------------------------------|---------------|------------|---------------------|
| 0x00   | Control Register                | US_CR         | Write-only | _                   |
| 0x04   | Mode Register                   | US_MR         | Read/write | 0                   |
| 0x08   | Interrupt Enable Register       | US_IER        | Write-only | _                   |
| 0x0C   | Interrupt Disable Register      | US_IDR        | Write-only | -                   |
| 0x10   | Interrupt Mask Register         | US_IMR        | Read-only  | 0                   |
| 0x14   | Channel Status Register         | US_CSR        | Read-only  | 0x18 <sup>(1)</sup> |
| 0x18   | Receiver Holding Register       | US_RHR        | Read-only  | 0                   |
| 0x1C   | Transmitter Holding Register    | US_THR        | Write-only | _                   |
| 0x20   | Baud Rate Generator Register    | US_BRGR       | Read/write | 0                   |
| 0x24   | Receiver Time-out Register      | US_RTOR       | Read/write | 0                   |
| 0x28   | Transmitter Time-guard Register | US_TTGR       | Read/write | 0                   |
| 0x2C   | Reserved                        | _             | -          | _                   |
| 0x30   | Receive Pointer Register        | US_RPR        | Read/write | 0                   |
| 0x34   | Receive Counter Register        | US_RCR        | Read/write | 0                   |
| 0x38   | Transmit Pointer Register       | US_TPR        | Read/write | 0                   |
| 0x3C   | Transmit Counter Register       | US_TCR        | Read/write | 0                   |
| 0x40   | Modem Control Register          | US_MC         | Write-only | _                   |
| 0x44   | Modem Status Register           | US_MS         | Read-only  | (See Note 2)        |

Notes:

This may be 0x18 or 0x418 depending on the value of bootn and modem control inputs.
 This depends on the value of modem control input signals, as these are reflected in this register.





# **USART Control Register**

| Name:<br>Access Type: | US_CR<br>Write-on | ly    |       |       |        |        |        |
|-----------------------|-------------------|-------|-------|-------|--------|--------|--------|
| 31                    | 30                | 29    | 28    | 27    | 26     | 25     | 24     |
| -                     | -                 | -     | -     | -     | -      | -      | -      |
| 23                    | 22                | 21    | 20    | 19    | 18     | 17     | 16     |
| -                     | -                 | -     | -     | -     | -      | -      | -      |
| 15                    | 14                | 13    | 12    | 11    | 10     | 9      | 8      |
| -                     | -                 | -     | SENDA | STTTO | STPBRK | STTBRK | RSTSTA |
| 7                     | 6                 | 5     | 4     | 3     | 2      | 1      | 0      |
| TXDIS                 | TXEN              | RXDIS | RXEN  | RSTTX | RSTRX  | _      | -      |

#### • RSTRX: Reset Receiver

0 = No effect.

1 = The receiver logic is reset.

### • RSTTX: Reset Transmitter

0 = No effect.

1 = The transmitter logic is reset.

### • RXEN: Receiver Enable

0 = No effect.

1 = The receiver is enabled if RXDIS is 0.

#### RXDIS: Receiver Disable

0 = No effect.

1 = The receiver is disabled.

#### • TXEN: Transmitter Enable

0 = No effect.

1 = The transmitter is enabled if TXDIS is 0.

### • TXDIS: Transmitter Disable

- 0 = No effect.
- 1 = The transmitter is disabled.

#### • RSTSTA: Reset Status Bits

0 = No effect.

1 = Resets the status bits PARE, FRAME, OVRE and RXBRK in the US\_CSR.

#### • STTBRK: Start Break

0 = No effect.

1 = If break is not being transmitted, starts transmission of a break after the characters present in US\_THR and the Transmit Shift Register have been transmitted.

#### • STPBRK: Stop Break

0 = No effect.

1 = If a break is being transmitted, stops transmission of the break after a minimum of one character length and transmits a high level during 12 bit periods.

### • STTTO: Start Time-out

0 = No effect.

1 = Starts waiting for a character before clocking the time-out counter.

#### • SENDA: Send Address

0 = No effect.

1 = In multi-drop mode only, the next character written to the US\_THR is sent with the address bit set.

# **USART Mode Register**

| Name:<br>Access Type: | US_MR<br>Read/write | е  |       |    |      |       |      |
|-----------------------|---------------------|----|-------|----|------|-------|------|
| 31                    | 30                  | 29 | 28    | 27 | 26   | 25    | 24   |
| -                     | _                   | _  | -     | -  | _    | -     | -    |
| 23                    | 22                  | 21 | 20    | 19 | 18   | 17    | 16   |
| _                     | -                   | _  | -     | _  | CLKO | MODE9 | _    |
| 15                    | 14                  | 13 | 12    | 11 | 10   | 9     | 8    |
| CHM                   | ODE                 | NB | STOP  |    | PAR  |       | SYNC |
| 7                     | 6                   | 5  | 4     | 3  | 2    | 1     | 0    |
| СН                    | RL                  | US | SCLKS | -  |      |       | _    |

• USCLKS: Clock Selection (Baud Rate Generator Input Clock)

| USCLKS |   | Selected Clock |
|--------|---|----------------|
| 0      | 0 | ACLK           |
| 0      | 1 | ACLK/8         |
| 1      | х | External (SCK) |

#### • CHRL: Character Length

| CHRL |   | Character Length |
|------|---|------------------|
| 0    | 0 | Five bits        |
| 0    | 1 | Six bits         |
| 1    | 0 | Seven bits       |
| 1    | 1 | Eight bits       |

Start, stop and parity bits are added to the character length.

• SYNC: Synchronous Mode Select

0 = USART operates in asynchronous mode.

1 = USART operates in synchronous mode.

• PAR: Parity Type

|   | PAR |   | Parity Type                |
|---|-----|---|----------------------------|
| 0 | 0   | 0 | Even parity                |
| 0 | 0   | 1 | Odd parity                 |
| 0 | 1   | 0 | Parity forced to 0 (space) |
| 0 | 1   | 1 | Parity forced to 1 (mark)  |
| 1 | 0   | х | No parity                  |
| 1 | 1   | x | Multi-drop mode            |





### • NBSTOP: Number of Stop Bits

The interpretation of the number of stop bits depends on SYNC.

| NBS | тор | Asynchronous<br>(SYNC = 0) | Synchronous<br>(SYNC = 1) |
|-----|-----|----------------------------|---------------------------|
| 0   | 0   | 1 stop bit                 | 1 stop bit                |
| 0   | 1   | 1.5 stop bits              | Reserved                  |
| 1   | 0   | 2 stop bits                | 2 stop bits               |
| 1   | 1   | Reserved                   | Reserved                  |

#### • CHMODE: Channel Mode

| CHM | IODE | Mode Description                                                                   |
|-----|------|------------------------------------------------------------------------------------|
| 0   | 0    | Normal Mode<br>The USART Channel operates as an Rx/Tx USART.                       |
| 0   | 1    | Automatic Echo<br>Receiver Data Input is connected to TXD pin.                     |
| 1   | 0    | Local Loopback<br>Transmitter Output Signal is connected to Receiver Input Signal. |
| 1   | 1    | Remote Loopback<br>RXD pin is internally connected to TXD pin.                     |

### • MODE9: 9-bit Character Length

0 = CHRL defines character length.

1 = 9-bit character length.

### CKLO: Clock Output Select

0 = The USART does not drive the SCK pin.

1 = The USART drives the SCK pin if USCLKS[1] is 0.

# **USART Interrupt Enable Register**

| Name:<br>Access Type: | US_IER | US_IER<br>Write-only |       |       |       |         |         |  |  |  |
|-----------------------|--------|----------------------|-------|-------|-------|---------|---------|--|--|--|
| 31                    | 30     | 29                   | 28    | 27    | 26    | 25      | 24      |  |  |  |
| -                     | -      | _                    | -     | -     | -     | -       | -       |  |  |  |
| 23                    | 22     | 21                   | 20    | 19    | 18    | 17      | 16      |  |  |  |
| -                     | -      | -                    | -     | -     | -     | -       | -       |  |  |  |
| 15                    | 14     | 13                   | 12    | 11    | 10    | 9       | 8       |  |  |  |
| -                     | _      | -                    | -     | -     | DMSI  | TXEMPTY | TIMEOUT |  |  |  |
| 7                     | 6      | 5                    | 4     | 3     | 2     | 1       | 0       |  |  |  |
| PARE                  | FRAME  | OVRE                 | ENDTX | ENDRX | RXBRK | TXRDY   | RXRDY   |  |  |  |

### • RXRDY: Enable RXRDY Interrupt

- 0 = No effect.
- 1 = Enables RXRDY Interrupt.

## • TXRDY: Enable TXRDY Interrupt

- 0 = No effect.
- 1 = Enables TXRDY Interrupt.

## RXBRK: Enable Receiver Break Interrupt

- 0 = No effect.
- 1 = Enables Receiver Break Interrupt.

# ENDRX: Enable End of Receive Transfer Interrupt

- 0 = No effect.
- 1 = Enables End of Receive Transfer Interrupt.

## • ENDTX: Enable End of Transmit Transfer Interrupt

- 0 = No effect.
- 1 = Enables End of Transmit Transfer Interrupt.

### OVRE: Enable Overrun Error Interrupt

- 0 = No effect.
- 1 = Enables Overrun Error Interrupt.

## FRAME: Enable Framing Error Interrupt

0 = No effect.

1 = Enables Framing Error Interrupt.

• PARE: Enable Parity Error Interrupt

0 = No effect.

1 = Enables Parity Error Interrupt.

- TIMEOUT: Enable Time-out Interrupt
  - 0 = No effect.
  - 1 = Enables Reception Time-out Interrupt.
- TXEMPTY: Enable TXEMPTY Interrupt
  - 0 = No effect.
  - 1 = Enables TXEMPTY Interrupt.
- DMSI: Delta Modem Status Indication Interrupt
  - 0 = No effect.
  - 1 = Enables DMSI Interrupt.





# **USART Interrupt Disable Register**

| Name:<br>Access Type: | US_IDR<br>Write-on |      |       |       |       |         |         |
|-----------------------|--------------------|------|-------|-------|-------|---------|---------|
| 31                    | 30                 | 29   | 28    | 27    | 26    | 25      | 24      |
| _                     | _                  | _    | _     | -     | _     | _       | -       |
| 23                    | 22                 | 21   | 20    | 19    | 18    | 17      | 16      |
| -                     | -                  | -    | -     | -     | -     | -       | -       |
| 15                    | 14                 | 13   | 12    | 11    | 10    | 9       | 8       |
| -                     | -                  | -    | _     | -     | DMSI  | TXEMPTY | TIMEOUT |
| 7                     | 6                  | 5    | 4     | 3     | 2     | 1       | 0       |
| PARE                  | FRAME              | OVRE | ENDTX | ENDRX | RXBRK | TXRDY   | RXRDY   |

### • RXRDY: Disable RXRDY Interrupt

- 0 = No effect.
- 1 = Disables RXRDY Interrupt.

### • TXRDY: Disable TXRDY Interrupt

- 0 = No effect.
- 1 = Disables TXRDY Interrupt.

### • RXBRK: Disable Receiver Break Interrupt

- 0 = No effect.
- 1 = Disables Receiver Break Interrupt.

# ENDRX: Disable End of Receive Transfer Interrupt

- 0 = No effect.
- 1 = Disables End of Receive Transfer Interrupt.

### • ENDTX: Disable End of Transmit Transfer Interrupt

- 0 = No effect.
- 1 = Disables End of Transmit Transfer Interrupt.

### • OVRE: Disable Overrun Error Interrupt

- 0 = No effect.
- 1 = Disables Overrun Error Interrupt.

### • FRAME: Disable Framing Error Interrupt

0 = No effect.

1 = Disables Framing Error Interrupt.

PARE: Disable Parity Error Interrupt

0 = No effect.

1 = Disables Parity Error Interrupt.

- TIMEOUT: Disable Time-out Interrupt
  - 0 = No effect.
  - 1 = Disables Receiver Time-out Interrupt.
- TXEMPTY: Disable TXEMPTY Interrupt
  - 0 = No effect.
  - 1 = Disables TXEMPTY Interrupt.
- DMSI: Delta Modem Status Indication Interrupt
  - 0 = No effect.
  - 1 = Disables DMSI Interrupt.

# **USART Interrupt Mask Register**

| Name:<br>Access Type: | US_IMR<br>Read-on |      |       |       |       |         |         |
|-----------------------|-------------------|------|-------|-------|-------|---------|---------|
| 31                    | 30                | 29   | 28    | 27    | 26    | 25      | 24      |
| -                     | _                 | -    | -     | -     | -     | -       | -       |
| 23                    | 22                | 21   | 20    | 19    | 18    | 17      | 16      |
| -                     | _                 | -    | -     | -     | -     | -       | -       |
| 15                    | 14                | 13   | 12    | 11    | 10    | 9       | 8       |
| _                     | _                 | -    | -     | _     | DMSI  | TXEMPTY | TIMEOUT |
| 7                     | 6                 | 5    | 4     | 3     | 2     | 1       | 0       |
| PARE                  | FRAME             | OVRE | ENDTX | ENDRX | RXBRK | TXRDY   | RXRDY   |

### • RXRDY: RXRDY Interrupt Mask

- 0 = RXRDY Interrupt is disabled.
- 1 = RXRDY Interrupt is enabled.
- TXRDY: TXRDY Interrupt Mask
  - 0 = TXRDY Interrupt is disabled.
  - 1 = TXRDY Interrupt is enabled.
- RXBRK: Receiver Break Interrupt Mask
  - 0 = Receiver Break Interrupt is disabled.
  - 1 = Receiver Break Interrupt is enabled.
- ENDRX: End of Receive Transfer Interrupt Mask
   0 = End of Receive Transfer Interrupt is disabled.
   1 = End of Receive Transfer Interrupt is enabled.
- ENDTX: End of Transmit Transfer Interrupt Mask
   0 = End of Transmit Transfer Interrupt is disabled.
   1 = End of Transmit Transfer Interrupt is enabled.
- OVRE: Overrun Error Interrupt Mask 0 = Overrun Error Interrupt is disabled.
  - 1 = Overrun Error Interrupt is enabled.
  - T = Overrun Error Interrupt is enabled.
- FRAME: Framing Error Interrupt Mask
   0 = Framing Error Interrupt is disabled.
   1 = Framing Error Interrupt is enabled.
- **PARE: Parity Error Interrupt Mask** 0 = Parity Error Interrupt is disabled.
  - 1 = Parity Error Interrupt is enabled.
- TIMEOUT: Time-out Interrupt Mask
  - 0 = Receive Time-out Interrupt is disabled.
  - 1 = Receive Time-out Interrupt is enabled.
- TXEMPTY: TXEMPTY Interrupt Mask
  - 0 = TXEMPTY Interrupt is disabled.
  - 1 = TXEMPTY Interrupt is enabled.
- DMSI: Delta Modem Status Indication Interrupt
  - 0 = DMSI Interrupt is disabled.
  - 1 = DMSI Interrupt is enabled.





# **USART Channel Status Register**

| Name:<br>Access Type: | US_CSF<br>Read-on |      |       |       |       |         |         |
|-----------------------|-------------------|------|-------|-------|-------|---------|---------|
| 31                    | 30                | 29   | 28    | 27    | 26    | 25      | 24      |
| _                     | _                 | _    | -     | -     | _     | _       | _       |
| 23                    | 22                | 21   | 20    | 19    | 18    | 17      | 16      |
| _                     | _                 | _    | -     | -     | _     | _       | _       |
| 15                    | 14                | 13   | 12    | 11    | 10    | 9       | 8       |
| _                     | _                 | _    | -     | -     | DMSI  | TXEMPTY | TIMEOUT |
| 7                     | 6                 | 5    | 4     | 3     | 2     | 1       | 0       |
| PARE                  | FRAME             | OVRE | ENDTX | ENDRX | RXBRK | TXRDY   | RXRDY   |

### • RXRDY: Receiver Ready

0 = No complete character has been received since the last read of the US\_RHR or the receiver is disabled.

1 = At least one complete character has been received and the US\_RHR has not yet been read.

### • TXRDY: Transmitter Ready

0 = US\_THR contains a character waiting to be transferred to the Transmit Shift Register.

1 = US\_THR is empty and there is no break request pending TSR availability.

Equal to zero when the USART is disabled or at reset. Transmitter Enable command (in US\_CR) sets this bit to one.

### RXBRK: Break Received/End of Break

0 = No Break Received nor End of Break detected since the last "Reset Status Bits" command in the Control Register.1 = Break Received or End of Break detected since the last "Reset Status Bits" command in the Control Register.

### • ENDRX: End of Receive Transfer

0 = The End of Transfer signal from the Peripheral Data Controller channel dedicated to the receiver is inactive.

1 = The End of Transfer signal from the Peripheral Data Controller channel dedicated to the receiver is active.

### ENDTX: End of Transmit Transfer

0 = The End of Transfer signal from the Peripheral Data Controller channel dedicated to the transmitter is inactive.

1 = The End of Transfer signal from the Peripheral Data Controller channel dedicated to the transmitter is active.

#### • OVRE: Overrun Error

0 = No byte has been transferred from the Receive Shift Register to the US\_RHR when RxRDY was asserted since the last "Reset Status Bits" command.

1 = At least one byte has been transferred from the Receive Shift Register to the US\_RHR when RxRDY was asserted since the last "Reset Status Bits" command.

#### • FRAME: Framing Error

0 = No stop bit has been detected low since the last "Reset Status Bits" command.

1 = At least one stop bit has been detected low since the last "Reset Status Bits" command.

#### PARE: Parity Error

1 = At least one parity bit has been detected false (or a parity bit high in multi-drop mode) since the last "Reset Status Bits" command.

0 = No parity bit has been detected false (or a parity bit high in multi-drop mode) since the last "Reset Status Bits" command.

#### • TIMEOUT: Receiver Time-out

0 = There has not been a time-out since the last "Start Time-out" command or the Time-out Register is 0.

1 = There has been a time-out since the last "Start Time-out" command.



### • TXEMPTY: Transmitter Empty

0 = There are characters in either US\_THR or the Transmit Shift Register or a break is being transmitted.

1 = There are no characters in US\_THR and the Transmit Shift Register and break is not active.

Equal to zero when the USART is disabled or at reset. Transmitter Enable command (in US\_CR) sets this bit to one.

### DMSI: Delta Modem Status Indication Interrupt

0 = No effect.

1 = There has been a change in the modem status delta bits since the last "Reset Status Bits" command.





# **USART Receiver Holding Register**

| Name:<br>Access Type: | US_RHF<br>Read-on |    |    |    |    |    |       |
|-----------------------|-------------------|----|----|----|----|----|-------|
| 31                    | 30                | 29 | 28 | 27 | 26 | 25 | 24    |
| -                     | _                 | _  | -  | -  | _  | _  | -     |
| 23                    | 22                | 21 | 20 | 19 | 18 | 17 | 16    |
| -                     | _                 | _  | -  | -  | _  | _  | -     |
| 15                    | 14                | 13 | 12 | 11 | 10 | 9  | 8     |
| -                     | _                 | _  | -  | -  | _  | _  | RXCHR |
| 7                     | 6                 | 5  | 4  | 3  | 2  | 1  | 0     |
|                       | RXCHR             |    |    |    |    |    |       |

### • RXCHR: Received Character

Last character received if RXRDY is set. When number of data bits is less than eight, the bits are right-aligned. All unused bits read as zero.

# **USART Transmitter Holding Register**

| Name:<br>Access Type: | US_THF<br>Write-on |    |    |     |    |    |       |
|-----------------------|--------------------|----|----|-----|----|----|-------|
| 31                    | 30                 | 29 | 28 | 27  | 26 | 25 | 24    |
| -                     | _                  | -  | -  | -   | -  | -  | -     |
| 23                    | 22                 | 21 | 20 | 19  | 18 | 17 | 16    |
| -                     | _                  | _  | _  | _   | _  | _  | -     |
| 15                    | 14                 | 13 | 12 | 11  | 10 | 9  | 8     |
| -                     | _                  | _  | _  | _   | _  | _  | TXCHR |
| 7                     | 6                  | 5  | 4  | 3   | 2  | 1  | 0     |
|                       |                    |    | TX | CHR |    |    |       |

#### • TXCHR: Character to be Transmitted

Next character to be transmitted after the current character if TXRDY is not set. When number of data bits is less than eight, the bits are right-aligned.

# **USART Baud Rate Generator Register**

| Name:<br>Access Type: | US_BRG<br>Read/wri |    |    |    |    |    |    |
|-----------------------|--------------------|----|----|----|----|----|----|
| 31                    | 30                 | 29 | 28 | 27 | 26 | 25 | 24 |
| _                     | _                  | _  | -  | -  | -  | _  | -  |
| 23                    | 22                 | 21 | 20 | 19 | 18 | 17 | 16 |
| -                     | _                  | _  | _  | -  | _  | _  | -  |
| 15                    | 14                 | 13 | 12 | 11 | 10 | 9  | 8  |
|                       |                    |    | C  | D  |    |    |    |
| 7                     | 6                  | 5  | 4  | 3  | 2  | 1  | 0  |
|                       |                    |    | C  | D  |    |    |    |

### • CD: Clock Divisor

This register has no effect if synchronous mode is selected with an external clock.

| CD         | Effect                                                                                                      |  |  |  |
|------------|-------------------------------------------------------------------------------------------------------------|--|--|--|
| 0          | Disables clock                                                                                              |  |  |  |
| 1          | Clock Divisor bypass                                                                                        |  |  |  |
| 2 to 65535 | Baud Rate (asynchronous mode) = Selected clock/ 16 x CD<br>Baud Rate (synchronous mode) = Selected clock/CD |  |  |  |

Note: In synchronous mode, the value programmed must be even to ensure a 50:50 mark-to-space ratio.

Note: Clock divisor bypass (CD = 1) must not be used when internal clock ACLK is selected (USCLKS = 0).





# **USART Receiver Time-out Register**

| Name:<br>Access Type: | US_RTC<br>Read/wr |    |    |    |    |    |    |
|-----------------------|-------------------|----|----|----|----|----|----|
| 31                    | 30                | 29 | 28 | 27 | 26 | 25 | 24 |
| _                     | _                 | _  | -  | -  | -  | _  | -  |
| 23                    | 22                | 21 | 20 | 19 | 18 | 17 | 16 |
| -                     | _                 | _  | -  | -  | -  | _  | -  |
| 15                    | 14                | 13 | 12 | 11 | 10 | 9  | 8  |
| _                     | _                 | _  | -  | -  | -  | _  | _  |
| 7                     | 6                 | 5  | 4  | 3  | 2  | 1  | 0  |
|                       | ТО                |    |    |    |    |    |    |

### • TO: Time-out Value

When a value is written to this register, a Start Time-out command is automatically performed.

| то      | Effect                                                                                                                                                              |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Disables the RX Time-out function.                                                                                                                                  |
| 1 - 255 | The Time-out counter is loaded with TO when<br>the Start Time-out command is given or when<br>each new data character is received (after<br>reception has started). |

Time-out duration = TO x 4 x Bit period

# **USART Transmitter Time-guard Register**

| Name:<br>Access Type: | US_TTG<br>Read/wr |    |    |    |    |    |    |
|-----------------------|-------------------|----|----|----|----|----|----|
| 31                    | 30                | 29 | 28 | 27 | 26 | 25 | 24 |
| _                     | _                 | _  | -  | -  | _  | _  | -  |
| 23                    | 22                | 21 | 20 | 19 | 18 | 17 | 16 |
| -                     | _                 | _  | -  | -  | _  | _  | -  |
| 15                    | 14                | 13 | 12 | 11 | 10 | 9  | 8  |
| _                     | _                 | _  | -  | -  | _  | _  | -  |
| 7                     | 6                 | 5  | 4  | 3  | 2  | 1  | 0  |
|                       |                   |    | -  | TG |    |    |    |

## • TG: Time-guard Value

| TG      |                                                                                            |
|---------|--------------------------------------------------------------------------------------------|
| 0       | Disables the TX Time-guard function.                                                       |
| 1 - 255 | TXD is inactive high after the transmission of each character for the time-guard duration. |

Time-guard duration = TG x Bit period

# **USART Receive Pointer Register**

| Name:<br>Access Type: | US_RPR<br>Read/write |    |     |     |    |    |    |
|-----------------------|----------------------|----|-----|-----|----|----|----|
| 31                    | 30                   | 29 | 28  | 27  | 26 | 25 | 24 |
|                       |                      |    | RXF | ۲R  |    |    |    |
| 23                    | 22                   | 21 | 20  | 19  | 18 | 17 | 16 |
|                       |                      |    | RXF | 'TR |    |    |    |
| 15                    | 14                   | 13 | 12  | 11  | 10 | 9  | 8  |
|                       |                      |    | RXF | TR  |    |    |    |
| 7                     | 6                    | 5  | 4   | 3   | 2  | 1  | 0  |
|                       |                      |    | RXP | TR  |    |    |    |

## • RXPTR: Receive Pointer

RXPTR must be loaded with the address of the receive buffer.





# **USART Receive Counter Register**

| Name:<br>Access Type: | US_RCF<br>Read/wri |    |    |     |    |    |    |
|-----------------------|--------------------|----|----|-----|----|----|----|
| 31                    | 30                 | 29 | 28 | 27  | 26 | 25 | 24 |
| -                     | -                  | _  | -  | -   | -  | _  | -  |
| 23                    | 22                 | 21 | 20 | 19  | 18 | 17 | 16 |
| _                     | -                  | _  | -  | -   | -  | _  | -  |
| 15                    | 14                 | 13 | 12 | 11  | 10 | 9  | 8  |
|                       |                    |    | Rک | CTR |    |    |    |
| 7                     | 6                  | 5  | 4  | 3   | 2  | 1  | 0  |
|                       |                    |    | R> | CTR |    |    |    |

### • RXCTR: Receive Counter

RXCTR must be loaded with the size of the receive buffer.

- 0: Stop peripheral data transfer dedicated to the receiver.
- 1 65535: Start peripheral data transfer if RXRDY is active.

# **USART Transmit Pointer Register**

| Name:<br>Access Type: | US_TPR<br>Read/write | C  |     |     |    |    |    |
|-----------------------|----------------------|----|-----|-----|----|----|----|
| 31                    | 30                   | 29 | 28  | 27  | 26 | 25 | 24 |
|                       |                      |    | TXF | Ϋ́R |    |    |    |
| 23                    | 22                   | 21 | 20  | 19  | 18 | 17 | 16 |
|                       |                      |    | TXF | Ϋ́R |    |    |    |
| 15                    | 14                   | 13 | 12  | 11  | 10 | 9  | 8  |
|                       |                      |    | TXF | Ϋ́R |    |    |    |
| 7                     | 6                    | 5  | 4   | 3   | 2  | 1  | 0  |
|                       |                      |    | TXF | ΫΤR |    |    |    |

### • TXPTR: Transmit Pointer

TXPTR must be loaded with the address of the transmit buffer.

# **USART Transmit Counter Register**

| Name:<br>Access Type: | US_TCF<br>Read/wr |    |    |     |    |    |    |
|-----------------------|-------------------|----|----|-----|----|----|----|
| 31                    | 30                | 29 | 28 | 27  | 26 | 25 | 24 |
| -                     | _                 | _  | -  | -   | -  | _  | -  |
| 23                    | 22                | 21 | 20 | 19  | 18 | 17 | 16 |
| -                     | _                 | -  | -  | -   | -  | _  | -  |
| 15                    | 14                | 13 | 12 | 11  | 10 | 9  | 8  |
|                       |                   |    | тх | CTR |    |    |    |
| 7                     | 6                 | 5  | 4  | 3   | 2  | 1  | 0  |
|                       |                   |    | ТХ | CTR |    |    |    |

### • TXCTR: Transmit Counter

TXCTR must be loaded with the size of the transmit buffer.

0: Stop peripheral data transfer dedicated to the transmitter.

1 - 65535: Start peripheral data transfer if TXRDY is active.





# **Modem Control Register**

Degister Name

| Register Name | : US_IVIC |     |    |    |    |     |     |
|---------------|-----------|-----|----|----|----|-----|-----|
| 31            | 30        | 29  | 28 | 27 | 26 | 25  | 24  |
| -             | _         | _   | _  | _  | -  | _   | -   |
| 23            | 22        | 21  | 20 | 19 | 18 | 17  | 16  |
| -             | -         | -   | -  | -  | _  | _   | -   |
| 15            | 14        | 13  | 12 | 11 | 10 | 9   | 8   |
| -             | _         | _   | _  | _  | -  | _   | -   |
| 7             | 6         | 5   | 4  | 3  | 2  | 1   | 0   |
| -             | _         | FCM | _  | -  | _  | RTS | DTR |

This register controls the interface with the modem or data set (or a peripheral device emulating a modem). The contents of the Control Register are indicated below.

### DTR: Data Terminal Ready

This bit controls the NDTR output. When bit 0 is set to a logic 1, the NDTR output is forced to a logic 0. When bit 0 is reset to a logic 0, the NDTR output is forced to a logic 1.

Note: The NDTR output of the UART can be applied to an EIA inverting line driver to obtain proper polarity input at the succeeding modem or data set.

### RTS: Request to Send

This bit controls the NRTS output. Bit 1 affects the NRTS output in a manner identical to that described above for bit 0.

### FCM: Flow Control Mode

When FCM is set high, the hardware can perform operations automatically depending on the state of NCTS and character transmission logic. Such changes take place immediately and are reflected in the values read in the Modem Status Register. This flag is set low at reset.

In flow control mode, transmission should occur only if NCTS is active.



# Modem Status Register

### Register Name: US\_MS

| 31  | 30 | 29  | 28  | 27   | 26   | 25   | 24   |
|-----|----|-----|-----|------|------|------|------|
| _   | -  | _   | _   | -    | _    | _    | -    |
| 23  | 22 | 21  | 20  | 19   | 18   | 17   | 16   |
| _   | -  | _   | _   | -    | _    | _    | -    |
| 15  | 14 | 13  | 12  | 11   | 10   | 9    | 8    |
| _   | -  | _   | _   | -    | _    | _    | FCMS |
| 7   | 6  | 5   | 4   | 3    | 2    | 1    | 0    |
| DCD | RI | DSR | CTS | DDCD | TERI | DDSR | DCTS |

This register provides the current state of the control lines from the modem (or peripheral device) to the CPU. In addition to this current-state information, four bits of the Modem Status Register provide change information. These bits are set to logic 1 whenever a control input from the modem changes state. They are reset to logic 0 whenever the CPU reads the Modem Status Register.

### DCTS: Delta Clear to Send

This bit is the Delta Clear to Send indicator. Bit 0 indicates that the NCTS input to the chip has changed state since the last time it was read by the CPU.

### • DDSR: Delta Data Set Ready

This bit is the Delta Data Set Ready indicator. Bit 1 indicates that the NDSR input to the chip has changed state since the last time it was read by the CPU.

### • TERI: Trailing Edge Ring Indicator

This bit is the Trailing Edge of Ring Indicator detector. Bit 2 indicates that the NRI input to the chip has changed from a low to a high state.

### • DDCD: Delta Data Carrier Detect

This bit is the Delta Data Carrier Detect indicator. Bit 3 indicates that the NDCD input has changed state.

Note that whenever bit 0, 1, 2, or 3 is set to logic 1, a Modem Status Interrupt is generated. This is reflected in the modem status register.

### CTS: Clear to Send

This bit is the complement of the Clear to Send (NCTS) input. If bit 4 (loop) of the MCR is set to a 1, this bit is equivalent to RTS in the MCR.

### DSR: Data Set Ready

This bit is the complement of the Data Set Ready (NDSR) input. If bit 4 (loop) of the MCR is set to a 1, this bit is equivalent to DTR in the MCR.

### RI: Ring Indicator

This bit is the complement of the Ring Indicator (NRI) input. If bit 4 (loop) of the MCR is set to a 1, this bit is equivalent to OUT1 in the MCR.

### DCD: Data Carrier Detect

This bit is the complement of the Data Carrier Detect (NDCD) input. If bit 4 (loop) of the MCR is set to a 1, this bit is equivalent to OUT2 in the MCR.

### • FCMS: Flow Control Status

This bit indicates the value of the FCM in the Modem Control Register.





# TC: Timer/Counter

The AT75C310 features a timer/counter block which includes three identical 16-bit timer/counter channels. Each channel can be independently programmed to perform a wide range of functions including frequency measurement, event counting, interval measurement, pulse generation, delay timing and pulse-width modulation.

Each timer/counter channel has three external clock inputs, five internal clock inputs, and two multi-purpose input/output signals that can be configured by the user. Each channel drives an internal interrupt signal that can be programmed to generate processor interrupts via the AIC.

The timer/counter block has two global registers which act upon all three TC channels. The Block Control Register allows the three channels to be started simultaneously with the same instruction. The Block Mode Register defines the external clock inputs for each timer/counter channel, allowing them to be chained.





| Channel Signal      | Description                                                                        |
|---------------------|------------------------------------------------------------------------------------|
| XC0, XC1, XC2       | External Clock Inputs                                                              |
| TIOA                | Capture Mode: General-purpose input<br>Waveform Mode: General-purpose output       |
| TIOB                | Capture Mode: General-purpose input<br>Waveform Mode: General-purpose input/output |
| INT                 | Interrupt signal output                                                            |
| SYNC                | Synchronization input signal                                                       |
| Block Signal        |                                                                                    |
| TCLK0, TCLK1, TCLK2 | External Clock Inputs                                                              |
| TIOA0               | TIOA signal for Channel 0                                                          |
| TIOB0               | TIOB signal for Channel 0                                                          |
| TIOA1               | TIOA signal for Channel 1                                                          |
| TIOB1               | TIOB signal for Channel 1                                                          |
| TIOA2               | TIOA signal for Channel 2                                                          |
| TIOB2               | TIOB signal for Channel 2                                                          |

## **Signal Name Description**

Note: After a hardware reset, the timer/counter block pins are controlled by the PIO controller. They must be configured to be controlled by the peripheral before being used.

### **Timer/Counter Description**

The three timer/counter channels are independent and identical in operation. The registers for channel programming are listed in Table 19 on page 85.

### Counter

Each timer/counter channel is organized around a 16-bit counter. The value of the counter is incremented at each positive edge of the selected clock. When the counter has reached the value 0xFFFF and passes to 0x0000, an overflow occurs and the bit COVFS in TC\_SR (Status Register) is set.

The current value of the counter is accessible in real time by reading TC\_CV. The counter can be reset by a trigger. In this case, the counter value passes to 0x0000 on the next valid edge of the selected clock.

### **Clock Selection**

At block level, input clock signals of each channel can either be connected to the external inputs TCLK0, TCLK1 or TCLK2 or be connected to the configurable I/O signals TIOA0, TIOA1 or TIOA2 for chaining by programming the TC\_BMR (Block Mode).

Each channel can independently select an internal or external clock source for its counter:

- Internal clock signals: ACLK/2, ACLK/8, ACLK/32, ACLK/128, ACLK/1024
- External clock signals: XC0, XC1 or XC2

The selected clock can be inverted with the CLKI bit in TC\_CMR (Channel Mode). This allows counting on the opposite edges of the clock.

The burst function allows the clock to be validated when an external signal is high. The BURST parameter in the Mode Register defines this signal (none, XC0, XC1, XC2).

Note: In all cases, if an external clock is used, the duration of each of its levels must be longer than the system clock (ACLK) period. The external clock frequency must be at least 2.5 times lower than the system clock (ACLK).









### **Clock Control**

The clock of each counter can be controlled in two different ways: it can be enabled/disabled and started/stopped.

- The clock can be enabled or disabled by the user with the CLKEN and the CLKDIS commands in the Control Register. In Capture Mode, it can be disabled by an RB load event if LDBDIS is set to 1 in TC\_CMR. In Waveform Mode, it can be disabled by an RC Compare event if CPCDIS is set to 1 in TC\_CMR. When disabled, the start or the stop actions have no effect: only a CLKEN command in the Control Register can re-enable the clock. When the clock is enabled, the CLKSTA bit is set in the Status Register.
- The clock can also be started or stopped: a trigger (software, synchro, external or compare) always starts the clock. The clock can be stopped by an RB load event in Capture Mode (LDBSTOP = 1 in TC\_CMR) or a RC compare event in Waveform Mode (CPCSTOP = 1 in TC\_CMR). The start and the stop commands have an effect only if the clock is enabled.

### **Timer/Counter Operating Modes**

Each timer/counter channel can independently operate in two different modes:

- 1. Capture mode allows measurement on signals
- 2. Waveform mode allows wave generation

The timer/counter operating mode is programmed with the WAVE bit in the TC Mode Register. In capture mode, TIOA and TIOB are configured as inputs. In waveform mode, TIOA is always configured to be an output and TIOB is an output if it is not selected to be the external trigger.

### Figure 18. Clock Control



### Trigger

A trigger resets the counter and starts the counter clock. Three types of triggers are common to both modes and a fourth external trigger is available to each mode.

The following triggers are common to both modes:

- Software trigger: Each channel has a software trigger that is available by setting SWTRG in TC\_CCR.
- SYNC: Each channel has a synchronization signal SYNC. When asserted, this signal has the same effect as a software trigger. The SYNC signals of all channels are asserted simultaneously by writing TC\_BCR (Block Control) with SYNC set.
- 3. Compare RC trigger: RC is implemented in each channel and can provide a trigger when the counter value matches the RC value if CPCTRG is set in TC\_CMR.

The timer/counter channel can also be configured to have an external trigger. In capture mode, the external trigger signal can be selected between TIOA and TIOB. In waveform mode, an external event can be programmed on one of the following signals: TIOB, XC0, XC1 or XC2. This external event can then be programmed to perform a trigger by setting ENETRG in TC\_CMR.

If an external trigger is used, the duration of the pulses must be longer than the system clock (ACLK) period in order to be detected.

Whatever the trigger used, it will be taken into account at the following active edge of the selected clock. This means that the counter value may not read zero just after a trigger, especially when a low-frequency signal is selected as the clock.



# **Capture Mode**

Capture mode is entered by clearing the WAVE parameter in TC\_CMR (Channel Mode Register). Capture mode allows the TC channel to perform measurements such as pulse timing, frequency, period, duty cycle and phase on TIOA and TIOB signals which are inputs.

Figure 19 shows the configuration of the TC Channel when programmed in capture mode.

### Capture Registers A and B (RA and RB)

Registers A and B are used as capture registers. This means that they can be loaded with the counter value when a programmable event occurs on the signal TIOA.

The parameter LDRA in TC\_CMR defines the TIOA edge for the loading of register A and the parameter LDRB defines the TIOA edge for the loading of Register B.

RA is loaded only if it has not been loaded since the last trigger or if RB has been loaded since the last loading of RA.

RB is loaded only if RA has been loaded since the last trigger or the last loading of RB.

Loading RA or RB before the read of the last value loaded sets the Overrun Error Flag (LOVRS) in TC\_SR (Status Register). In this case, the old value is overwritten.

### **Trigger Conditions**

In addition to the SYNC signal, the software trigger and the RC compare trigger, an external trigger can be defined.

Bit ABETRG in TC\_CMR selects input signal TIOA or TIOB as an external trigger. Parameter ETRGEDG defines the edge (rising, falling or both) detected to generate an external trigger. If ETRGEDG = 0 (none), the external trigger is disabled.

### **Status Register**

The following bits in the status register are significant in capture operating mode.

- CPCS: RC Compare Status
   There has been an RC Compare match at least once
   since the last read of the status
- COVFS: Counter Overflow Status The counter has attempted to count past \$FFFF since the last read of the status
- LOVRS: Load Overrun Status RA or RB has been loaded at least twice without any read of the corresponding register since the last read of the status
- LDRAS: Load RA Status RA has been loaded at least once without any read since the last read of the status
- LDRBS: Load RB Status RB has been loaded at least once without any read since the last read of the status
- ETRGS: External Trigger Status An external trigger on TIOA or TIOB has been detected since the last read of the status









# Waveform Mode

Waveform mode is entered by setting the WAVE parameter in TC\_CMR (Channel Mode Register).

Waveform mode allows the TC channel to generate one or two PWM signals with the same frequency and independently programmable duty cycles or different types of oneshot or repetitive pulses.

In this mode, TIOA is configured as output and TIOB is defined as output if it is not used as an external event (EEVT parameter in TC\_CMR).

Figure 20 shows the configuration of the TC Channel when programmed in waveform mode.

### Compare Register A, B and C (RA, RB, and RC)

In waveform mode, RA, RB and RC are all used as compare registers.

RA Compare is used to control the TIOA output. RB Compare is used to control the TIOB (if configured as output). RC Compare can be programmed to control TIOA and/or TIOB outputs.

RC Compare can also stop the counter clock (CPCSTOP = 1 in TC\_CMR) and/or disable the counter clock (CPCDIS = 1 in TC\_CMR).

As in capture mode, RC Compare can also generate a trigger if CPCTRG = 1. A trigger resets the counter so RC can control the period of PWM waveforms.

### **External Event/Trigger Conditions**

An external event can be programmed to be detected on one of the clock sources (XC0, XC1, XC2) or TIOB. The external event selected can then be used as a trigger.

The parameter EEVT in TC\_CMR selects the external trigger. The parameter EEVTEDG defines the trigger edge for each of the possible external triggers (rising, falling or both). If EEVTEDG is cleared (none), no external event is defined.

If TIOB is defined as an external event signal (EEVT = 0), TIOB is no longer used as output and the TC channel can only generate a waveform on TIOA.

When an external event is defined, it can be used as a trigger by setting bit ENETRG in TC\_CMR.

As in capture mode, the SYNC signal, the software trigger and the RC compare trigger are also available as triggers.

### **Output Controller**

The output controller defines the output level changes on TIOA and TIOB following an event. TIOB control is used only if TIOB is defined as output (not as an external event).

The following events control TIOA and TIOB: software trigger, external event and RC compare. RA compare controls TIOA and RB compare controls TIOB. Each of these events can be programmed to set, clear or toggle the output as defined in the corresponding parameter in TC\_CMR. The tables below show which parameter in TC\_CMR is used to define the effect of each event.

| Parameter | TIOA Event       |
|-----------|------------------|
| ASWTRG    | Software trigger |
| AEEVT     | External event   |
| ACPC      | RC compare       |
| ACPA      | RA compare       |

| Parameter | TIOB Event       |
|-----------|------------------|
| BSWTRG    | Software trigger |
| BEEVT     | External event   |
| BCPC      | RC compare       |
| ВСРВ      | RB compare       |

If two or more events occur at the same time, the priority level is defined as follows:

- 1. Software trigger
- 2. External event
- 3. RC compare
- 4. RA or RB compare

### Status

The following bits in the status register are significant in waveform mode:

- CPAS: RA Compare Status
   There has been a RA Compare match at least once since the last read of the status
- CPBS: RB Compare Status
   There has been a RB Compare match at least once since the last read of the status
- CPCS: RC Compare Status
   There has been a RC Compare match at least once
   since the last read of the status
- COVFS: Counter Overflow Counter has attempted to count past \$FFFF since the last read of the status
- ETRGS: External Trigger

External trigger has been detected since the last read of the status





Figure 20. Waveform Mode



84

AT75C310



# **TC User Interface**

TC Base Address: 0xFF014000

Table 18. TC Global Memory Map

| Offset | Channel/Register          | Name         | Access     | Reset State |  |
|--------|---------------------------|--------------|------------|-------------|--|
| 0x00   | TC Channel 0              | See Table 19 |            |             |  |
| 0x40   | TC Channel 1              | See Table 19 |            |             |  |
| 0x80   | TC Channel 2              | See Table 19 |            |             |  |
| 0xC0   | TC Block Control Register | TC_BCR       | Write-only | _           |  |
| 0xC4   | TC Block Mode Register    | TC_BMR       | Read/write | 0           |  |

TC\_BCR (Block Control Register) and TC\_BMR (Block Mode Register) control the TC block. TC channels are controlled by the registers listed in Table 19. The offset of each of the channel registers in Table 19 is in relation to the offset of the corresponding channel as stated in Table 18.

Table 19. TC Channel Memory Map

| Offset | Register Description       | Register Name | Access                    | Reset State |
|--------|----------------------------|---------------|---------------------------|-------------|
| 0x00   | Channel Control Register   | TC_CCR        | Write-only                | _           |
| 0x04   | Channel Mode Register      | TC_CMR        | Read/write                | 0           |
| 0x08   | Reserved                   |               |                           | _           |
| 0x0C   | Reserved                   |               |                           | _           |
| 0x10   | Counter Value Register     | TC_CVR        | Read/write                | 0           |
| 0x14   | Register A                 | TC_RA         | Read/write <sup>(1)</sup> | 0           |
| 0x18   | Register B                 | TC_RB         | Read/write <sup>(1)</sup> | 0           |
| 0x1C   | Register C                 | TC_RC         | Read/write                | 0           |
| 0x20   | Status Register            | TC_SR         | Read-only                 | _           |
| 0x24   | Interrupt Enable Register  | TC_IER        | Write-only                | -           |
| 0x28   | Interrupt Disable Register | TC_IDR        | Write-only                | -           |
| 0x2C   | Interrupt Mask Register    | TC_IMR        | Read-only                 | 0           |

Note: 1. Read only if WAVE = 0



# **TC Block Control Register**

| Register Name<br>Access Type: | e: TC_BCF<br>Write-on |    |    |    |    |    |      |
|-------------------------------|-----------------------|----|----|----|----|----|------|
| 31                            | 30                    | 29 | 28 | 27 | 26 | 25 | 24   |
| -                             | _                     | -  | -  | -  | -  | -  | -    |
| 23                            | 22                    | 21 | 20 | 19 | 18 | 17 | 16   |
| -                             | _                     | -  | -  | -  | -  | -  | -    |
| 15                            | 14                    | 13 | 12 | 11 | 10 | 9  | 8    |
| _                             | _                     | _  | -  | -  | _  | _  | -    |
| 7                             | 6                     | 5  | 4  | 3  | 2  | 1  | 0    |
| _                             | _                     | _  | _  | _  | _  | -  | SYNC |

# • SYNC: Synchro Command

0 = No effect.

1 = Asserts the SYNC signal which generates a software trigger simultaneously for each of the channels.

# **TC Block Mode Register**

| Register Name:<br>Access Type: | TC_BMF<br>Read/wr |    |       |     |      |     |      |
|--------------------------------|-------------------|----|-------|-----|------|-----|------|
| 31                             | 30                | 29 | 28    | 27  | 26   | 25  | 24   |
| _                              | _                 | _  | -     | _   | _    | _   | _    |
| 23                             | 22                | 21 | 20    | 19  | 18   | 17  | 16   |
| _                              | _                 | _  | -     | _   | _    | _   | _    |
| 15                             | 14                | 13 | 12    | 11  | 10   | 9   | 8    |
| -                              | _                 | _  | -     | -   | _    | _   | _    |
| 7                              | 6                 | 5  | 4     | 3   | 2    | 1   | 0    |
| -                              | -                 | TC | 2XC2S | TC1 | XC1S | TC0 | XCOS |

# • TC0XC0S: External Clock Signal 0 Selection

| TC0) | (COS | Signal Connected to XC0 |
|------|------|-------------------------|
| 0    | 0    | TCLK0                   |
| 0    | 1    | None                    |
| 1    | 0    | TIOA1                   |
| 1    | 1    | TIOA2                   |

## • TC1XC1S: External Clock Signal 1 Selection

| TC1> | (C1S | Signal Connected to XC1 |
|------|------|-------------------------|
| 0    | 0    | TCLK1                   |
| 0    | 1    | None                    |
| 1    | 0    | TIOA0                   |
| 1    | 1    | TIOA2                   |

## • TC2XC2S: External Clock Signal 2 Selection

| TC2X | C2S | Signal Connected to XC2 |
|------|-----|-------------------------|
| 0    | 0   | TCLK2                   |
| 0    | 1   | None                    |
| 1    | 0   | TIOA0                   |
| 1    | 1   | TIOA1                   |





# **TC Channel Control Register**

| Register Name<br>Access Type: | : TC_CCF<br>Write-on |    |    |    |       |        |       |
|-------------------------------|----------------------|----|----|----|-------|--------|-------|
| 31                            | 30                   | 29 | 28 | 27 | 26    | 25     | 24    |
| -                             | -                    | -  | -  | -  | -     | -      | -     |
| 23                            | 22                   | 21 | 20 | 19 | 18    | 17     | 16    |
| -                             | -                    | -  | -  | -  | -     | -      | -     |
| 15                            | 14                   | 13 | 12 | 11 | 10    | 9      | 8     |
| -                             | _                    | _  | -  | -  | -     | _      | _     |
| 7                             | 6                    | 5  | 4  | 3  | 2     | 1      | 0     |
| _                             | _                    | _  | -  | -  | SWTRG | CLKDIS | CLKEN |

### CLKEN: Counter Clock Enable Command

0 = No effect.

1 = Enables the clock if CLKDIS is not 1.

CLKDIS: Counter Clock Disable Command

0 = No effect.

1 = Disables the clock.

• SWTRG: Software Trigger Command

0 = No effect.

1 = A software trigger is performed: the counter is reset and clock is started.

# TC Channel Mode Register: Capture Mode

| Register Name<br>Access Type: | : TC_CMF<br>Read/wri |    |      |      |        |        |      |
|-------------------------------|----------------------|----|------|------|--------|--------|------|
| 31                            | 30                   | 29 | 28   | 27   | 26     | 25     | 24   |
| -                             | _                    | _  | -    | -    | -      | _      | -    |
| 23                            | 22                   | 21 | 20   | 19   | 18     | 17     | 16   |
| -                             | _                    | _  | -    | L    | DRB    | L      | ORA  |
| 15                            | 14                   | 13 | 12   | 11   | 10     | 9      | 8    |
| WAVE=0                        | CPCTRG               | _  | -    | -    | ABETRG | ETR    | GEDG |
| 7                             | 6                    | 5  | 4    | 3    | 2      | 1      | 0    |
| LDBDIS                        | LDBSTOP              | BL | JRST | CLKI |        | TCCLKS |      |

### • TCCLKS: Clock Selection

| 1 | TCCLKS |   | Clock Selected |
|---|--------|---|----------------|
| 0 | 0      | 0 | ACLK/2         |
| 0 | 0      | 1 | ACLK/8         |
| 0 | 1      | 0 | ACLK/32        |
| 0 | 1      | 1 | ACLK/128       |
| 1 | 0      | 0 | ACLK/1024      |
| 1 | 0      | 1 | XC0            |
| 1 | 1      | 0 | XC1            |
| 1 | 1      | 1 | XC2            |

### CLKI: Clock Invert

0 = Counter is incremented on rising edge of the clock.

- 1 = Counter is incremented on falling edge of the clock.
- BURST: Burst Signal Selection

| BUI | RST |                                              |
|-----|-----|----------------------------------------------|
| 0   | 0   | The clock is not gated by an external signal |
| 0   | 1   | XC0 is ANDed with the selected clock         |
| 1   | 0   | XC1 is ANDed with the selected clock         |
| 1   | 1   | XC2 is ANDed with the selected clock         |

- LDBSTOP: Counter Clock Stopped with RB Loading
  - $\mathbf{0}=\mathbf{Counter}\ \mathbf{clock}\ \mathbf{is}\ \mathbf{not}\ \mathbf{stopped}\ \mathbf{when}\ \mathbf{RB}\ \mathbf{loading}\ \mathbf{occurs}.$
  - 1 = Counter clock is stopped when RB loading occurs.

### LDBDIS: Counter Clock Disable with RB Loading

- 0 = Counter clock is not disabled when RB loading occurs.
- 1 = Counter clock is disabled when RB loading occurs.





### • ETRGEDG: External Trigger Edge Selection

| ETRO | GEDG | Edge         |
|------|------|--------------|
| 0    | 0    | None         |
| 0    | 1    | Rising edge  |
| 1    | 0    | Falling edge |
| 1    | 1    | Each edge    |

### ABETRG: TIOA or TIOB External Trigger Selection

0 = TIOB is used as an external trigger.

- 1 = TIOA is used as an external trigger.
- CPCTRG: RC Compare Trigger Enable
  - 0 = RC Compare has no effect on the counter and its clock.
  - 1 = RC Compare resets the counter and starts the counter clock.
- WAVE = 0
  - 0 = Capture Mode is enabled.
  - 1 = Capture Mode is disabled (Waveform Mode is enabled).
- LDRA: RA Loading Selection

| LD | RA | Edge                 |
|----|----|----------------------|
| 0  | 0  | None                 |
| 0  | 1  | Rising edge of TIOA  |
| 1  | 0  | Falling edge of TIOA |
| 1  | 1  | Each edge of TIOA    |

• LDRB: RB Loading Selection

| LD | RB | Edge                 |
|----|----|----------------------|
| 0  | 0  | None                 |
| 0  | 1  | Rising edge of TIOA  |
| 1  | 0  | Falling edge of TIOA |
| 1  | 1  | Each edge of TIOA    |

# TC Channel Mode Register: Waveform Mode

| Register Name<br>Access Type: | : TC_CMR<br>Read/write |    |        |      |    |        |      |
|-------------------------------|------------------------|----|--------|------|----|--------|------|
| 31                            | 30                     | 29 | 28     | 27   | 26 | 25     | 24   |
| BSW                           | TRG                    | В  | EEVT   | BCI  | PC | BC     | PB   |
| 23                            | 22                     | 21 | 20     | 19   | 18 | 17     | 16   |
| ASW                           | TRG                    | А  | EEVT   | ACI  | PC | AC     | PA   |
| 15                            | 14                     | 13 | 12     | 11   | 10 | 9      | 8    |
| WAVE=1                        | CPCTRG                 | -  | ENETRG | EE   | VT | EEV    | ΓEDG |
| 7                             | 6                      | 5  | 4      | 3    | 2  | 1      | 0    |
| CPCDIS                        | CPCSTOP                | В  | URST   | CLKI |    | TCCLKS |      |

### TCCLKS: Clock Selection

| 1 | TCCLKS |   | Clock Selected |
|---|--------|---|----------------|
| 0 | 0      | 0 | ACLK/2         |
| 0 | 0      | 1 | ACLK/8         |
| 0 | 1      | 0 | ACLK/32        |
| 0 | 1      | 1 | ACLK/128       |
| 1 | 0      | 0 | ACLK/1024      |
| 1 | 0      | 1 | XC0            |
| 1 | 1      | 0 | XC1            |
| 1 | 1      | 1 | XC2            |

### CLKI: Clock Invert

- 0 = Counter is incremented on rising edge of the clock.
- 1 = Counter is incremented on falling edge of the clock.
- BURST: Burst Signal Selection

| BURST |   |                                              |
|-------|---|----------------------------------------------|
| 0     | 0 | The clock is not gated by an external signal |
| 0     | 1 | XC0 is ANDed with the selected clock         |
| 1     | 0 | XC1 is ANDed with the selected clock         |
| 1     | 1 | XC2 is ANDed with the selected clock         |

### • CPCSTOP: Counter Clock Stopped with RC Compare

- 0 = Counter clock is not stopped when counter reaches RC.
- 1 = Counter clock is stopped when counter reaches RC.

### CPCDIS: Counter Clock Disable with RC Compare

- 0 = Counter clock is not disabled when counter reaches RC.
- 1 = Counter clock is disabled when counter reaches RC.





### • EEVTEDG: External Event Edge Selection

| EEVT | EDG | Edge         |
|------|-----|--------------|
| 0    | 0   | None         |
| 0    | 1   | Rising edge  |
| 1    | 0   | Falling edge |
| 1    | 1   | Each edge    |

#### • EEVT: External Event Selection

| EE | VT | Signal Selected as<br>External Event | TIOB<br>Direction    |
|----|----|--------------------------------------|----------------------|
| 0  | 0  | TIOB                                 | Input <sup>(1)</sup> |
| 0  | 1  | XC0                                  | Output               |
| 1  | 0  | XC1                                  | Output               |
| 1  | 1  | XC2                                  | Output               |

Note: 1. If TIOB is chosen as the external event signal, it is configured as an input and no longer generates waveforms.

### ENETRG: External Event Trigger Enable

0 = The external event has no effect on the counter and its clock. In this case, the selected external event only controls the TIOA output.

1 = The external event resets the counter and starts the counter clock.

### • CPCTRG: RC Compare Trigger Enable

0 = RC Compare has no effect on the counter and its clock.

- 1 = RC Compare resets the counter and starts the counter clock.
- WAVE = 1

0 = Waveform mode is disabled (capture mode is enabled).

- 1 = Waveform mode is enabled.
- ACPA: RA Compare Effect on TIOA

| AC | PA | Effect |
|----|----|--------|
| 0  | 0  | None   |
| 0  | 1  | Set    |
| 1  | 0  | Clear  |
| 1  | 1  | Toggle |

### ACPC: RC Compare Effect on TIOA

| AC | PC | Effect |
|----|----|--------|
| 0  | 0  | None   |
| 0  | 1  | Set    |
| 1  | 0  | Clear  |
| 1  | 1  | Toggle |

## • AEEVT: External Event Effect on TIOA

| AEI | EVT | Effect |
|-----|-----|--------|
| 0   | 0   | None   |
| 0   | 1   | Set    |
| 1   | 0   | Clear  |
| 1   | 1   | Toggle |

## • ASWTRG: Software Trigger Effect on TIOA

| ASW | TRG | Effect |
|-----|-----|--------|
| 0   | 0   | None   |
| 0   | 1   | Set    |
| 1   | 0   | Clear  |
| 1   | 1   | Toggle |

## BCPB: RB Compare Effect on TIOB

| BC | РВ | Effect |
|----|----|--------|
| 0  | 0  | None   |
| 0  | 1  | Set    |
| 1  | 0  | Clear  |
| 1  | 1  | Toggle |

## • BCPC: RC Compare Effect on TIOB

| BC | PC | Effect |
|----|----|--------|
| 0  | 0  | None   |
| 0  | 1  | Set    |
| 1  | 0  | Clear  |
| 1  | 1  | Toggle |

## • BEEVT: External Event Effect on TIOB

| BEI | EVT | Effect |
|-----|-----|--------|
| 0   | 0   | None   |
| 0   | 1   | Set    |
| 1   | 0   | Clear  |
| 1   | 1   | Toggle |





# • BSWTRG: Software Trigger Effect on TIOB

| BSW | TRG | Effect |
|-----|-----|--------|
| 0   | 0   | None   |
| 0   | 1   | Set    |
| 1   | 0   | Clear  |
| 1   | 1   | Toggle |

# **TC Counter Value Register**

| Register Name:<br>Access Type: | TC_CVR<br>Read-only |    |    |    |    |    |    |
|--------------------------------|---------------------|----|----|----|----|----|----|
| 31                             | 30                  | 29 | 28 | 27 | 26 | 25 | 24 |
| -                              | _                   | _  | -  | _  | -  | _  | _  |
| 23                             | 22                  | 21 | 20 | 19 | 18 | 17 | 16 |
| -                              | -                   | _  | -  | _  | -  | _  | -  |
| 15                             | 14                  | 13 | 12 | 11 | 10 | 9  | 8  |
|                                |                     |    | C  | V  |    |    |    |
| 7                              | 6                   | 5  | 4  | 3  | 2  | 1  | 0  |
|                                |                     |    | C  | V  |    |    |    |

### • CV: Counter Value

CV contains the counter value in real-time.

# **TC Register A**

| Register Name: | TC_RA                                         |
|----------------|-----------------------------------------------|
| Access Type:   | Read-only if WAVE = 0, Read/write if WAVE = 1 |

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----|----|----|----|----|----|----|
| _  | -  | _  | _  | _  | -  | _  | -  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| _  | _  | -  | _  | _  | _  | _  | _  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
|    |    |    | F  | RA |    |    |    |
| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    | F  | RA |    |    |    |

# • RA: Register A

RA contains the Register A value in real-time.





# **TC Register B**

| Register Name:<br>Access Type: |    | TC_RB<br>Read-only if WAVE = 0, Read/write if WAVE = 1 |    |           |    |    |    |  |
|--------------------------------|----|--------------------------------------------------------|----|-----------|----|----|----|--|
| 31                             | 30 | 29                                                     | 28 | 27        | 26 | 25 | 24 |  |
| -                              | _  | _                                                      | _  | _         | -  | _  | -  |  |
| 23                             | 22 | 21                                                     | 20 | 19        | 18 | 17 | 16 |  |
| -                              | _  | _                                                      | _  | _         | -  | _  | _  |  |
| 15                             | 14 | 13                                                     | 12 | 11        | 10 | 9  | 8  |  |
|                                |    | RB                                                     |    |           |    |    |    |  |
| 7                              | 6  | 5                                                      | 4  | 3         | 2  | 1  | 0  |  |
|                                |    |                                                        | F  | <b>≀B</b> |    |    |    |  |

### • RB: Register B

RB contains the Register B value in real-time.

# **TC Register C**

| Register Name:<br>Access Type: | TC_RC<br>Read/wri | te |    |    |    |    |    |
|--------------------------------|-------------------|----|----|----|----|----|----|
| 31                             | 30                | 29 | 28 | 27 | 26 | 25 | 24 |
| -                              | _                 | _  | -  | _  | -  | _  | _  |
| 23                             | 22                | 21 | 20 | 19 | 18 | 17 | 16 |
| -                              | _                 | _  | -  | _  | -  | _  | -  |
| 15                             | 14                | 13 | 12 | 11 | 10 | 9  | 8  |
|                                |                   |    | F  | C  |    |    |    |
| 7                              | 6                 | 5  | 4  | 3  | 2  | 1  | 0  |
|                                |                   |    | F  | RC |    |    |    |

# • RC: Register C

RC contains the Register C value in real-time.

# **TC Status Register**

| Register Name<br>Access Type: | TC_SR<br>Read/wr | ite   |      |      |       |       |        |
|-------------------------------|------------------|-------|------|------|-------|-------|--------|
| 31                            | 30               | 29    | 28   | 27   | 26    | 25    | 24     |
| -                             | -                | -     | -    | -    | -     | -     | -      |
| 23                            | 22               | 21    | 20   | 19   | 18    | 17    | 16     |
| -                             | _                | -     | -    | -    | MTIOB | MTIOA | CLKSTA |
| 15                            | 14               | 13    | 12   | 11   | 10    | 9     | 8      |
| -                             | -                | -     | -    | -    | -     | -     | -      |
| 7                             | 6                | 5     | 4    | 3    | 2     | 1     | 0      |
| ETRGS                         | LDRBS            | LDRAS | CPCS | CPBS | CPAS  | LOVRS | COVFS  |

## COVFS: Counter Overflow Status

- 0 = No counter overflow has occurred since the last read of the Status Register.
- 1 = A counter overflow has occurred since the last read of the Status Register.

### LOVRS: Load Overrun Status

0 = Load overrun has not occurred since the last read of the Status Register or WAVE = 1.

1 = RA or RB have been loaded at least twice without any read of the corresponding register since the last read of the Status Register if WAVE = 0.

## CPAS: RA Compare Status

0 = RA Compare has not occurred since the last read of the Status Register or WAVE = 0.

1 = RA Compare has occurred since the last read of the Status Register if WAVE = 1.

## CPBS: RB Compare Status

0 = RB Compare has not occurred since the last read of the Status Register or WAVE = 0.

1 = RB Compare has occurred since the last read of the Status Register if WAVE = 1.

### CPCS: RC Compare Status

0 = RC Compare has not occurred since the last read of the Status Register.

1 = RC Compare has occurred since the last read of the Status Register.

### • LDRAS: RA Loading Status

0 = RA Load has not occurred since the last read of the Status Register or WAVE = 1.

1 = RA Load has occurred since the last read of the Status Register if WAVE = 0.

## • LDRBS: RB Loading Status

0 = RB Load has not occurred since the last read of the Status Register or WAVE = 1.

1 = RB Load has occurred since the last read of the Status Register if WAVE = 0.

### • ETRGS: External Trigger Status

0 = External trigger has not occurred since the last read of the Status Register.

1 = External trigger has occurred since the last read of the Status Register.

### • CLKSTA: Clock Enabling Status

0 = Clock is disabled.

1 = Clock is enabled.

## • MTIOA: TIOA Mirror

0 = TIOA is low. If WAVE = 0, TIOA pin is low. If WAVE = 1, TIOA is driven low.

1 = TIOA is high. If WAVE = 0, TIOA pin is high. If WAVE = 1, TIOA is driven high.

## • MTIOB: TIOB Mirror

- 0 = TIOB is low. If WAVE = 0, TIOB pin is low. If WAVE = 1, TIOB is driven low.
- 1 = TIOB is high. If WAVE = 0, TIOB pin is high. If WAVE = 1, TIOB is driven high.





# **TC Interrupt Enable Register**

| Register Name:<br>Access Type: | : TC_IER<br>Write-on |       |      |      |      |       |       |
|--------------------------------|----------------------|-------|------|------|------|-------|-------|
| 31                             | 30                   | 29    | 28   | 27   | 26   | 25    | 24    |
| -                              | -                    | -     | -    | -    | -    | -     | -     |
| 23                             | 22                   | 21    | 20   | 19   | 18   | 17    | 16    |
| -                              | -                    | -     | -    | -    | -    | -     | -     |
| 15                             | 14                   | 13    | 12   | 11   | 10   | 9     | 8     |
| -                              | _                    | _     | -    | -    | -    | -     | -     |
| 7                              | 6                    | 5     | 4    | 3    | 2    | 1     | 0     |
| ETRGS                          | LDRBS                | LDRAS | CPCS | CPBS | CPAS | LOVRS | COVFS |

### COVFS: Counter Overflow

- 0 = No effect.
- 1 = Enables the Counter Overflow Interrupt.
- LOVRS: Load Overrun
  - 0 = No effect.
  - 1 = Enables the Load Overrun Interrupt.

### • CPAS: RA Compare

- 0 = No effect.
- 1 = Enables the RA Compare Interrupt.

### CPBS: RB Compare

- 0 = No effect.
- 1 = Enables the RB Compare Interrupt.

### CPCS: RC Compare

- 0 = No effect.
- 1 = Enables the RC Compare Interrupt.

### LDRAS: RA Loading

- 0 = No effect.
- 1 = Enables the RA Load Interrupt.

### • LDRBS: RB Loading

- 0 = No effect.
- 1 = Enables the RB Load Interrupt.

### • ETRGS: External Trigger

- 0 = No effect.
- 1 = Enables the External Trigger Interrupt.

# **TC Interrupt Disable Register**

| Register Name<br>Access Type: | : TC_IDR<br>Write-on |       |      |      |      |       |       |
|-------------------------------|----------------------|-------|------|------|------|-------|-------|
| 31                            | 30                   | 29    | 28   | 27   | 26   | 25    | 24    |
| -                             | _                    | _     | -    | -    | _    | _     | _     |
| 23                            | 22                   | 21    | 20   | 19   | 18   | 17    | 16    |
| -                             | _                    | _     | -    | -    | _    | _     | _     |
| 15                            | 14                   | 13    | 12   | 11   | 10   | 9     | 8     |
| -                             | _                    | _     | -    | -    | _    | _     | _     |
| 7                             | 6                    | 5     | 4    | 3    | 2    | 1     | 0     |
| ETRGS                         | LDRBS                | LDRAS | CPCS | CPBS | CPAS | LOVRS | COVFS |

### COVFS: Counter Overflow

- 0 = No effect.
- 1 = Disables the Counter Overflow Interrupt.
- LOVRS: Load Overrun
  - 0 = No effect.
  - 1 = Disables the Load Overrun Interrupt (if WAVE = 0).

## • CPAS: RA Compare

- 0 = No effect.
- 1 = Disables the RA Compare Interrupt (if WAVE = 1).

## CPBS: RB Compare

- 0 = No effect.
- 1 = Disables the RB Compare Interrupt (if WAVE = 1).

## CPCS: RC Compare

- 0 = No effect.
- 1 = Disables the RC Compare Interrupt.

## LDRAS: RA Loading

- 0 = No effect.
- 1 = Disables the RA Load Interrupt (if WAVE = 0).

## • LDRBS: RB Loading

- 0 = No effect.
- 1 = Disables the RB Load Interrupt (if WAVE = 0).

## • ETRGS: External Trigger

- 0 = No effect.
- 1 = Disables the External Trigger Interrupt.





# **TC Interrupt Mask Register**

| Register Name:<br>Access Type: | TC_IMR<br>Read-on |       |      |      |      |       |       |
|--------------------------------|-------------------|-------|------|------|------|-------|-------|
| 31                             | 30                | 29    | 28   | 27   | 26   | 25    | 24    |
| _                              | _                 | _     | -    | _    | _    | -     | _     |
| 23                             | 22                | 21    | 20   | 19   | 18   | 17    | 16    |
| -                              | _                 | _     | -    | _    | _    | -     | _     |
| 15                             | 14                | 13    | 12   | 11   | 10   | 9     | 8     |
| -                              | _                 | _     | -    | _    | _    | -     | _     |
| 7                              | 6                 | 5     | 4    | 3    | 2    | 1     | 0     |
| ETRGS                          | LDRBS             | LDRAS | CPCS | CPBS | CPAS | LOVRS | COVFS |

### COVFS: Counter Overflow

0 = The Counter Overflow Interrupt is disabled.

1 = The Counter Overflow Interrupt is enabled.

### LOVRS: Load Overrun

0 = The Load Overrun Interrupt is disabled.

1 = The Load Overrun Interrupt is enabled.

### • CPAS: RA Compare

0 = The RA Compare Interrupt is disabled.

1 = The RA Compare Interrupt is enabled.

### CPBS: RB Compare

0 = The RB Compare Interrupt is disabled.

1 = The RB Compare Interrupt is enabled.

### CPCS: RC Compare

0 = The RC Compare Interrupt is disabled.

1 = The RC Compare Interrupt is enabled.

### • LDRAS: RA Loading

0 = The Load RA Interrupt is disabled.

1 = The Load RA Interrupt is enabled.

### • LDRBS: RB Loading

0 = The Load RB Interrupt is disabled.

1 = The Load RB Interrupt is enabled.

### • ETRGS: External Trigger

- 0 = The External Trigger Interrupt is disabled.
- 1 = The External Trigger Interrupt is enabled.



# **SPI: Serial Peripheral Interface**

The serial peripheral interface provides communication with external devices in master or slave mode. It also

allows communication with external processors or serial Flash.

### Figure 21. SPI Block Diagram



#### Table 20. SPI Interface Pins

| Pin Name  | Description                             | Mode                      | Function                                                                                 |
|-----------|-----------------------------------------|---------------------------|------------------------------------------------------------------------------------------|
| MISO      | Master In/Slave Out                     | Master<br>Slave           | Serial data input to SPI<br>Serial data output from SPI                                  |
| MOSI      | Master Out/Slave In                     | Master<br>Slave           | Serial data output from SPI<br>Serial data input to SPI                                  |
| SPCK      | Serial Clock                            | Master<br>Slave           | Clock output from SPI<br>Clock input to SPI                                              |
| NPCSS     | Peripheral Chip Select/<br>Slave Select | Master<br>Master<br>Slave | Output: Selects peripheral<br>Input: Low causes mode fault<br>Input: Chip select for SPI |
| NPCS[3:1] | Peripheral Chip Selects                 | Master                    | Extra selects                                                                            |

Note: 1. After a hardware reset, the SPI pins NPCS[3:1] are not enabled by default and must be programmed via the PIO A controller.





## **Master Mode**

In master mode, the SPI controls data transfers to and from the slave(s) connected to the SPI bus. The SPI drives the chip select(s) to the slave(s) and the serial clock (SPCK). After enabling the SPI, a data transfer begins when the ARM core writes to the SP\_TDR (Transmit Data Register). See Table 21.

Transmit and receive buffers maintain the data flow at a constant rate with a reduced requirement for high-priority interrupt servicing. When new data is available in the SP\_TDR (Transmit Data Register) the SPI continues to transfer data. If the SP\_RDR (Receive Data Register) has not been read before new data is received, the Overrun Error (OVRES) flag is set.

The delay between the activation of the chip select and the start of the data transfer (DLYBS), as well as the delay between each data transfer (DLYBCT), can be programmed for each of the four external chip selects. All data transfer characteristics including the two timing values are programmed in registers SP\_CSR0 to SP\_CSR(Chip Select Registers). See Table 21 on page 107.

In master mode, the peripheral selection can be defined in two different ways:

- 1. Fixed Peripheral Select: SPI exchanges data with only one peripheral
- 2. Variable Peripheral Select: Data can be exchanged with more than one peripheral

Figures 22 and 23 show the operation of the SPI in master mode. For details concerning the flag and control bits in these diagrams, see Table 21 on page 107.

### **Fixed Peripheral Select**

This mode is ideal for transferring memory blocks without the extra overhead in the transmit data register to determine the peripheral.

Fixed peripheral select is activated by setting bit PS to zero in SP\_MR (Mode Register). The peripheral is defined by the PCS field that is also in SP\_MR.

This option is only available when the SPI is programmed in master mode.

### Variable Peripheral Select

Variable peripheral select is activated by setting bit PS to one. The PCS field in SP\_TDR (Transmit Data Register) is used to select the destination peripheral. The data transfer characteristics are changed when the selected peripheral changes according to the associated chip select register.

The PCS field in the SP MR has no effect.

This option is only available when the SPI is programmed in master mode.

#### **Chip Selects**

The chip select lines are driven by the SPI only if it is programmed in master mode. These lines are used to select the destination peripheral. The PCSDEC field in SP\_MR (Mode Register) selects one to four peripherals (PCSDEC = 0) or up to 15 peripherals (PCSDEC = 1).

If variable peripheral select is active, the chip select signals are defined for each transfer in the PCS field in SP\_TDR. Chip select signals can thus be defined independently for each transfer.

If fixed peripheral select is active, chip select signals are defined for all transfers by the field PCS in SP\_MR. If a transfer with a new peripheral is necessary, the software must wait until the current transfer is completed and then change the value of PCS in SP\_MR before writing new data in SP\_TDR.

The value on the NPCS pins at the end of each transfer can be read in the SP\_RDR (Receive Data Register).

By default, all NPCS signals are high (equal to one) before and after each transfer.

### **Mode Fault Detection**

A mode fault is detected when the SPI is programmed in master mode and a low level is driven by an external master on the NPCS0/NSS signal.

When a mode fault is detected, the MODF bit in the SP\_SR is set until the SP\_SR is read and the SPI is disabled until re-enabled by bit SPIEN in the SP\_CR (Control Register).









Figure 23. SPI in Master Mode





## **Slave Mode**

In slave mode, the SPI waits for NPCSS to go active low before receiving the serial clock from an external master.

In slave mode, CPOL, NCPHA and BITS fields of SP\_CSR0 are used to define the transfer characteristics. The other chip select registers are not used in slave mode.







# **Data Transfer**

Figure 25, Figure 26 and Figure 27 show examples of data transfers.





Figure 26. SPI Transfer Format (NCPHA Equals Zero, Eight Bits per Transfer)







### **Clock Generation**

In master mode, the SPI master clock is either ACLK or ACLK/32 as defined by the MCK32 field of SP\_MR. The SPI baud rate clock is generated by dividing the SPI master clock by a value between 4 and 510. The divisor is defined in the SCBR field in each chip select register. The transfer speed can thus be defined independently for each chip select signal.

CPOL and NCPHA in the chip select registers define the clock/data relationship between master and slave devices. CPOL defines the inactive value of the SPCK. NCPHA defines the edge that causes data to change and the edge that causes data to be captured.

In slave mode, the input clock low and high pulse duration must be longer than two system clock (ACLK) periods.

### **Peripheral Data Controller**

The SPI is connected to two PDC channels. One is dedicated to the receiver, the other is dedicated to the transmitter.

### **SPI Programmer's Model**

SPI Base Address: 0xFF020000

| Table 21. SPI Memory M |
|------------------------|
|------------------------|

The PDC channel is programmed using SP\_TPR (Transmit Pointer) and SP\_TCR (Transmit Counter) for the transmitter and SP\_RPR (Receive Pointer) and SP\_RCR (Receive Counter) for the receiver. The status of the PDC is given in SP\_SR by the SPENDTX bit for the transmitter and by the SPENDRX bit for the receiver.

The pointer registers (SP\_TPR and SP\_RPR) are used to store the address of the transmit or receive buffers. The counter registers (SP\_TCR and SP\_RCR) are used to store the size of these buffers.

The receiver data transfer is triggered by the RDRF bit and the transmitter data transfer is triggered by TDRE. When a transfer is performed, the counter is decremented and the pointer is incremented. When the counter reaches 0, the status bit is set (SPENDRX for the receiver, SPENDTX for the transmitter in SP\_SR) and can be programmed to generate an interrupt. While the counter is at zero, the status bit is asserted and transfers are disabled.

| Offset | Register Description       | Register Name | Access     | Reset State |
|--------|----------------------------|---------------|------------|-------------|
| 0x00   | Control Register           | SP_CR         | Write-only | _           |
| 0x04   | Mode Register              | SP_MR         | Read/write | 0           |
| 0x08   | Receive Data Register      | SP_RDR        | Read-only  | 0           |
| 0x0C   | Transmit Data Register     | SP_TDR        | Write-only | _           |
| 0x10   | Status Register            | SP_SR         | Read-only  | 0           |
| 0x14   | Interrupt Enable Register  | SP_IER        | Write-only | _           |
| 0x18   | Interrupt Disable Register | SP_IDR        | Write-only | _           |





### Table 21. SPI Memory Map (Continued)

| Offset | Register Description    | Register Name Access |            | Reset State |
|--------|-------------------------|----------------------|------------|-------------|
| 0x1C   | Interrupt Mask Register | SP_IMR               | Read-only  | 0           |
| 0x20   | Reserved                | _                    | _          | _           |
| 0x24   | Reserved                | _                    | _          | _           |
| 0x28   | Reserved                | -                    | _          | _           |
| 0x2C   | Reserved                | _                    | _          | _           |
| 0x30   | Chip Select Register 0  | SP_CSR0              | Read/write | 0           |
| 0x34   | Chip Select Register 1  | SP_CSR1              | Read/write | 0           |
| 0x38   | Reserved                | _                    | _          | _           |
| 0x3C   | Reserved                | _                    | _          | _           |

# **SPI Control Register**

| Register Name<br>Access Type: | SP_CR<br>Write-on |    |    |    |    |        |       |
|-------------------------------|-------------------|----|----|----|----|--------|-------|
| 31                            | 30                | 29 | 28 | 27 | 26 | 25     | 24    |
| -                             | -                 | -  | -  | -  | -  | -      | -     |
| 23                            | 22                | 21 | 20 | 19 | 18 | 17     | 16    |
| -                             | _                 | -  | -  | -  | -  | -      | -     |
| 15                            | 14                | 13 | 12 | 11 | 10 | 9      | 8     |
| _                             | _                 | -  | -  | -  | -  | _      | -     |
| 7                             | 6                 | 5  | 4  | 3  | 2  | 1      | 0     |
| SWRST                         | _                 | -  | -  | -  | -  | SPIDIS | SPIEN |

### • SPIEN: SPI Enable

0 = No effect.

1 = Enables the SPI to transfer and receive data.

### • SPIDIS: SPI Disable

0 = No effect.

1 = Disables the SPI.

All pins are set in input mode and no data is received or transmitted.

If a transfer is in progress, the transfer is finished before the SPI is disabled.

If both SPIEN and SPIDIS are equal to one when the control register is written, the SPI is disabled.

### • SWRST: SPI Software reset

- 0 = No effect.
- 1 = Resets the SPI.

A software-triggered hardware reset of the SPI interface is performed.

## **SPI Mode Register**

| Register Name<br>Access Type: | e: SP_MR<br>Read/wi |    |    |       |        |    |      |
|-------------------------------|---------------------|----|----|-------|--------|----|------|
| 31                            | 30                  | 29 | 28 | 27    | 26     | 25 | 24   |
|                               |                     |    | DL | YBCS  |        |    |      |
| 23                            | 22                  | 21 | 20 | 19    | 18     | 17 | 16   |
| -                             | -                   | -  | -  |       | PC     | CS |      |
| 15                            | 14                  | 13 | 12 | 11    | 10     | 9  | 8    |
| _                             | _                   | -  | -  | -     | -      | -  | -    |
| 7                             | 6                   | 5  | 4  | 3     | 2      | 1  | 0    |
| LLB                           | -                   | -  | -  | MCK32 | PCSDEC | PS | MSTR |

### • MSTR: Master/Slave Mode

0 = SPI is in slave mode.

1 = SPI is in master mode.

MSTR configures the SPI interface for either master or slave mode operation.

### • PS: Peripheral Select

0 = Fixed Peripheral Select.

1 = Variable Peripheral Select.

### • PCSDEC: Chip Select Decode

0 = The chip selects are directly connected to a peripheral device.

1 = The four chip select lines are connected to a 4-to-16-bit decoder.

When PCSDEC equals one, up to 16 chip select signals can be generated with the four lines using an external 4-to-16bit decoder.

The Chip Select Register defines the characteristics of the 16 chips selected according to the following rules:

SP\_CSR0 defines peripheral chip select signals 0 to 3.

SP\_CSR1 defines peripheral chip select signals 4 to 7.

SP\_CSR2 defines peripheral chip select signals 8 to 11.

SP\_CSR3 defines peripheral chip select signals 12 to 15.

### MCK32: Clock Selection

- 0 = SPI master clock equals ACLK.
- 1 = SPI master clock equals ACLK/32.

### • LLB: Local Loopback Enable

- 0 = Local loopback path disabled.
- 1 = Local loopback path enabled.

LLB controls the local loopback on the data serializer for testing in master mode only.





### • PCS: Peripheral Chip Select

This field is only used if Fixed Peripheral Select is active (PS=0). If PCSDEC=0:

 $PCS = xxx0 \quad NPCS[3:0] = 1110$   $PCS = xx01 \quad NPCS[3:0] = 1101$   $PCS = x011 \quad NPCS[3:0] = 1011$   $PCS = 0111 \quad NPCS[3:0] = 0111$   $PCS = 1111 \quad forbidden (no peripheral is selected)$  (x = don't care)If PCSDEC=1: NPCS[3:0] output signals = PCS

### DLYBCS: Delay Between Chip Selects

This field defines the delay from NPCS inactive to the activation of another NPCS. The DLYBCS time guarantees nonoverlapping chip selects and solves bus contentions in case of peripherals having long data float times.

If DLYBCS is less than or equal to six, six SPI master clock periods will be inserted by default.

Otherwise, the following equation determines the delay:

Delay\_Between\_Chip\_Selects = DLYBCS × SPI\_Master\_Clock\_Period

| Register Name:<br>Access Type: | SP_RDR<br>Read-only |    |    |    |    |    |    |
|--------------------------------|---------------------|----|----|----|----|----|----|
| 31                             | 30                  | 29 | 28 | 27 | 26 | 25 | 24 |
| -                              | _                   | _  | _  | _  | -  | _  | -  |
| 23                             | 22                  | 21 | 20 | 19 | 18 | 17 | 16 |
| -                              | -                   | -  | _  |    | PC | S  |    |
| 15                             | 14                  | 13 | 12 | 11 | 10 | 9  | 8  |
|                                |                     |    | R  | lD |    |    |    |
| 7                              | 6                   | 5  | 4  | 3  | 2  | 1  | 0  |
|                                |                     |    | R  | lD |    |    |    |

## **SPI Receive Data Register**

### RD: Receive Data

Data received by the SPI interface is stored in this register right-justified. Unused bits read zero.

### PCS: Peripheral Chip Select Status

In master mode only, these bits indicate the value on the NPCS pins at the end of a transfer. Otherwise, these bits read as zero.



## **SPI Transmit Data Register**

| Register Name:<br>Access Type: | SP_TDR<br>Write-onl |    |    |    |    |    |    |
|--------------------------------|---------------------|----|----|----|----|----|----|
| 31                             | 30                  | 29 | 28 | 27 | 26 | 25 | 24 |
| -                              | -                   | _  | -  | _  | -  | _  | -  |
| 23                             | 22                  | 21 | 20 | 19 | 18 | 17 | 16 |
| -                              | -                   | _  | -  |    | PC | S  |    |
| 15                             | 14                  | 13 | 12 | 11 | 10 | 9  | 8  |
|                                |                     |    | Т  | D  |    |    |    |
| 7                              | 6                   | 5  | 4  | 3  | 2  | 1  | 0  |
|                                |                     |    | Т  | D  |    |    |    |

### • TD: Transmit Data

Data that is to be transmitted by the SPI interface is stored in this register. Information to be transmitted must be written to the transmit data register in a right-justified format.

### • PCS: Peripheral Chip Select

This field is only used if Variable Peripheral Select is active (PS = 1) and if the SPI is in master mode.

If PCSDEC = 0: PCS = xxx0 NPCS[3:0] = 1110 PCS = xx01 NPCS[3:0] = 1101 PCS = x011 NPCS[3:0] = 1011 PCS = 0111 NPCS[3:0] = 0111 PCS = 1111 forbidden (no peripheral is selected) (x = don't care) If PCSDEC = 1: NPCS[3:0] output signals = PCS





## **SPI Status Register**

| Register Name<br>Access Type: | : SP_SR<br>Read-on | ly |    |       |      |      |        |
|-------------------------------|--------------------|----|----|-------|------|------|--------|
| 31                            | 30                 | 29 | 28 | 27    | 26   | 25   | 24     |
| -                             | _                  | _  | -  | -     | -    | -    | _      |
| 23                            | 22                 | 21 | 20 | 19    | 18   | 17   | 16     |
| -                             | _                  | _  | -  | -     | -    | -    | SPIENS |
| 15                            | 14                 | 13 | 12 | 11    | 10   | 9    | 8      |
| -                             | _                  | _  | -  | -     | -    | -    | _      |
| 7                             | 6                  | 5  | 4  | 3     | 2    | 1    | 0      |
| -                             | _                  | _  | -  | OVRES | MODF | TDRE | RDRF   |

### RDRF: Receive Data Register Full

0 = No data has been received since the last read of SP\_RDR.

1 = Data has been received and the received data has been transferred from the serializer to SP\_RDR since the last read of SP\_RDR.

### • TDRE: Transmit Data Register Empty

0 = Data has been written to SP\_TDR and not yet transferred to the serializer.

1 = The last data written in the Transmit Data Register has been transferred in the serializer.

TDRE equals zero when the SPI is disabled or at reset. The SPI enable command sets this bit to one.

### • MODF: Mode Fault Error

- 0 = No mode fault has been detected since the last read of SP\_SR.
- 1 = A mode fault occurred since the last read of the SP\_SR.

### OVRES: Overrun Error Status

0 = No overrun has been detected since the last read of SP\_SR.

1 = An overrun has occurred since the last read of SP\_SR.

An overrun occurs when SP\_RDR is loaded at least twice from the serializer since the last read of the SP\_RDR.

### SPIENS: SPI Enable Status

- 0 = SPI is disabled.
- 1 = SPI is enabled.

# **SPI Interrupt Enable Register**

| Register Name<br>Access Type: | :: SP_IER<br>Write-on |    |    |       |      |      |      |
|-------------------------------|-----------------------|----|----|-------|------|------|------|
| 31                            | 30                    | 29 | 28 | 27    | 26   | 25   | 24   |
| -                             | -                     | -  | -  | -     | -    | -    | -    |
| 23                            | 22                    | 21 | 20 | 19    | 18   | 17   | 16   |
| -                             | _                     | -  | -  | -     | -    | -    | _    |
| 15                            | 14                    | 13 | 12 | 11    | 10   | 9    | 8    |
| -                             | _                     | _  | -  | -     | _    | _    | _    |
| 7                             | 6                     | 5  | 4  | 3     | 2    | 1    | 0    |
| -                             | _                     | _  | -  | OVRES | MODF | TDRE | RDRF |

- RDRF: Receive Data Register Full Interrupt Enable
  - 0 = No effect.
  - 1 = Enables the Receiver Data Register Full Interrupt.
- TDRE: SPI Transmit Data Register Empty Interrupt Enable
  - 0 = No effect.
  - 1 = Enables the Transmit Data Register Empty Interrupt.

### • MODF: Mode Fault Error Interrupt Enable

0 = No effect.

1 = Enables the Mode Fault Interrupt.

### • OVRES: Overrun Error Interrupt Enable

0 = No effect.

**Register Name:** 

1 = Enables the Overrun Error Interrupt.

SP\_IDR

## **SPI Interrupt Disable Register**

| Access Type: | Write-on | ly |    |       |      |      |      |
|--------------|----------|----|----|-------|------|------|------|
| 31           | 30       | 29 | 28 | 27    | 26   | 25   | 24   |
| -            | -        | -  | -  | -     | -    | -    | -    |
| 23           | 22       | 21 | 20 | 19    | 18   | 17   | 16   |
| _            | _        | -  | -  | -     | _    | _    | -    |
| 15           | 14       | 13 | 12 | 11    | 10   | 9    | 8    |
| -            | _        | -  | -  | -     | _    | _    | -    |
| 7            | 6        | 5  | 4  | 3     | 2    | 1    | 0    |
| -            | _        | -  | -  | OVRES | MODF | TDRE | RDRF |
|              |          |    |    |       |      |      |      |

### RDRF: Receive Data Register Full Interrupt Disable

0 = No effect.

1 = Disables the Receiver Data Register Full Interrupt.

### TDRE: Transmit Data Register Empty Interrupt Disable

0 = No effect.

1 = Disables the Transmit Data Register Empty Interrupt.





### • MODF: Mode Fault Interrupt Disable

0 = No effect.

- 1 = Disables the Mode Fault Interrupt.
- OVRES: Overrun Error Interrupt Disable
  - 0 = No effect.
  - 1 = Disables the Overrun Error Interrupt.

### **SPI Interrupt Mask Register**

| Register Name: | SP_IMR    |
|----------------|-----------|
| Access Type:   | Read-only |

| 31 | 30 | 29 | 28 | 27    | 26   | 25   | 24   |
|----|----|----|----|-------|------|------|------|
| _  | -  | —  | -  | -     | —    | —    | -    |
| 23 | 22 | 21 | 20 | 19    | 18   | 17   | 16   |
| _  | -  | _  | -  | -     | _    | _    | -    |
| 15 | 14 | 13 | 12 | 11    | 10   | 9    | 8    |
| _  | -  | -  | -  | -     | -    | -    | -    |
| 7  | 6  | 5  | 4  | 3     | 2    | 1    | 0    |
| -  | -  | _  | -  | OVRES | MODF | TDRE | RDRF |

### RDRF: Receive Data Register Full Interrupt Mask

- 0 = Receive Data Register Full Interrupt is disabled.
- 1 = Receive Data Register Full Interrupt is enabled.
- TDRE: Transmit Data Register Empty Interrupt Mask
   0 = Transmit Data Register Empty Interrupt is disabled.
   1 = Transmit Data Register Empty Interrupt is enabled.
- MODF: Mode Fault Interrupt Mask
  - 0 = Mode Fault Interrupt is disabled.
  - 1 = Mode Fault Interrupt is enabled.
- OVRES: Overrun Error Interrupt Mask
  - 0 = Overrun Error Interrupt is disabled.
  - 1 = Overrun Error Interrupt is enabled.

## **SPI Chip Select Register**

| Register Name:<br>Access Type: | SP_CSF<br>Read/wr | R0SP_CSR1<br>ite |     |      |    |       |      |
|--------------------------------|-------------------|------------------|-----|------|----|-------|------|
| 31                             | 30                | 29               | 28  | 27   | 26 | 25    | 24   |
|                                |                   |                  | DLY | 'BCT |    |       |      |
| 23                             | 22                | 21               | 20  | 19   | 18 | 17    | 16   |
|                                |                   |                  | DL  | YBS  |    |       |      |
| 15                             | 14                | 13               | 12  | 11   | 10 | 9     | 8    |
|                                |                   |                  | SC  | CBR  |    |       |      |
| 7                              | 6                 | 5                | 4   | 3    | 2  | 1     | 0    |
|                                | В                 | TS               |     | -    | _  | NCPHA | CPOL |

### • CPOL: Clock Polarity

0 = The inactive state value of SPCK is logic level zero.

1 = The inactive state value of SPCK is logic level one.

CPOL is used to determine the inactive state value of the serial clock (SPCK). It is used with NCPHA to produce a desired clock/data relationship between master and slave devices.

### • NCPHA: Clock Phase

0 = Data is changed on the leading edge of SPCK and captured on the following edge of SPCK.

1 = Data is captured on the leading edge of SPCK and changed on the following edge of SPCK.

NCPHA determines which edge of SPCK causes data to change and which edge causes data to be captured. NCPHA is used with CPOL to produce a desired clock/data relationship between master and slave devices.

### • BITS: Bits Per Transfer

The BITS field determines the number of data bits transferred. Reserved values should not be used.

| BITS[3:0] | Bits per Transfer |
|-----------|-------------------|
| 0000      | 8                 |
| 0001      | 9                 |
| 0010      | 10                |
| 0011      | 11                |
| 0100      | 12                |
| 0101      | 13                |
| 0110      | 14                |
| 0111      | 15                |
| 1000      | 16                |
| 1001      | Reserved          |
| 1010      | Reserved          |
| 1011      | Reserved          |
| 1100      | Reserved          |





| BITS[3:0] | Bits per Transfer |
|-----------|-------------------|
| 1101      | Reserved          |
| 1110      | Reserved          |
| 1111      | Reserved          |

### SCBR: Serial Clock Baud Rate

In master mode, the SPI interface uses a modulus counter to derive the SPCK baud rate from the SPI master clock (selected between ACLK and ACLK/32). The baud rate is selected by writing a value from 2 to 255 in the field SCBR. The following equation determines the SPCK baud rate:

 $SPCK\_Baud\_Rate = \frac{SPI\_Master\_Clock\_Frequency}{2 \times SCBR}$ 

Giving SCBR a value of zero or one disables the baud rate generator. SPCK is disabled and assumes its inactive state value. No serial transfers may occur. At reset, baud rate is disabled.

### DLYBS: Delay Before SPCK

This field defines the delay from NPCS valid to the first valid SPCK transition.

When DLYBS equals zero, the NPCS valid to SPCK transition is 1/2 the SPCK clock period.

Otherwise, the following equation determines the delay:

NPCS\_to\_SPCK\_Delay = DLYBS × SPI\_Master\_Clock\_Period

### DLYBCT: Delay Between Consecutive Transfers

This field defines the delay between two consecutive transfers with the same peripheral without removing the chip select. The delay is always inserted after each transfer and before removing the chip select if needed.

When DLYBCT equals zero, a delay of four SPI master clock periods is inserted.

Otherwise, the following equation determines the delay:

Delay\_after\_Transfer = 32 × DLYBCT × SPI\_Master\_Clock\_Period

## WD: Watchdog Timer

The AT75C310 has an internal watchdog timer which can be used to prevent system lock-up if the software becomes trapped in a deadlock. In normal operation, the user reloads the watchdog at regular intervals before the timer overflow occurs. If an overflow does occur, the watchdog timer generates one or a combination of the following signals depending on the parameters in WD\_OMR (Overflow Mode Register):

- If RSTEN is set, an internal reset is generated (WD\_RESET as shown in Figure 28).
- If IRQEN is set, a pulse is generated on the signal WDIRQ which is connected to the Advanced Interrupt Controller.
- If EXTEN is set, a low level is driven on the NWDOVF signal for a duration of eight ACLK cycles.

The watchdog timer has a 16-bit down counter. Bits 12 to 15 of the value loaded when the watchdog is restarted are programmable using the HPCV parameter in WD\_CMR (Clock Mode). Four clock sources are available to the watchdog counter: ACLK/8, ACLK/32, ACLK/128 or ACLK/1024. The selection is made using the WDCLKS parameter in WD\_CMR. This provides a programmable time-out period of 1.3 ms to 2.6 seconds with a 24 MHz system clock.

All write accesses are protected by control access keys to help prevent corruption of the watchdog should an error condition occur. To update the contents of the mode and control registers it is necessary to write the correct bit pattern to the control access key bits at the same time as the control bits are written (the same write access).



## Figure 28. Watchdog Timer Block Diagram

## WD User Interface

WD Base Address: 0xFF028000

| Offset | Register Description   | Register Name | Access     | Reset State |
|--------|------------------------|---------------|------------|-------------|
| 0x00   | Overflow Mode Register | WD_OMR        | Read/write | 0           |
| 0x04   | Clock Mode Register    | WD_CMR        | Read/write | 0           |
| 0x08   | Control Register       | WD_CR         | Write-only | _           |
| 0x0C   | Status Register        | WD_SR         | Read-only  | 0           |





## WD Overflow Mode Register

| Name:<br>Access:<br>Reset Value: | WD_OM<br>Read/wr<br>0 |    |    |       |       |       |      |
|----------------------------------|-----------------------|----|----|-------|-------|-------|------|
| 31                               | 30                    | 29 | 28 | 27    | 26    | 25    | 24   |
| -                                | _                     | _  | -  | -     | _     | _     | -    |
| 23                               | 22                    | 21 | 20 | 19    | 18    | 17    | 16   |
| _                                | _                     | _  | -  | _     | _     | _     | -    |
| 15                               | 14                    | 13 | 12 | 11    | 10    | 9     | 8    |
|                                  |                       |    | 0  | KEY   |       |       |      |
| 7                                | 6                     | 5  | 4  | 3     | 2     | 1     | 0    |
|                                  | OKEY                  |    |    | EXTEN | IRQEN | RSTEN | WDEN |

### • WDEN: Watchdog Enable

0 = Watchdog is disabled and does not generate any signals.

1 = Watchdog is enabled and generates enabled signals.

### RSTEN: Reset Enable

0 = Generation of an internal reset by the watchdog is disabled.

1 = When overflow occurs, the watchdog generates an internal reset.

### • IRQEN: Interrupt Enable

0 = Generation of an interrupt by the watchdog is disabled.

1 = When overflow occurs, the watchdog generates an interrupt.

### • EXTEN: External Signal Enable

0 = Generation of a pulse on the pin NWDOVF by the watchdog is disabled.

1 = When an overflow occurs, a pulse on the pin NWDOVF is generated.

### OKEY: Overflow Access Key

Used only when writing WD\_OMR. OKEY is read as 0. 0x234 = Write access in WD\_OMR is allowed.

Other value = Write access in WD\_OMR is prohibited.

## WD Clock Mode Register

| Name:<br>Access:<br>Reset Value: | WD_CM<br>Read/wr<br>0 |    |    |     |     |      |    |
|----------------------------------|-----------------------|----|----|-----|-----|------|----|
| 31                               | 30                    | 29 | 28 | 27  | 26  | 25   | 24 |
| -                                | _                     | _  | -  | _   | -   | _    | _  |
| 23                               | 22                    | 21 | 20 | 19  | 18  | 17   | 16 |
| _                                | _                     | _  | -  | _   | -   | -    | _  |
| 15                               | 14                    | 13 | 12 | 11  | 10  | 9    | 8  |
|                                  |                       |    | Cł | KEY |     |      |    |
| 7                                | 6                     | 5  | 4  | 3   | 2   | 1    | 0  |
| CKEY                             | _                     |    | HF |     | WDO | CLKS |    |

### • WDCLKS: Clock Selection

| WDC | CLKS | Clock Selected |
|-----|------|----------------|
| 0   | 0    | ACLK/8         |
| 0   | 1    | ACLK/32        |
| 1   | 0    | ACLK/128       |
| 1   | 1    | ACLK/1024      |

### HPCV: High Preload Counter Value

Counter is preloaded when watchdog counter is restarted with bits 0 to 11 set (FFF) and bits 12 to 15 equaling HPCV.

### • CKEY: Clock Access Key

Used only when writing WD\_CMR. CKEY is read as 0. 0x06E: Write access in WD\_CMR is allowed. Other value: Write access in WD\_CMR is prohibited.

## **WD Control Register**

| Name:<br>Access: | WD_CR<br>Write-onl | у  |    |      |    |    |    |
|------------------|--------------------|----|----|------|----|----|----|
| 31               | 30                 | 29 | 28 | 27   | 26 | 25 | 24 |
| _                | -                  | _  | -  | -    | -  | _  | -  |
| 23               | 22                 | 21 | 20 | 19   | 18 | 17 | 16 |
| _                | -                  | _  | -  | -    | -  | _  | -  |
| 15               | 14                 | 13 | 12 | 11   | 10 | 9  | 8  |
|                  |                    |    | RS | TKEY |    |    |    |
| 7                | 6                  | 5  | 4  | 3    | 2  | 1  | 0  |
|                  |                    |    | RS | TKEY |    |    |    |

### • RSTKEY: Restart Key

0xC071 = Watchdog counter is restarted. Other value = No effect.





## **WD Status Register**

| Name:<br>Access: |    | WD_SR<br>Read-only |    |    |    |    |       |  |  |  |  |  |
|------------------|----|--------------------|----|----|----|----|-------|--|--|--|--|--|
| 31               | 30 | 29                 | 28 | 27 | 26 | 25 | 24    |  |  |  |  |  |
| -                | -  | _                  | _  | _  | _  | -  | _     |  |  |  |  |  |
| 23               | 22 | 21                 | 20 | 19 | 18 | 17 | 16    |  |  |  |  |  |
| -                | -  | _                  | _  | _  | _  | -  | _     |  |  |  |  |  |
| 15               | 14 | 13                 | 12 | 11 | 10 | 9  | 8     |  |  |  |  |  |
| _                | -  | _                  | -  | _  | _  | -  | -     |  |  |  |  |  |
| 7                | 6  | 5                  | 4  | 3  | 2  | 1  | 0     |  |  |  |  |  |
| _                | _  | _                  | -  | _  | _  | -  | WDOVF |  |  |  |  |  |

## • WDOVF: Watchdog Overflow

0 = No watchdog overflow.

1 = A watchdog overflow has occurred since the last restart of the watchdog counter or since internal or external reset.



## **WD Enabling Sequence**

To enable the watchdog timer the sequence is as follows:

- Disable the watchdog by clearing the bit WDEN: Write 0x2340 to WD\_OMR This step is unnecessary if the WD is already disabled (reset state).
- Initialize the WD Clock Mode Register: Write 0x373C to WD\_CMR (HPCV = 15 and WDCLKS = MCK/8)

- Restart the timer: Write 0xC071 to WD\_CR
- 4. Enable the watchdog: Write 0x2345 to WD\_OMR (interrupt enabled)





# **Dual-port Mailbox**

Communication between the asynchronous ARM7TDMI and OakDSPCore are via the dual-port mailbox (DPMB). It is assumed that each processor is running asynchronously and that the coherency of communication is maintained by robust software.

The DPMB consists of 512 bytes of DPRAM and some memory-mapped registers that configure the DPMB and act as semaphores. The DPMB sits on the ARM7TDMI ASB bus and can be accessed by memory-mapped operations. Similarly, the DPMB also sits on the OakDSPCore data bus and can be accessed by memory-mapped operations.

Messages can be sent between the two processors by the sending processor writing data to the DPRAM in the DPMB and signalling via the semaphores. The data is subsequently read by the recipient processor. Individual mailboxes are bi-directional with access permission controlled by the semaphores. The message-passing protocol can be configured for each mailbox as interrupt-driven or polled in each direction.



## **Dual-port RAM**

The major component of the DPMB is a dual-port RAM (DPRAM). It consists of 256 x 16 bits of dual-port static RAM. The DPRAM is divided into eight equal mailboxes, each with its own semaphore register. The hardware implements locks so that both processors never have write access to the same mailbox region. This protection mechanism is based upon the values of the semaphores, which must be maintained by the software.

If a processor attempts to access a mailbox to which it does not have semaphore permission, then this access will be ignored.

The DPMB supports word access from the ARM side provided the address is word-aligned, and half-word access from both the ARM and Oak sides provided the address is half-word-aligned. All other accesses will result in a data abort being issued. The DPMB does not decode protection information carried in AMBA output BPROT[1:0] and, as a result, does not support Thumb-compiled code.

In order to reduce hardware, the minimum number of address bits are used in decoding register and mailbox addresses. This results in address aliasing. For the ARM side, only address bits ba[5:2] and ba[9] are used in register decode and bits ba[8:5] in mailbox decode. On the Oak side, only address bits dxap[2:0] are used in register decode and bits dxap[7:4] are used in mailbox decode.





### **Semaphore Operation**

The DPMB supports semaphore registers to facilitate asynchronous communication between two processors. Each of the eight mailboxes has its own memory-mapped semaphore register. This avoids any need for complex readmodify-write operations. Each semaphore is configured to control message-passing in a single direction, i.e., from the ARM to the Oak when the DPMB ARM-to-Oak flag is set high. When this flag is low, then the direction of transfer is Oak to ARM.

A semaphore can be configured to support interrupts or polling in either direction. The ARM Interrupt Enable (AIE) flag determines if interrupts are raised to the ARM when an associated semaphore operation occurs. Similarly, the Oak Interrupt Enable (OIE) flag determines if an interrupt is raised to the Oak when an associated semaphore operation occurs.

There are no hardware-read restrictions to any semaphore for either processor. This allows a semaphore to be polled freely. However, the software is expected to maintain message-level synchronization and not attempt to write to the same semaphore at the same time. Because the two processors may run asynchronously, the semaphores are resynchronized to the clock domains of both processors and, hence, cycle accuracy is not maintained.

At reset, all semaphores are reset low.

Each semaphore can be set or cleared by either processor by performing a write operation to the semaphore register. A set operation (write high) sets the semaphore register to high and a clear operation (write low) sets the semaphore low. However, a semaphore operation can also raise or clear interrupts, depending on which processor performs the operation and which processor has been enabled as the sender processor. The semantics of semaphore operations are presented in Table 22.

| Operation | ARM to Oak High                                               | ARM to Oak Low                                                |
|-----------|---------------------------------------------------------------|---------------------------------------------------------------|
| ARM Set   | Set Semaphore<br>Raise Oak Interrupt                          | Set Semaphore<br>Clear ARM Interrupt                          |
| ARM Clear | Clear Semaphore<br>Clear ARM Interrupt                        | Clear Semaphore<br>Clear ARM Interrupt<br>Raise Oak Interrupt |
| Oak Set   | Set Semaphore<br>Clear Oak Interrupt                          | Set Semaphore<br>Raise ARM Interrupt                          |
| Oak Clear | Clear Semaphore<br>Clear Oak Interrupt<br>Raise ARM Interrupt | Clear Semaphore<br>Clear Oak Interrupt                        |

Table 22. Semaphore Operations Semantics





## **DPMB Register Map**

## Table 23. ARM Registers

| Register Address                  |                             | Register |          |          |          |          |            |
|-----------------------------------|-----------------------------|----------|----------|----------|----------|----------|------------|
| (Offset from Base) <sup>(1)</sup> | <b>Register Description</b> | Name     | Config 0 | Config 1 | Config 2 | Config 3 | Access     |
| 0x200                             | Mailbox Semaphore 0         | DPMBS0   | 0x000    | 0x000    | 0x000    | 0x000    | Read/write |
| 0x204                             | Mailbox Semaphore 1         | DPMBS1   | 0x040    | 0x0E0    | 0x080    | _        | Read/write |
| 0x208                             | Mailbox Semaphore 2         | DPMBS2   | 0x080    | 0x100    | 0x100    | _        | Read/write |
| 0x20C                             | Mailbox Semaphore 3         | DPMBS3   | 0x0C0    | 0x120    | 0x140    | _        | Read/write |
| 0x210                             | Mailbox Semaphore 4         | DPMBS4   | 0x100    | 0x160    | 0x180    | _        | Read/write |
| 0x214                             | Mailbox Semaphore 5         | DPMBS5   | 0x140    | 0x1A0    | 0x1A0    | _        | Read/write |
| 0x218                             | Mailbox Semaphore 6         | DPMBS6   | 0x180    | 0x1C0    | 0x1C0    | _        | Read/write |
| 0x21C                             | Mailbox Semaphore 7         | DPMBS7   | 0x1C0    | 0x1E0    | 0x1E0    | _        | Read/write |
| 0x220                             | Mailbox Configuration       | DPMBCC   |          |          |          |          | Read/write |

Note: 1. Base address is 0xFA000000 for OakA and 0xFB000000 for OakB.

## Table 24. Oak Registers

|                  |                             | Register | Mailbox Base Address |          |          |          |            |
|------------------|-----------------------------|----------|----------------------|----------|----------|----------|------------|
| Register Address | <b>Register Description</b> | Name     | Config 0             | Config 1 | Config 2 | Config 3 | Access     |
| 0xE800           | Mailbox Sempahore 0         | DPMBS0   | 0xE000               | 0xE000   | 0xE000   | 0xE000+  | Read/write |
| 0xE801           | Mailbox Semaphore 1         | DPMBS1   | 0xE020               | 0xE070   | 0xE040   | Ι        | Read/write |
| 0xE802           | Mailbox Semaphore 2         | DPMBS2   | 0xE040               | 0xE080   | 0xE080   | -        | Read/write |
| 0xE803           | Mailbox Semaphore 3         | DPMBS3   | 0xE080               | 0xE090   | 0xE0A0   | _        | Read/write |
| 0xE804           | Mailbox Semaphore 4         | DPMBS4   | 0xE0A0               | 0xE0B0   | 0xE0C0   | _        | Read/write |
| 0xE805           | Mailbox Semaphore 5         | DPMBS5   | 0xE0C0               | 0xE0D0   | 0xE0D0   | _        | Read/write |
| 0xE806           | Mailbox Semaphore 6         | DPMBS6   | 0xE0E0               | 0xE0E0   | 0xE0E0   | _        | Read/write |
| 0xE807           | Mailbox Semaphore 7         | DPMBS7   | 0xE100               | 0xE0F0   | 0xE0F0   | -        | Read/write |

## **DPMB Semaphore Registers**

The semaphore registers look the same from the ARM and the Oak sides.

| 31 | 30 | 29 | 28 | 27 | 26  | 25  | 24  |
|----|----|----|----|----|-----|-----|-----|
| -  | _  | _  | _  | _  | _   | _   | -   |
| 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16  |
| -  | _  | _  | _  | _  | _   | _   | -   |
| 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8   |
| _  | _  | _  | _  | _  | _   | _   | -   |
| 7  | 6  | 5  | 4  | 3  | 2   | 1   | 0   |
| -  | _  | -  | -  | -  | OIS | AIS | Sem |

### Sem: Semaphore

When low, the sender has read and write permission to the mailbox. The recipient has no permission to read or write the associated mailbox. When high, the recipient has read and write permission to the mailbox and the sender has no permission.

### AIS: ARM Interrupt Status

This flag indicates the value of the ARM interrupt flag. This is a read-only bit; any attempt to write to this bit will be ignored.

### • OIS: Oak Interrupt Status

This flag indicates the value of the Oak interrupt flag. This is a read-only bit; any attempt to write to this bit will be ignored.

## **DPMB Configuration Register**

The DPMB is configured by means of a memory-mapped register that sits on the ARM ASB bus. This register is not accessible by the Oak.

| 31    | 30        | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |  |
|-------|-----------|----|----|----|----|----|----|--|--|--|--|
| RESET | MB_CONFIG |    | _  | _  | _  | _  | -  |  |  |  |  |
| 23    | 22        | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |  |
|       | OIE       |    |    |    |    |    |    |  |  |  |  |
| 15    | 14        | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |  |
|       | AIE       |    |    |    |    |    |    |  |  |  |  |
| 7     | 6         | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |  |
|       | ATO       |    |    |    |    |    |    |  |  |  |  |

### • ATO[7:0]: ARM To Oak

The value of this flag conditions the semantics of semaphore operation for the associated mailbox. When high, the ARM is the sender and the Oak is the recipient. When low, the Oak is the sender and the ARM is the recipient.

### • AIE[15:8]: ARM Interrupt Enable

When high, appropriate semaphore operations can raise an interrupt to the ARM. When low, interrupts are never raised by any semaphore operation.

### OIE[23:16]: Oak Interrupt Enable

When high, appropriate semaphore operations can raise an interrupt to the ARM. When low, interrupts are never raised by any semaphore operation.

### MB\_CONFIG[30:29]: Mailbox Configuration

Selects one of four possible mailbox configurations. Refer to Table 23.

### RESET

When a high is written to this bit, the DPMB is reset to its initial state, ready for the configuration to be set.





## Assembly Source Code – Boot Program

```
_____
;Cadence Design Systems Ltd. Copyright 1999. All Rights Reserved.
,_____
; MODULE:
            bootcode.s
;CREATION DATE: 26 Feb 1999
; AUTHOR:
            Kevin Robertson
; DESCRIPTION:
       This file contains the code to go into the SIAP bootrom - it is used by all the
       bootrom tests which use a GET to include this file. If the bootrom is changed then all
       the boot tests MUST be rerun to check the change.
;CHANGE HISTORY:
;26 Feb 1999
;Initial version
;3 May 1999
;Final Version - changed wait count to the required value for a 3 sec timeout and reduced Baudrate down to
;9600.
;------
           AREA bootrom, CODE, READONLY
;
;----- List of constants and types -----
ARM_MODE_SVC EQU
                 0x13
I_BIT
          EOU
                 0x80
F_BIT
           EQU
                 0x40
;- The WAIT_TIME is for a 3 second wait. The value is calculated from the cycle count of the loop
;- rx_ poll_timed of 13 and a clock period of 41.47nS. This gives the time for a count of 1 as 542nS.
;-3 Secs/542nS = 0x54754f.
          EQU
WAIT_TIME
                 0x0054754F
RAM_BASE
          EQU
                 0xFD000000
           EQU
                 4096
RAM_SIZE
RAM LIMIT
           EQU
                RAM_BASE + RAM_SIZE
;----- List of Imported resources -----
;----- List of Internal resources -----
•-----
    Define the vector table.
;
    The reset vector jumps to the handler code.
;
    All others just dead loop on themselves!
;
;-----
reset
 B InitReset ; reset
undefvec
 B undefvec ; Undefined
swivec
 B swivec ; SW IRQ
pabtvec
 B pabtvec ; Program abort
dabtvec
 B pabtvec ; Program abort
dabtvec
 B rsvdvec ; reserved
irqvec
 B irqvec ; IRQ
fiqvec
```

```
B fiqvec ; FIQ
; Entry point.
;------
InitReset
; Setup the SVC mode and stack pointer on the top of the internal RAM
     mov rO, #ARM - MODE_SVC:OR:I_BIT:OR:F_BIT ; No interrupts
     msr cpsr, r0
     ldr r13, =RAM-LIMIT
,_____
; Configure USARTO with the following parameters:
   Baud Rate 9600
;
   Mode: 1 Stop bit, Even Parity, 8 Data Bits, Clock = MCKI
;
        Channel = Normal Mode
ldr rl, USARTO-CR-Reg
                      ; Disable and Reset the Transmitter and Receiver
  ldr r2, = OXAC
  str r2, [r1]
  ldr rl, USARTO_MR-Reg
                       ; Set up the mode register with the
  ldr r2,
       = OXCO
                       ; parameters given above.
  str r2, [r1]
  ldr rl, USARTO_ID_Reg
                      ; Disable All Interrupts
  ldr r2, = 0x7FF
  str r2, [r1]
  ldr rl, USARTO_BR_Reg
                       ; Setup the Baud Rate to 9600bps
  ldr r2, = 0x9C
  str r2, [r1]
  ldr rl, USARTO_CR.Reg
                      ; Enable the transmitter and receiver
  1dr r2, = 0x50
  str r2, [r1]
,_____
; Read Modem Status and check that DSR is set. If it is not set then remap
;-----
  ldr rl, USARTO-ModS_Reg
  ldr r2, [r1]
  tst r2, #0x20
  beg remap
;_____
; Set RTS which indicates to the other end that we have seen the DSR and can proceed.
ldr rl, USARTO_ModC_Reg
  ldr r2, =0x02
  str r2, (r1]
•-----
; Setup a value in r6 for the TIMEOUT. If this value goes to zero then this
; code performs a REMAP booting from CSO.
;-----
  ldr r6, = WAIT_TIME
; Read the Initial sequence from the USART. The code will branch to REMAP if
; it has to wait for longer than approx 3 secs, or if any of the received
; characters are incorrect.
;------
```





```
bl rx-poll-timed
   cmp r2, #0x16
   bne remap
;
; A synch has been received look for the rest of the activation sequence
;
   bl rx_poll_timed
   cmp r2, #0x42
   bne remap
   bl rx_poll_timed
   cmp, r2, #Ox6f
   bne remap,
   bl rx_poll_timed
   cmp r2, #0x6f
   bne remap,
   bl rx_poll_timed
   cmp r2, #0x74
   bne remap
   bl rx_poll_timed
   cmp r2, #Ox16
   bne remap
   ;Activation sequence received send the response
   mov r2, #0x16
   bl sendbyte
   mov r2, #0x52
   bl send_byte
   mov r2, #0x4f
   bl send_byte
   mov r2, #0x4d
   bl send_byte
   mov r2, #0x16
   bl send_byte
   ; Read the 16 bit length most significant byte first
   bl rx_poll mov r3, r2, LSL #8
   bl rx_poll
   add r3, r3, r2
   ; Respond with the received length
   mov r2, r3, lsr #8
   bl sendbyte
   mov r2, r3
   bl send_byte
   ; Put the downloaded code in the SRAM
   mov r6, #RAM_BASE
;-----
; Now download all the code bytes. Every time a byte is read it is X'ored with
; the previous total to get a checksum. Each group of four bytes is shifted in
; to form a word which is then copied to the Oak PRAM.
mov r5, #0
   cmp r3, #0
read.loop
   beq sendcsum
   ; Read 4 bytes to form a little endian 32 bit value
   bl rx_poll
   eor r5, r5, r2
   mov r4, r2
   bl rx_poll
```

```
eor r5, r5, r2
  mov r2, r2, LSL #8
  orr r4, r4, r2
  bl rx_poll
  eor r5, r5, r2
  mov r2, r2, LSL #16
  orr r4, r4, r2
  bl rx_poll eor r5, r5, r2
  mov r2, r2, LSL #24
  orr r4, r4, r2
   ; Store the 32 bit value
  str r4, [r61, #4
   ; decrement the counter
  subs r3, r3, #4
  b read_loop
; End of the Down Load Loop. Now wait for DSR to reset then send the checksum
; for the values which have just been downloaded.
; Read Modem Status and check that DSR has been reset.
waitDSR
  ldr rl, USARTO_ModS_Reg
  ldr r2, [r1]
  teq r2,#0x20
  bne waitDSR
send-csum
  mov r2, r5
  bl send-byte
   ; Reset RTS
  ldr rl, USARTO_ModC_Reg
  ldr r2, = 0x00
  str r2, [r1]
   ; Wait for the execute command
  bl rx_poll
  cmp r2, #0x47
  bne fail_loop
  bl rx_poll
  cmp r2, #0x6f
  bne fail_loop
   ; Acknowledge
  mov r2, #0x06
  bl send_byte
   ; And Go for it ...
  mov r6, #RAM_BASE
  mov pc, r6
;-----
; rx_poll_timed
; Wait for a character to be received. The wait is limited by the Timeout
; value in register r6, if this value goes to zero then the code
; jumps to REMAP.
;
; Trashes rl, r2
;-----r
rx_poll-timed
  subs r6, r6, #0x01
  beq remap
  ldr rl, USARTO_CSR_Reg
  ldr rl, [r1]
```





```
tst rl, #0x01
  beq rx_poll_timed
  ldr rl, USARTO_RHR_Reg
  ldr r2, [r1]
  mov pc, lr
;------
; rx_poll
; Wait for a character to be received. The wait is not time limited
; Trashes rl, r2
;-----r
rx_poll
  ldr rl, USARTO_CSR_Reg
  ldr rl, [r1]
  tst rl, #0x01
  beq rx_poll
  ldr rl, USARTO - RHR_Reg
  ldr r2, [r1]
  mov pc, lr
;-----
; send-byte
; Wait for TXRDY then write the byte in r2
; Trashes rl
;-----s
send-byte
  ldr rl, USARTO_CSR_Reg
  ldr rl, [rl]
  tst rl, #0x02
  beq send_byte
  ldr rl, USARTO_THR_Reg
  str r2, [r1]
  mov PC, lr
;------
; Fail Loop - If any problem that can't be solved arises in the code then
; branch to here.
;-----
fail-loop
    B fail-loop
;_____
; remap - Code will jump here if there is a timeout on receiving the first
; byte of data, or there is an error in the initial sequence. Set the REMAP
; bit in the SIAP register, then set the PC to 0 - this will map in the memory at CSO
;-----
remap
  ldr rl, SIAP_Mode_Reg
  ldr r2, = 0x01
  str r2, [r1]
  mov PC, #OXOO
; USARTO Register Definitions
;------
USARTO_CR_Reg
  DCD OxFF018000
USARTO_MR_Reg
  DCD 0xFF018004
USARTO_ID_Reg
```

DCD OxFF01800C USARTO\_CSR\_Reg DCD OxFF018014 USARTO\_RHR\_Reg DCD OxFF018018 USARTO\_THR\_Reg DCD OxFF01801C USARTO\_BR\_Reg DCD OxFF018020 USARTO\_ModC\_Reg DCD OxFF018040 USARTO\_ModS\_Reg DCD OxFF018044 SIAP\_Mode\_Reg DCD OxFF000000 END





## **Atmel Headquarters**

Corporate Headquarters 2325 Orchard Parkway San Jose, CA 95131 TEL (408) 441-0311 FAX (408) 487-2600

#### Europe

Atmel SarL Route des Arsenaux 41 Casa Postale 80 CH-1705 Fribourg Switzerland TEL (41) 26-426-5555 FAX (41) 26-426-5500

#### Asia

Atmel Asia, Ltd. Room 1219 Chinachem Golden Plaza 77 Mody Road Tsimhatsui East Kowloon Hong Kong TEL (852) 2721-9778 FAX (852) 2722-1369

### Japan

Atmel Japan K.K. 9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033 Japan TEL (81) 3-3523-3551 FAX (81) 3-3523-7581

## **Atmel Operations**

Atmel Colorado Springs 1150 E. Cheyenne Mtn. Blvd. Colorado Springs, CO 80906 TEL (719) 576-3300 FAX (719) 540-1759

#### Atmel Rousset

Zone Industrielle 13106 Rousset Cedex France TEL (33) 4-4253-6000 FAX (33) 4-4253-6001

### Atmel Smart Card ICs

Scottish Enterprise Technology Park East Kilbride, Scotland G75 0QR TEL (44) 1355-357-000 FAX (44) 1355-242-743

#### Atmel Grenoble

Avenue de Rochepleine BP 123 38521 Saint-Egreve Cedex France TEL (33) 4-7658-3243 FAX (33) 4-7658-3320

### *Fax-on-Demand* North America: 1-(800) 292-8635 International:

1-(408) 441-0732

*e-mail* literature@atmel.com

Web Site http://www.atmel.com

BBS 1-(408) 436-4309



#### © Atmel Corporation 2001.

Atmel Corporation makes no warranty for the use of its products, other than those expressly contained in the Company's standard warranty which is detailed in Atmel's Terms and Conditions located on the Company's web site. The Company assumes no responsibility for any errors which may appear in this document, reserves the right to change devices or specifications detailed herein at any time without notice, and does not make any commitment to update the information contained herein. No licenses to patents or other intellectual property of Atmel are granted by the Company in connection with the sale of Atmel products, expressly or by implication. Atmel's products are not authorized for use as critical components in life support devices or systems.

ARM, Thumb and ARM Powered are registered trademarks of ARM Limited. ARM7TDMI is a trademark of ARM Limited. OakDSPCore is a registered trademark of DSP Group, Inc. Marks bearing <sup>®</sup> and/or <sup>™</sup> are registered trademarks and trademarks of Atmel Corporation.



, , , ,

Terms and product names in this document may be trademarks of others.

1369A-01/01/0M