



# ISD Cortex™-M0 ChipCorder ISD9160 Design Guide

The information described in this document is the exclusive intellectual property of Nuvoton Technology Corporation and shall not be reproduced without permission from Nuvoton.

Nuvoton is providing this document only for reference purposes of ISD ChipCorder microcontroller based system design. Nuvoton assumes no responsibility for errors or omissions.

All data and specifications are subject to change without notice.

For additional information or questions, please contact: Nuvoton Technology Corporation.

**Table of Contents-**

|                          |                                                        |     |
|--------------------------|--------------------------------------------------------|-----|
| TABLE OF CONTENTS- ..... |                                                        | 2   |
| 1                        | GENERAL DESCRIPTION .....                              | 7   |
| 2                        | FEATURES .....                                         | 8   |
| 3                        | PART INFORMATION AND PIN CONFIGURATION .....           | 11  |
| 3.1                      | Pin Configuration .....                                | 11  |
| 3.1.1                    | ISD9160 LQFP 48 pin.....                               | 11  |
| 3.1.2                    | Pin Description.....                                   | 11  |
| 4                        | BLOCK DIAGRAM .....                                    | 16  |
| 5                        | FUNCTIONAL DESCRIPTION.....                            | 17  |
| 5.1                      | ARM® Cortex™-M0 core.....                              | 17  |
| 5.2                      | System Manager.....                                    | 18  |
| 5.2.1                    | Overview.....                                          | 18  |
| 5.2.2                    | System Reset .....                                     | 18  |
| 5.2.3                    | System Power Distribution.....                         | 19  |
| 5.2.4                    | System Memory Map .....                                | 20  |
| 5.2.5                    | System Manager Control Registers .....                 | 22  |
| 5.2.6                    | System Timer (SysTick).....                            | 34  |
| 5.2.7                    | Nested Vectored Interrupt Controller (NVIC) .....      | 37  |
| 5.2.8                    | System Control Registers .....                         | 55  |
| 5.3                      | Clock Controller and Power Management Unit (PMU) ..... | 62  |
| 5.3.1                    | Clock Generator.....                                   | 62  |
| 5.3.2                    | System Clock & SysTick Clock .....                     | 63  |
| 5.3.3                    | Peripheral Clocks.....                                 | 64  |
| 5.3.4                    | Power Management.....                                  | 64  |
| 5.3.5                    | Clock Control Register Map .....                       | 66  |
| 5.3.6                    | Clock Control Register Description .....               | 67  |
| 5.4                      | General Purpose I/O .....                              | 79  |
| 5.4.1                    | Overview and Features.....                             | 80  |
| 5.4.2                    | GPIO I/O Modes .....                                   | 80  |
| 5.4.3                    | GPIO Control Register Map .....                        | 82  |
| 5.4.4                    | GPIO Control Register Description .....                | 83  |
| 5.5                      | Brownout Detection and Temperature Alarm .....         | 93  |
| 5.5.1                    | Brownout and Temperature Alarm Register Map.....       | 93  |
| 5.6                      | I2C Serial Interface Controller (Master/Slave) .....   | 99  |
| 5.6.1                    | Introduction .....                                     | 99  |
| 5.6.2                    | I2C Protocol Registers .....                           | 103 |
| 5.6.3                    | Register Mapping.....                                  | 106 |
| 5.6.4                    | Register Description.....                              | 107 |
| 5.6.5                    | Modes of Operation .....                               | 114 |
| 5.6.6                    | Data Transfer Flow in Five Operating Modes .....       | 115 |
| 5.7                      | PWM Generator and Capture Timer.....                   | 121 |
| 5.7.1                    | Introduction .....                                     | 121 |
| 5.7.2                    | Features.....                                          | 122 |
| 5.7.3                    | PWM Generator Architecture .....                       | 123 |

|        |                                                               |     |
|--------|---------------------------------------------------------------|-----|
| 5.7.4  | PWM-Timer Operation .....                                     | 123 |
| 5.7.5  | PWM Double Buffering, Auto-reload and One-shot Operation..... | 125 |
| 5.7.6  | Modulate Duty Cycle.....                                      | 125 |
| 5.7.7  | Dead-Zone Generator.....                                      | 126 |
| 5.7.8  | Capture Timer Operation .....                                 | 127 |
| 5.7.9  | PWM-Timer Interrupt Architecture .....                        | 128 |
| 5.7.10 | PWM-Timer Initialization Procedure.....                       | 128 |
| 5.7.11 | PWM-Timer Stop Procedure.....                                 | 128 |
| 5.7.12 | Capture Start Procedure .....                                 | 129 |
| 5.7.13 | Register Map .....                                            | 130 |
| 5.7.14 | Register Description.....                                     | 131 |
| 5.8    | Real Time Clock (RTC).....                                    | 143 |
| 5.8.1  | Overview.....                                                 | 143 |
| 5.8.2  | RTC Features .....                                            | 143 |
| 5.8.3  | RTC Block Diagram .....                                       | 144 |
| 5.8.4  | RTC Function Description.....                                 | 145 |
| 5.8.5  | Register Map .....                                            | 147 |
| 5.8.6  | Register Description.....                                     | 148 |
| 5.9    | Serial Peripheral Interface (SPI) Controller .....            | 161 |
| 5.9.1  | Overview.....                                                 | 161 |
| 5.9.2  | Features.....                                                 | 161 |
| 5.9.3  | SPI Block Diagram .....                                       | 161 |
| 5.9.4  | SPI Function Descriptions.....                                | 162 |
| 5.9.5  | SPI Timing Diagram.....                                       | 169 |
| 5.9.6  | SPI Configuration Examples .....                              | 172 |
| 5.9.7  | SPI Serial Interface Control Register Map .....               | 174 |
| 5.9.8  | SPI Control Register Description .....                        | 175 |
| 5.10   | Timer Controller .....                                        | 182 |
| 5.10.1 | General Timer Controller .....                                | 182 |
| 5.10.2 | Features.....                                                 | 182 |
| 5.10.3 | Timer Controller Block Diagram .....                          | 183 |
| 5.10.4 | Timer Controller Register Map .....                           | 184 |
| 5.11   | Watchdog Timer.....                                           | 190 |
| 5.11.1 | Watchdog Timer Control Registers Map .....                    | 192 |
| 5.12   | UART Interface Controller .....                               | 194 |
| 5.12.1 | Overview.....                                                 | 194 |
| 5.12.2 | Features of UART controller .....                             | 196 |
| 5.12.3 | Block Diagram .....                                           | 197 |
| 5.12.4 | IrDA Mode.....                                                | 199 |
| 5.12.5 | LIN (Local Interconnection Network) mode .....                | 201 |
| 5.12.6 | UART Interface Control Register Map .....                     | 202 |
| 5.12.7 | UART Interface Control Register Description .....             | 203 |
| 5.13   | I2S Audio PCM Controller.....                                 | 224 |
| 5.13.1 | Overview.....                                                 | 224 |
| 5.13.2 | Features.....                                                 | 224 |
| 5.13.3 | I2S Block Diagram .....                                       | 225 |
| 5.13.4 | I2S Operation.....                                            | 226 |

|        |                                               |     |
|--------|-----------------------------------------------|-----|
| 5.13.5 | FIFO operation.....                           | 227 |
| 5.13.6 | I2S Control Register Map.....                 | 228 |
| 5.13.7 | I2S Control Register Description.....         | 229 |
| 5.14   | Cyclic Redundancy Check (CRC) Controller..... | 239 |
| 5.14.1 | Overview and Features.....                    | 239 |
| 5.14.2 | Operation .....                               | 239 |
| 5.14.3 | Example.....                                  | 239 |
| 5.14.4 | CRC Controller Register Map .....             | 240 |
|        | CRC Control Register Description.....         | 241 |
| 5.15   | PDMA Controller .....                         | 245 |
| 5.15.1 | Overview.....                                 | 245 |
| 5.15.2 | Features.....                                 | 245 |
| 5.15.3 | Block Diagram .....                           | 245 |
| 5.15.4 | Function Description .....                    | 246 |
| 5.15.5 | PDMA Controller Register Map.....             | 247 |
| 5.15.6 | PDMA Control Register Description.....        | 248 |
| 6      | FLASH MEMORY CONTROLLER (FMC) .....           | 260 |
| 6.1    | Overview .....                                | 260 |
| 6.2    | Features.....                                 | 260 |
| 6.3    | Flash Memory Controller Block Diagram.....    | 261 |
| 6.4    | Flash Memory Organization.....                | 262 |
| 6.5    | Boot Selection.....                           | 263 |
| 6.6    | Data Flash (DATAF) .....                      | 263 |
| 6.7    | User Configuration (CONFIG) .....             | 264 |
| 6.8    | In-System Programming (ISP) .....             | 265 |
| 6.8.1  | ISP Procedure .....                           | 265 |
| 6.9    | Flash Control Register Map .....              | 268 |
| 6.10   | Flash Control Register Description .....      | 269 |
| 7      | ANALOG SIGNAL PATH BLOCKS.....                | 274 |
| 7.1    | Audio Analog-to-Digital Converter (ADC) ..... | 274 |
| 7.1.1  | Functional Description .....                  | 274 |
| 7.1.2  | Features.....                                 | 274 |
| 7.1.3  | Block Diagram .....                           | 274 |
| 7.1.4  | Operation .....                               | 275 |
| 7.1.5  | ADC Register Map .....                        | 277 |
| 7.1.6  | ADC Register Description .....                | 278 |
| 7.2    | Audio Class D Speaker Driver (DPWM) .....     | 282 |
| 7.2.1  | Functional Description .....                  | 282 |
| 7.2.2  | Features.....                                 | 282 |
| 7.2.3  | Block Diagram .....                           | 282 |
| 7.2.4  | Operation .....                               | 283 |
| 7.2.5  | DPWM Register Map .....                       | 284 |
| 7.2.6  | DPWM Register Description .....               | 285 |
| 7.3    | Analog Comparator.....                        | 288 |

|        |                                                             |     |
|--------|-------------------------------------------------------------|-----|
| 7.3.1  | Functional Description .....                                | 288 |
| 7.3.2  | Features.....                                               | 288 |
| 7.3.3  | Block Diagram .....                                         | 288 |
| 7.3.4  | Operational Procedure.....                                  | 289 |
| 7.3.5  | Register Map .....                                          | 289 |
| 7.3.6  | Register Description.....                                   | 290 |
| 7.4    | Analog Functional Blocks .....                              | 292 |
| 7.4.1  | Overview.....                                               | 293 |
| 7.4.2  | Features.....                                               | 293 |
| 7.4.3  | Register Map .....                                          | 293 |
| 7.4.4  | VMID Reference Voltage Generation.....                      | 295 |
| 7.4.5  | GPIO Current Source Generation .....                        | 296 |
| 7.4.6  | LDO Power Domain Control .....                              | 297 |
| 7.4.7  | Microphone Bias Generator .....                             | 298 |
| 7.4.8  | Analog Multiplexer .....                                    | 300 |
| 7.4.9  | Programmable Gain Amplifier.....                            | 302 |
| 7.4.10 | Capacitive Touch Sensing Relaxation Oscillator/Counter..... | 306 |
| 7.4.11 | Oscillator Frequency Measurement and Control.....           | 308 |
| 7.5    | Automatic Level Control (ALC) .....                         | 311 |
| 7.5.1  | Overview and Features.....                                  | 311 |
| 7.5.2  | ALC Control Register Map .....                              | 317 |
| 7.5.3  | ALC Control Register Description .....                      | 317 |
| 7.6    | Biquad Filter (BIQ) .....                                   | 323 |
| 7.6.1  | Overview and Features.....                                  | 323 |
| 7.6.2  | BIQ Control Register Map.....                               | 324 |
| 8      | APPLICATION DIAGRAM.....                                    | 327 |
| 9      | ELECTRICAL CHARACTERISTICS.....                             | 328 |
| 9.1    | Absolute Maximum Ratings .....                              | 328 |
| 9.2    | DC Electrical Characteristics .....                         | 329 |
| 9.3    | AC Electrical Characteristics .....                         | 333 |
| 9.3.1  | External 32kHz XTAL Oscillator.....                         | 333 |
| 9.3.2  | Internal 49.152MHz Oscillator.....                          | 333 |
| 9.3.3  | Internal 10 kHz Oscillator.....                             | 333 |
| 9.4    | Analog Characteristics .....                                | 334 |
| 9.4.1  | Specification of ADC and Speaker Driver .....               | 334 |
| 9.4.2  | Specification of PGA and BOOST.....                         | 335 |
| 9.4.3  | Specification of ALC an MICBIAS .....                       | 336 |
| 9.4.4  | Specification of LDO & Power management.....                | 337 |
| 9.4.5  | Specification of Brownout Detector .....                    | 338 |
| 9.4.6  | Specification of Power-On Reset (VCCD).....                 | 338 |
| 9.4.7  | Specification of Temperature Sensor.....                    | 339 |
| 9.4.8  | Specification of Comparator.....                            | 339 |
| 10     | PACKAGE DIMENSIONS .....                                    | 340 |
| 10.1.1 | 48L LQFP (7x7x1.4mm footprint 2.0mm).....                   | 340 |
| 11     | ORDERING INFORMATION.....                                   | 341 |
| 12     | REVISION HISTORY .....                                      | 342 |

|                              |            |
|------------------------------|------------|
| <b>IMPORTANT NOTICE.....</b> | <b>343</b> |
|------------------------------|------------|

Preliminary

## 1 GENERAL DESCRIPTION

The ISD9160 is a system-on-chip product optimized for low power, audio record and playback with an embedded ARM® Cortex™-M0 32-bit microcontroller core.

The ISD9160 embeds a Cortex™-M0 core running up to 50 MHz with 145K-byte of non-volatile flash memory and 12K-byte of embedded SRAM. It also comes equipped with a variety of peripheral devices, such as Timers, Watchdog Timer (WDT), Real-time Clock (RTC), Peripheral Direct Memory Access (PDMA), a variety of serial interfaces (UART, SPI/SSP, I<sup>2</sup>C, I<sup>2</sup>S), PWM modulators, GPIO, Analog Comparator, Low Voltage Detector and Brown-out detector.

The ISD9160 comes equipped with a rich set of power saving modes including a Deep Power Down (DPD) mode drawing less than 1µA. A micro-power 10KHz oscillator can periodically wake up the device from deep power down to check for other events. A Standby Power Down (SPD) mode can maintain a real time clock function at less than 10 µA.

For audio functionality the ISD9160 includes a Sigma-Delta ADC with 80dB SNR performance coupled with a Programmable Gain Amplifier (PGA) capable of a maximum gain of 61dB to enable direct connection of a microphone. Audio output is provided by a Differential Class D amplifier (DPWM) that can deliver 1W of power to an 8Ω speaker.

The ISD9160 provides eight analog enabled general purpose IO pins (GPIO). These pins can be configured to connect to an analog comparator, can be configured as analog current sources or can be routed to the SDADC for analog conversion. They can also be used as a relaxation oscillator to perform capacitive touch sensing.

## 2 FEATURES

- Core
  - ARM® Cortex™-M0 core runs up to 50MHz.
  - One 24-bit System tick timer for operating system support.
  - Supports a variety of low power sleep and power down modes.
  - Single-cycle 32-bit hardware multiplier.
  - NVIC (Nested Vector Interrupt Controller) for 32 interrupt inputs, each with 4-levels of priority.
  - Serial Wire Debug (SWD) supports with 2 watchpoints/4 breakpoints.
- Power Management
  - Wide operating voltage range from 2.4V to 5.5V.
  - Power management Unit (PMU) providing four levels of power control.
  - Deep Power Down (DPD) mode with sub micro-amp leakage (<1µA).
  - Wakeup from Deep Power Down via dedicated WAKEUP pin or timed operation from internal low power 10kHz oscillator.
  - Standby mode with limited RAM retention and RTC operation (<10µA).
  - Wakeup from Standby can be from any GPIO interrupt, RTC or BOD.
  - Sleep mode with minimal dynamic power consumption.
  - 3V LDO for operation of external 3V devices such as serial flash.
- Flash EPROM Memory
  - 145K bytes Flash EEPROM for program code and data storage.
  - 4KB of flash can be configured as boot sector for ISP loader.
  - Support In-system program (ISP) and In-circuit program (ICP) application code update
  - 1K byte page erase for flash
  - Configurable boundary to delineate code and data flash.
  - Support 2 wire In-circuit Programming (ICP) update from SWD ICE interface
- SRAM Memory
  - 12K bytes embedded SRAM.
- Clock Control
  - One high speed and two low speed oscillators providing flexible selection for different applications. No external components necessary.
  - Built-in trimmable oscillator with range of 16-50MHz. Factory trimmed within 1% to settings of 49.152MHz and 32.768MHz. User trimmable with in-built frequency measurement block (OSCFM) using reference clock of 32kHz crystal or external reference source.
  - Ultra-low power (<1uA) 10kHz oscillator for watchdog and wakeup from power-down or sleep operation.
  - External 32kHz crystal input for RTC function and low power system operation.
- GPIO
  - Four I/O modes:
    - ◆ Quasi bi-direction
    - ◆ Push-Pull output
    - ◆ Open-Drain output
    - ◆ Input only with high impedance
  - TTL/Schmitt trigger input selectable.
  - I/O pin can be configured as interrupt source with edge/level setting.
  - Switchable pull-up.
- Audio Analog to Digital converter
  - Sigma Delta ADC with configurable decimation filter and 16 bit output.
  - 80dB Signal-to-Noise (SNR) performance.
  - Programmable gain amplifier with 32 steps from -12 to 35.25dB in 0.75dB steps.

- Boost gain stage of 26dB, giving maximum total gain of 61dB.
- Input selectable from dedicated MIC pins or analog enabled GPIO.
- Programmable biquad filter to support multiple sample rates from 8-32kHz.
- DMA support for minimal CPU intervention.
- Differential Audio PWM Output (DPWM)
  - Direct connection of speaker
  - 1W drive capability into 8Ω load.
  - High efficiency 88%
  - Configurable up-sampling to support sample rates from 8-32kHz.
  - DMA support for minimal CPU intervention.
- Timers
  - Two timers with 8-bit pre-scaler and 24-bit resolution.
  - Counter auto reload.
- Watch Dog Timer
  - Default ON/OFF by configuration setting
  - Multiple clock sources
  - 8 selectable time out period from micro seconds to seconds (depending on clock source)
  - WDT can wake up power down/sleep.
  - Interrupt or reset selectable on watchdog time-out.
- RTC
  - Real Time Clock counter (second, minute, hour) and calendar counter (day, month, year)
  - Alarm registers (second, minute, hour, day, month, year)
  - Selectable 12-hour or 24-hour mode
  - Automatic leap year recognition
  - Time tick and alarm interrupts.
  - Device wake up function.
  - Supports software compensation of crystal frequency by compensation register (FCR)
- PWM/Capture
  - Built-in up to two 16-bit PWM generators provide two PWM outputs or one complementary paired PWM outputs.
  - The PWM generator equipped with a clock source selector, a clock divider, an 8-bit pre-scaler and Dead-Zone generator for complementary paired PWM.
  - PWM interrupt synchronous to PWM period.
  - 16-bit digital Capture timers (shared with PWM timers) provide rising/falling capture inputs.
  - Support Capture interrupt
- UART
  - UART ports with flow control (TX, RX, CTS and RTS)
  - 8-byte FIFO.
  - Support IrDA (SIR) and LIN function
  - Programmable baud-rate generator up to 1/16 of system clock.
- SPI
  - Master up to 20 Mbps / Slave up to 10 Mbps.
  - Support MICROWIRE/SPI master/slave mode (SSP)
  - Full duplex synchronous serial data transfer
  - Variable length of transfer data from 1 to 32 bits
  - MSB or LSB first data transfer
  - 2 slave/device select lines when used in master mode.
  - Hardware CRC calculation module available for CRC calculation of data stream.
  - DMA support for burst transfers.
- I2C

- Master/Slave up to 1Mbit/s
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master).
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allows devices with different bit rates to communicate via one serial bus.
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer.
- Programmable clock allowing versatile rate control.
- I<sup>2</sup>C-bus controller supports multiple address recognition.
- I<sup>2</sup>S
  - Interface with external audio CODEC.
  - Operate as either master or slave.
  - Capable of handling 8, 16, 24 and 32 bit word sizes
  - Mono and stereo audio data supported
  - I<sup>2</sup>S and MSB justified data format supported
  - Two 8 word FIFO data buffers are provided, one for transmit and one for receive
  - Generates interrupt requests when buffer levels cross a programmable boundary
  - Supports DMA requests, for transmit and receive
- Brown-out detector
  - With 8 levels: 2.1V, 2.2V, 2.4V, 2.5V, 2.625V, 2.8V, 3.0V, and 4.6V
  - Supports time-multiplex operation to minimize power consumption.
  - Supports Brownout Interrupt and Reset option
- Built in Low Dropout Voltage Regulator (LDO)
  - Capable of delivering 30mA load current.
  - Configurable for output voltage of 1.8V, 2.4V, 3.0V and 3.3V
  - Eight GPIO (GPIOA<7:0>) operate from LDO voltage domain allowing direct interface to, for example, 3V SPI Flash.
  - Can be bypassed and voltage domain supplied directly from system power.
- Additional Features
  - Over temperature alarm. Can generate interrupt if device exceeds safe operating temperature.
  - Temperature proportional voltage source which can be routed to ADC for temperature measurements.
  - Digital Microphone interface.
- Operating Temperature: -40C~85C
- Package:
  - All Green package (RoHS)
    - ◆ LQFP 48-pin

### 3 PART INFORMATION AND PIN CONFIGURATION

#### 3.1 Pin Configuration

##### 3.1.1 ISD9160 LQFP 48 pin



##### 3.1.2 Pin Description

The ISD9160 is a low pin count device where many pins are configurable to alternative functions. All General Purpose Input/Output (GPIO) pins can be configured to alternate functions as described in the table below and also in [Table 5-7](#) and [Table 5-8](#).

| Pin No. | Pin Name | Pin Type | Alt | Description |
|---------|----------|----------|-----|-------------|
|---------|----------|----------|-----|-------------|

| LQFP<br>48 |           |       | CFG |                                                                                                             |
|------------|-----------|-------|-----|-------------------------------------------------------------------------------------------------------------|
| 1          | WAKEUP    | I     |     | Pull low to wake part from deep power down                                                                  |
| 2          | PB.7      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 7                                             |
|            | I2S_SDO   | O     | 1   | Serial Data Output for I2S interface                                                                        |
|            | CMP7      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
| 3          | PB.6      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 6                                             |
|            | I2S_SDI   | I     | 1   | Serial Data Input for I2S interface                                                                         |
|            | CMP6      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
|            | SPI_MOSI1 | O     | 3   | Master Out, Slave In channel 1 for SPI interface                                                            |
| 4          | PB.5      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 5                                             |
|            | PWM1B     | O     | 1   | PWM channel 1 complementary output pin                                                                      |
|            | CMP5      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
|            | SPI_MISO1 | I     | 3   | Master In, Slave Out channel 1 for SPI interface                                                            |
| 5          | PB.4      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 4                                             |
|            | PWM0B     | O     | 1   | PWM channel 0 complementary output pin                                                                      |
|            | CMP4      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
|            | SPI_MOSI0 | O     | 3   | Master Out, Slave In channel 0 for SPI interface                                                            |
| 6          | PB.3      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 3                                             |
|            | I2C_SDA   | I/O   | 1   | Serial Data, I2C interface                                                                                  |
|            | CMP3      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
|            | SPI_MISO0 | I     | 3   | Master In, Slave Out channel 0 for SPI interface                                                            |
| 7          | PB.2      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 2                                             |
|            | I2C_SCL   | I/O   | 1   | Serial Clock, I2C interface                                                                                 |
|            | CMP2      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
|            | SPI_SCLK  | I/O   | 3   | Serial Clock for SPI interface                                                                              |
| 8          | PB.1      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 1. Triggers external interrupt 1 (EINT1/IRQ3) |
|            | MCLK      | O     | 1   | Master clock output for synchronizing external device                                                       |
|            | CMP1      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |
|            | SPI_SSB1  | O     | 3   | Slave Select Bar 1 for SPI interface                                                                        |
| 9          | PB.0      | A/I/O | 0   | General purpose input/output pin, analog capable; Port B, bit 0. Triggers external interrupt 0 (EINT0/IRQ2) |
|            | SPI_SSB1  | O     | 3   | Slave Select Bar 1 for SPI interface                                                                        |
|            | CMP0      | AIO   | 2   | Configure as relaxation oscillator for capacitive touch sensing                                             |

| Pin No. | Pin Name | Pin Type | Alt CFG | Description                                                                                          |
|---------|----------|----------|---------|------------------------------------------------------------------------------------------------------|
| LQFP 48 |          |          |         |                                                                                                      |
|         | SPI_SSB0 | I/O      | 3       | Slave Select Bar 0 for SPI interface                                                                 |
| 10      | VCCD     | P        |         | Main Digital Supply for Chip. Supplies all IO except analog, Speaker Driver and PA<7:0>              |
| 11      | VREG     | P        |         | Logic regulator output decoupling pin. A 1µF capacitor returning to VSSD must be placed on this pin. |
| 12      | NC       |          |         | Should remain unconnected.                                                                           |
| 13      | NC       |          |         | Should remain unconnected.                                                                           |
| 14      | PA.15    | I/O      | 0       | General purpose input/output pin; Port A, bit 15                                                     |
|         | TM1      | I        | 1       | External input to Timer 1                                                                            |
|         | SDIN     | I        | 2       | Sigma Delta bit stream input for digital MIC mode                                                    |
| 15      | PA.9     | I/O      | 0       | General purpose input/output pin; Port A, bit 9                                                      |
|         | UART_RX  | I        | 1       | Receive channel of UART                                                                              |
|         | I2S_BCLK | I/O      | 2       | Bit Clock for I2S interface                                                                          |
| 16      | PA.8     | I/O      | 0       | General purpose input/output pin; Port A, bit 8                                                      |
|         | UART_TX  | O        | 1       | Transmit channel of UART                                                                             |
|         | I2S_FS   | I/O      | 2       | Frame Sync Clock for I2S interface                                                                   |
| 17      | VCCSPK   | P        |         | Power Supply for PWM Speaker Driver                                                                  |
| 18      | SPK+     | O        |         | Positive Speaker Driver Output                                                                       |
| 19      | VSSSPK   | P        |         | Ground for PWM Speaker Driver                                                                        |
| 20      | SPK-     | O        |         | Negative Speaker Driver Output                                                                       |
| 21      | VCCSPK   | P        |         | Power Supply for PWM Speaker Driver                                                                  |
| 22      | RESETN   | I        |         | External reset input. Pull this pin low to reset device to initial state. Has internal weak pull-up. |
| 23      | ICE_DAT  | I/O      |         | Serial Wire Debug port data pin. Has internal weak pull-up.                                          |
| 24      | ICE_CLK  | I        |         | Serial Wire Debug port clock pin. Has internal weak pull-up.                                         |
| 25      | VSSD     | P        |         | Digital Ground.                                                                                      |
| 26      | PA.7     | I/O      | 0       | General purpose input/output pin; Port A, bit 7                                                      |
|         | I2S_SDO  | O        | 1       | Serial Data Out for I2S interface                                                                    |
| 27      | PA.6     | I/O      | 0       | General purpose input/output pin; Port A, bit 6                                                      |
|         | I2S_SDI  | I        | 1       | Serial Data In for I2S interface                                                                     |
| 28      | PA.5     | I/O      | 0       | General purpose input/output pin; Port A, bit 5                                                      |
|         | I2S_BCLK | I/O      | 1       | Bit Clock for I2S interface                                                                          |

| Pin No. | Pin Name  | Pin Type | Alt CFG | Description                                                                                            |
|---------|-----------|----------|---------|--------------------------------------------------------------------------------------------------------|
| LQFP 48 |           |          |         |                                                                                                        |
| 29      | PA.4      | I/O      | 0       | General purpose input/output pin; Port A, bit 4                                                        |
|         | I2S_FS    | I/O      | 1       | Frame Sync Clock for I2S interface                                                                     |
| 30      | PA.3      | I/O      | 0       | General purpose input/output pin; Port A, bit 3                                                        |
|         | SPI_MISO0 | I        | 1       | Master In, Slave Out channel 0 for SPI interface                                                       |
|         | I2C_SDA   | I/O      | 2       | Serial Data, I2C interface                                                                             |
| 31      | PA.2      | I/O      | 0       | General purpose input/output pin; Port A, bit 2                                                        |
|         | SPI_SSB0  | I/O      | 1       | Slave Select Bar 0 for SPI interface                                                                   |
| 32      | VDD33     | P        |         | LDO Regulator Output. If used, a 1µF capacitor must be placed to ground. If not used then tie to VCCD. |
| 33      | PA.1      | I/O      | 0       | General purpose input/output pin; Port A, bit 1                                                        |
|         | SPI_SCLK  | I/O      | 1       | Serial Clock for SPI interface                                                                         |
|         | I2C_SCL   | I/O      | 2       | Serial Clock, I2C interface                                                                            |
| 34      | PA.0      | I/O      | 0       | General purpose input/output pin; Port A, bit 2                                                        |
|         | SPI_MOSI0 | O        | 1       | Master Out, Slave In channel 0 for SPI interface                                                       |
|         | MCLK      | O        | 2       | Master clock output.                                                                                   |
| 35      | VCCLDO    | P        |         | Power Supply for LDO, should be connected to VCCD                                                      |
| 36      | PA.14     | I/O      | 0       | General purpose input/output pin; Port A, bit 14                                                       |
|         | SDCLK     | O        | 1       | Clock output for digital microphone mode.                                                              |
|         | SDCLKn    | O        | 2       | Inverse Clock output for digital microphone mode.                                                      |
| 37      | PA.13     | I/O      | 0       | General purpose input/output pin; Port A, bit 13                                                       |
|         | PWM1      | O        | 1       | PWM1 Output.                                                                                           |
|         | SPKM      | O        | 2       | Equivalent to SPK-.                                                                                    |
|         | I2S_BCLK  | I/O      | 3       | Bit Clock for I2S interface                                                                            |
| 38      | PA.12     | I/O      | 0       | General purpose input/output pin; Port A, bit 12                                                       |
|         | PWM0      | O        | 1       | PWM0 Output.                                                                                           |
|         | SPKP      | O        | 2       | Equivalent to SPK+                                                                                     |
|         | I2S_FS    | I/O      | 3       | Frame Sync Clock for I2S interface                                                                     |
| 39      | XO32K     | O        |         | 32.768kHz Crystal Oscillator Output                                                                    |
| 40      | XI32K     | I        |         | 32.768kHz Crystal Oscillator Input. Max Voltage 1.8V                                                   |
| 41      | VSSA      | AP       |         | Ground for analog circuitry.                                                                           |
| 42      | VMID      | O        |         | Mid rail reference. Connect 4.7µF to VSSA.                                                             |

| Pin No. | Pin Name  | Pin Type | Alt CFG | Description                                      |
|---------|-----------|----------|---------|--------------------------------------------------|
| LQFP 48 |           |          |         |                                                  |
| 43      | MIC+      | AI       |         | Positive microphone input.                       |
| 44      | MIC-      | AI       |         | Negative microphone input.                       |
| 45      | MICBIAS   | AO       |         | Microphone bias output.                          |
| 46      | VCCA      | AP       |         | Analog power supply.                             |
| 47      | PA.11     | I/O      | 0       | General purpose input/output pin; Port A, bit 11 |
|         | I2C_SCL   | I/O      | 1       | Serial Clock, I2C interface                      |
|         | I2S_SDO   | O        | 2       | Serial Data Out I2S interface                    |
|         | UART_CTSn | I        | 3       | UART Clear to Send Input.                        |
| 48      | PA.10     | I/O      | 0       | General purpose input/output pin; Port A, bit 10 |
|         | I2C_SDA   | I/O      | 1       | Serial Data, I2C interface                       |
|         | I2S_SDI   | I        | 2       | Serial Data In I2S interface                     |
|         | UART_RTSn | O        | 3       | UART Request to Send Output.                     |

Note:

1. Pin Type I=Digital Input, O=Digital Output; AI=Analog Input; P=Power Pin; AP=Analog Power

#### 4 BLOCK DIAGRAM



Figure 4-1 ISD9160 Block Diagram

## 5 FUNCTIONAL DESCRIPTION

### 5.1 ARM® Cortex™-M0 core

The Cortex™-M0 processor is a multistage, 32-bit RISC processor. It has an AMBA AHB-Lite interface and includes an NVIC component. It also has hardware debug functionality. The processor can execute Thumb code and is compatible with other Cortex-M profile processor.

Figure 5-1 shows the functional blocks of processor.



Figure 5-1 Functional Block Diagram

The implemented device provides:

- A low gate count processor that features:
  - The ARMv6-M Thumb® instruction set.
  - Thumb-2 technology.
  - ARMv6-M compliant 24-bit SysTick timer.
  - A 32-bit hardware multiplier.
  - The system interface supports little-endian data accesses.
  - The ability to have deterministic, fixed-latency, interrupt handling.
  - Load/store-multiples that can be abandoned and restarted to facilitate rapid interrupt handling.
  - C Application Binary Interface compliant exception model.  
This is the ARMv6-M, C Application Binary Interface (C-ABI) compliant exception model that enables the use of pure C functions as interrupt handlers.
  - Low power sleep-mode entry using Wait For Interrupt (WFI), Wait For Event (WFE) instructions, or the return from interrupt sleep-on-exit feature.
- NVIC that features:
  - 32 external interrupt inputs, each with four levels of priority.
  - Dedicated non-Maskable Interrupt (NMI) input.
  - Support for both level-sensitive and pulse-sensitive interrupt lines
  - Wake-up Interrupt Controller (WIC), providing ultra-low power sleep mode support.
- Debug support
  - Four hardware breakpoints.

- Two watchpoints.
- Program Counter Sampling Register (PCSR) for non-intrusive code profiling.
- Single step and vector catch capabilities.
- Bus interfaces:
  - Single 32-bit AMBA-3 AHB-Lite system interface that provides simple integration to all system peripherals and memory.
  - Single 32-bit slave port that supports the DAP (Debug Access Port).

## 5.2 System Manager

### 5.2.1 Overview

The following functions are included in system manager section

- System Memory Map
- System Timer (SysTick)
- Nested Vectored Interrupt Controller (NVIC)
- System management registers for product ID
- System management registers for chip and module functional reset and multi-function pin control
- Brown-Out and chip miscellaneous Control Register
- Combined peripheral interrupt source identify

### 5.2.2 System Reset

The system reset includes one of the list below event occurs. For these reset event flags can be read by **RSTSRC** register.

- The Power-On Reset
- The low level on the RESETN pin
- Watchdog Time Out Reset
- Low Voltage Reset
- Cortex-M0 MCU Reset
- PMU Reset – for details of wakeup events, also examine **PWRCON** register.
- SWD Debug interface.

A power-on reset (POR) will occur if the main external supply rail ramps from 0V or the voltage of the main supply drops below reset threshold. A low voltage reset monitors the regulated core logic (1.8V) supply and will assert if the voltage on this rail drops below reliable logic threshold.

### 5.2.3 System Power Distribution

The ISD9160 implements several power domains:

- Analog power from VCCA and VSSA provides the power for analog module operation.
- Digital power from VCCD and VSSD supplies the power to the IO ring and the internal regulator which provides 1.8V power for digital operation.
- VCCLDO supplies the LDO regulator whose output is available on pin VDD33. This supply powers the IO ring for GPIOA<7:0>.
- An internal Standby reference (SB REG) generates a 1.8V rail to part of the logic including the IO ring, Standby RAM and RTC during standby mode for low power operation.

The outputs of internal voltage regulators; VREG and VDD33, require external decoupling capacitors which should be located close to the corresponding pin. The following diagram shows the power distribution of this device.



Figure 5-2 ISD9160 Power Distribution Diagram

### 5.2.4 System Memory Map

The ISD9160 provides 4G-byte address space. The memory locations assigned to each on-chip module is shown in Table 5-1. The detailed register definition, memory space, and programming detailed will be described in the following sections for each on-chip module. The ISD9160 supports little-endian data format.

Table 5-1 Address Space Assignments for On-Chip Modules

| Address Space                                         | Token     | Modules                                 | Reference             |
|-------------------------------------------------------|-----------|-----------------------------------------|-----------------------|
| <b>Flash &amp; SRAM Memory Space</b>                  |           |                                         |                       |
| 0x0000_0000 – 0x0002_33FF                             | FLASH_BA  | FLASH Memory Space (141KB)              |                       |
| 0x0000_0000 – 0x0002_43FF                             | FLASH_BA  | FLASH Memory Space (145KB)              |                       |
| 0x2000_0000 – 0x2000_2FFF                             | SRAM_BA   | SRAM Memory Space (12KB)                |                       |
| <b>AHB Modules Space (0x5000_0000 – 0x501F_FFFF)</b>  |           |                                         |                       |
| 0x5000_0000 – 0x5000_01FF                             | GCR_BA    | System Global Control Registers         | <a href="#">5.2.5</a> |
| 0x5000_0200 – 0x5000_02FF                             | SYCLK_BA  | Clock Control Registers                 | <a href="#">5.3.5</a> |
| 0x5000_0300 – 0x5000_03FF                             | INT_BA    | Interrupt Multiplexer Control Registers | 0                     |
| 0x5000_4000 – 0x5000_7FFF                             | GPIO_BA   | GPIO Control Registers                  | <a href="#">5.4.3</a> |
| 0x5000_8000 – 0x5000_BFFF                             | PDMA_BA   | SRAM_APB DMA Control Registers          | <a href="#">5.15</a>  |
| 0x5000_C000 – 0x5000_FFFF                             | FMC_BA    | Flash Memory Control Registers          | <a href="#">6.3</a>   |
| <b>APB1 Modules Space (0x4000_0000 ~ 0x400F_FFFF)</b> |           |                                         |                       |
| 0x4000_4000 – 0x4000_7FFF                             | WDT_BA    | Watch-Dog Timer Control Registers       | <a href="#">5.11</a>  |
| 0x4000_8000 – 0x4000_BFFF                             | RTC_BA    | Real Time Clock (RTC) Control Register  | <a href="#">5.8</a>   |
| 0x4001_0000 – 0x4001_3FFF                             | TIMER0_BA | Timer0/Timer1 Control Registers         | <a href="#">5.10</a>  |
| 0x4002_0000 – 0x4002_3FFF                             | I2C0_BA   | I2C0 Interface Control Registers        | <a href="#">5.6</a>   |
| 0x4003_0000 – 0x4003_3FFF                             | SPI0_BA   | SPI0 Serial Interface Control Registers | <a href="#">5.9</a>   |
| 0x4004_0000 – 0x4004_3FFF                             | PWMA_BA   | PWM0/1 Control Registers                | <a href="#">5.7</a>   |
| 0x4005_0000 – 0x4005_3FFF                             | UART0_BA  | UART0 Control Registers                 | <a href="#">5.12</a>  |
| 0x4007_0000 – 0x4007_3FFF                             | DPWM_BA   | Differential Audio PWM Speaker Driver   | <a href="#">7.2</a>   |
| 0x4008_0000 – 0x4008_3FFF                             | ANA_BASE  | Analog Block Control Registers          | <a href="#">7.4</a>   |

|                                                         |          |                                                 |                       |
|---------------------------------------------------------|----------|-------------------------------------------------|-----------------------|
| 0x4008_4000 – 0x4008_7FFF                               | BOD_BA   | Brown Out Detector Control Registers            | <a href="#">5.5.1</a> |
| 0x4009_0000 – 0x4009_7FFF                               | CRC_BA   | CRC Block Control Registers                     | <a href="#">5.14</a>  |
| 0x400A_0000 - 0x400A_FFFF                               | I2S_BA   | I2S Interface Control registers                 | <a href="#">5.13</a>  |
| 0x400B_0000 - 0x400B_FFFF                               | BIQ_BA   | Biquad Filter Control Registers                 | <a href="#">7.6</a>   |
| 0x400D_0000 – 0x400D_3FFF                               | ACMP_BA  | Analog Comparator Control Registers             | <a href="#">7.3</a>   |
| 0x400E_0000 – 0x400E_FFFF                               | ADC0_BA  | Analog-Digital-Converter (ADC) Registers        | <a href="#">7.1</a>   |
| 0x400F_0000 – 0x400F_7FFF                               | SBRAM_BA | Standby RAM Block Address space                 |                       |
| <b>System Control Space (0xE000_E000 ~ 0xE000_EFFF)</b> |          |                                                 |                       |
| 0xE000_E010 – 0xE000_E0FF                               | SCS_BA   | System Timer Control Registers                  | <a href="#">5.2.6</a> |
| 0xE000_E100 – 0xE000_ECFF                               | SCS_BA   | External Interrupt Controller Control Registers | <a href="#">5.2.7</a> |
| 0xE000_ED00 – 0xE000_ED8F                               | SCS_BA   | System Control Registers                        | <a href="#">5.2.8</a> |

### 5.2.5 System Manager Control Registers

| Register             | Offset       | R/W | Description                              | Reset Value | Reference                  |
|----------------------|--------------|-----|------------------------------------------|-------------|----------------------------|
| GCR_BA = 0x5000_0000 |              |     |                                          |             |                            |
| <b>RSTSRC</b>        | GCR_BA+0x04  | R/W | System Reset Source Register             | 0x0000_00XX | <a href="#">Table 5-2</a>  |
| <b>IPRSTC1</b>       | GCR_BA+0x08  | R/W | IP Reset Control Register1               | 0x0000_0000 | <a href="#">Table 5-3</a>  |
| <b>IPRSTC2</b>       | GCR_BA+0x0C  | R/W | IP Reset Control Register2               | 0x0000_0000 | <a href="#">Table 5-4</a>  |
| <b>GPA_INP</b>       | GCR_BA+0x30  | R/W | GPIOA input type control register        | 0x0000_0000 | <a href="#">Table 5-5</a>  |
| <b>GPB_INP</b>       | GCR_BA+0x34  | R/W | GPIOB input type control register        | 0x0000_0000 | <a href="#">Table 5-6</a>  |
| <b>GPA_ALT</b>       | GCR_BA+0x38  | R/W | GPIOA multiple function control register | 0x0000_0000 | <a href="#">Table 5-7</a>  |
| <b>GPB_ALT</b>       | GCR_BA+0x3C  | R/W | GPIOB multiple function control register | 0x0000_0000 | <a href="#">Table 5-8</a>  |
| <b>WAKECR</b>        | GCR_BA+0x54  | R/W | WAKEUP pad control register              | 0x0000_0006 | <a href="#">Table 5-9</a>  |
| <b>REGLOCK</b>       | GCR_BA+0x100 | R/W | Register Lock Key address                | 0x0000_0000 | <a href="#">Table 5-10</a> |
| <b>OSCTRIM</b>       | GCR_BA+0x110 | R/W | Internal oscillator trim register        | 0xFFFF_FFFF | <a href="#">Table 5-11</a> |
| <b>OSC10K</b>        | GCR_BA+0x114 | R/W | 10K Oscillator trim register             | 0xFFFF_FFFF |                            |

**System Reset Source Register (RSTSRC)**

This register provides specific information for software to identify this chip's reset source from last operation.

| Register | Offset    | R/W | Description                  |  |  |  | Reset Value |
|----------|-----------|-----|------------------------------|--|--|--|-------------|
| RSTSRC   | GCR_BA+04 | R/W | System Reset Source Register |  |  |  | 0x0000_00xx |

| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0         |
|----------|----------|----------|----------|----------|----------|----------|-----------|
| RSTS_CPU | RSTS_PMU | RSTS_SYS | Reserved | Reserved | RSTS_WDG | Reserved | RSTS_CORE |

Table 5-2 System Reset Source Register (RSTSRC, address 0x5000\_0004) Bit Description.

| Bits   | Symbol   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                |
| [7]    | RSTS_CPU | The <b>RSTS_CPU</b> flag is set by hardware if software writes <b>CPU_RST (IPRSTCR1[1])</b> with a “1” to reset Cortex-M0 CPU kernel and Flash memory controller (FMC).<br>1= The Cortex-M0 CPU kernel and FMC has been reset by software setting <b>CPU_RST</b> to 1.<br>0= No reset from CPU<br>This bit is cleared by writing 1 to itself.                                                           |
| [6]    | RSTS_PMU | The <b>RSTS_PMU</b> flag is set if the PMU.<br>1= PMU reset the system from a power down/standby event.<br>0= No reset from PMU<br>This bit is cleared by writing 1 to itself.                                                                                                                                                                                                                          |
| [5]    | RSTS_SYS | The <b>RSTS_SYS</b> flag is set if the previous reset source originates from the Cortex_M0 kernel.<br>1= The Cortex_M0 MCU issued a reset signal to reset the system by software writing 1 to bit <b>SYSRESTREQ(AIRCR[2], Application Interrupt and Reset Control Register)</b> in system control registers of Cortex_M0 kernel.<br>0= No reset from MCU<br>This bit is cleared by writing 1 to itself. |
| [2]    | RSTS_WDG | The <b>RSTS_WDG</b> flag is set if previous reset source originates from the Watch-Dog module.<br>1= The Watch-Dog module issued the reset signal to reset the system.<br>0= No reset from Watch-Dog<br>This bit is cleared by writing 1 to itself.                                                                                                                                                     |

|     |                  |                                                                                                                                                                                                                                                          |
|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | Reserved         | Reserved                                                                                                                                                                                                                                                 |
| [0] | <b>RSTS_CORE</b> | <p>The <b>RSTS_CORE</b> flag is set if the core has been reset. Possible sources of reset are a Power-On Reset (POR), RESETn Pin Reset or PMU reset.</p> <p>1 = Core was reset by hardware block.</p> <p>This bit is cleared by writing 1 to itself.</p> |

Preliminary

**IP Reset Control Register1 (IPRSTC1)**

| Register | Offset    | R/W | Description                 | Reset Value |
|----------|-----------|-----|-----------------------------|-------------|
| IPRSTC1  | GCR_BA+08 | R/W | IP Reset Control Register 1 | 0x0000_0000 |

|          |   |   |   |   |          |         |          |
|----------|---|---|---|---|----------|---------|----------|
| 7        | 6 | 5 | 4 | 3 | 2        | 1       | 0        |
| Reserved |   |   |   |   | PDMA_RST | CPU_RST | CHIP_RST |

Table 5-3 IP Reset Control Register 1 (IPRSTC1 address 0x5000\_0008) Bit Description.

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2]    | PDMA_RST     | <p><b>PDMA Controller Reset</b><br/>Set “1” will generate a reset signal to the PDMA Block. User needs to set this bit to “0” to release from the reset state<br/>0= Normal operation<br/>1= PDMA IP reset</p>                                                                                                                                                                                                                                                               |
| [1]    | CPU_RST      | <p><b>CPU kernel one shot reset.</b><br/>Setting this bit will reset the CPU kernel and Flash Memory Controller(FMC), this bit will automatically return to “0” after the 2 clock cycles<br/>This bit is a protected bit, to program first issue the unlock sequence (<a href="#">see Protected Register Lock Key Register (REGLOCK)</a>)<br/>0= Normal<br/>1= Reset CPU</p>                                                                                                 |
| [0]    | CHIP_RST     | <p><b>CHIP one shot reset.</b><br/>Set this bit will reset the whole chip, this bit will automatically return to “0” after the 2 clock cycles.<br/>CHIP_RST has same behavior as POR reset, all the chip modules are reset and the chip configuration settings from flash are reloaded.<br/>This bit is a protected bit, to program first issue the unlock sequence (<a href="#">see Protected Register Lock Key Register (REGLOCK)</a>)<br/>0= Normal<br/>1= Reset CHIP</p> |

**IP Reset Control Register2 (IPRSTC2)**

Setting these bits “1” will generate an asynchronous reset signal to the corresponding peripheral block. The user needs to set bit to “0” to release block from the reset state.

| Register | Offset    | R/W | Description                 |  |  |  | Reset Value |
|----------|-----------|-----|-----------------------------|--|--|--|-------------|
| IPRSTC2  | GCR_BA+0C | R/W | IP Reset Control Resister 2 |  |  |  | 0x0000_0000 |

| 31       | 30       | 29       | 28        | 27       | 26       | 25       | 24        |
|----------|----------|----------|-----------|----------|----------|----------|-----------|
| Reserved | ANA_RST  | I2S_RST  | ADC_RST   | Reserved | Reserved | Reserved | Reserved  |
| 23       | 22       | 21       | 20        | 19       | 18       | 17       | 16        |
| Reserved | ACMP_RST | Reserved | PWM10_RST | CRC_RST  | BIQ_RST  | Reserved | UART0_RST |
| 15       | 14       | 13       | 12        | 11       | 10       | 9        | 8         |
| Reserved | Reserved | DPWM_RST | SPI0_RST  | Reserved | Reserved | Reserved | I2C0_RST  |
| 7        | 6        | 5        | 4         | 3        | 2        | 1        | 0         |
| TMR1_RST | TMR0_RST | Reserved | Reserved  | Reserved | Reserved | Reserved | Reserved  |

Table 5-4 IP Reset Control Register 2 (IPRSTC2 address 0x5000\_000C) Bit Description.

| Bits | Descriptions                                                                   |
|------|--------------------------------------------------------------------------------|
| [30] | <b>ANA_RST</b> <b>Analog block control Reset.</b> 1=Reset, 0=Normal Operation. |
| [29] | <b>I2S_RST</b> <b>I2S Controller Reset.</b> 1=Reset, 0=Normal Operation.       |
| [28] | <b>ADC_RST</b> <b>ADC Controller Reset.</b> 1=Reset, 0=Normal Operation.       |
| [22] | <b>ACMP_RST</b> <b>Analog Comparator Reset.</b> 1=Reset, 0=Normal Operation.   |
| [20] | <b>PWM10_RST</b> <b>PWM10 controller Reset.</b> 1=Reset, 0=Normal Operation.   |
| [19] | <b>CRC_RST</b> <b>CRC Generation Block Reset.</b> 1=Reset, 0=Normal Operation. |
| [18] | <b>BIQ_RST</b> <b>Biquad Filter Block Reset.</b> 1=Reset, 0=Normal Operation.  |
| [16] | <b>UART0_RST</b> <b>UART0 controller Reset.</b> 1=Reset, 0=Normal Operation.   |
| [13] | <b>DPWM_RST</b> <b>DPWM Speaker Driver Reset.</b> 1=Reset, 0=Normal Operation. |
| [12] | <b>SPI0_RST</b> <b>SPI0 controller Reset.</b> 1=Reset, 0=Normal Operation.     |
| [8]  | <b>I2C0_RST</b> <b>I2C0 controller Reset.</b> 1=Reset, 0=Normal Operation.     |
| [7]  | <b>TMR1_RST</b> <b>Timer1 controller Reset.</b> 1=Reset, 0=Normal Operation.   |
| [6]  | <b>TMR0_RST</b> <b>Timer0 controller Reset.</b> 1=Reset, 0=Normal Operation.   |

**GPIOA Input Type Control Register (GPA\_INP)**

| Register | Offset    | R/W | Description                       |  |  |  |  | Reset Value |
|----------|-----------|-----|-----------------------------------|--|--|--|--|-------------|
| GPA_INP  | GCR_BA+30 | R/W | GPIOA input type control register |  |  |  |  | 0x0000_0000 |

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

Table 5-5 GPIOA Input Type Control Register (GPA\_INP address 0x5000\_0030) Bit Description.

| Bits    | Descriptions    |                                                                                                                                                                                           |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>SCHMITT</b>  | This register controls whether the GPIO input buffer Schmitt trigger is enabled.<br>1= GPIOA[15:0] I/O input Schmitt Trigger enabled<br>0= GPIOA[15:0] I/O input Schmitt Trigger disabled |
| [15:0]  | <b>Reserved</b> |                                                                                                                                                                                           |

GPIOB Input Type Control Register (GPB\_INP)

| Register | Offset    | R/W | Description                       |  |  |  |  | Reset Value |
|----------|-----------|-----|-----------------------------------|--|--|--|--|-------------|
| GPB_INP  | GCR_BA+34 | R/W | GPIOB input type control register |  |  |  |  | 0x0000_0000 |

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

Table 5-6 GPIOB Input Type Control Register (GPB\_INP address 0x5000\_0034) Bit Description.

| Bits    | Descriptions |                                                                                                                                                                                         |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:16] | SCHMITT      | This register controls whether the GPIO input buffer Schmitt trigger is enabled.<br>1= GPIOB[7:0] I/O input Schmitt Trigger enabled<br>0= GPIOB[7:0] I/O input Schmitt Trigger disabled |

**GPIO Alternative Function Control Register (GPA\_ALT, GPB\_ALT)**

Each GPIO pin can take on multiple alternate functions depending on the setting of this register. Each pin has two bits of alternate function control. Set to 00 the pin is a standard GPIO pin whose attributes are defined by the GPIO control registers (See Section 5.4). Set to other values the pin is assigned to a peripheral as outlined in table below.

| Register | Offset    | R/W | Description                                |  |  |  | Reset Value |
|----------|-----------|-----|--------------------------------------------|--|--|--|-------------|
| GPA_ALT  | GCR_BA+38 | R/W | Alternative Function Pin Control Register. |  |  |  | 0x0000_0000 |
| GPB_ALT  | GCR_BA+3C | R/W | Alternative Function Pin Control Register. |  |  |  | 0x0000_0000 |

|       |    |       |    |       |    |       |    |
|-------|----|-------|----|-------|----|-------|----|
| 31    | 30 | 29    | 28 | 27    | 26 | 25    | 24 |
| GPA15 |    | GPA14 |    | GPA13 |    | GPA12 |    |
| 23    | 22 | 21    | 20 | 19    | 18 | 17    | 16 |
| GPA11 |    | GPA10 |    | GPA9  |    | GPA8  |    |
| 15    | 14 | 13    | 12 | 11    | 10 | 9     | 8  |
| GPA7  |    | GPA6  |    | GPA5  |    | GPA4  |    |
| 7     | 6  | 5     | 4  | 3     | 2  | 1     | 0  |
| GPA3  |    | GPA2  |    | GPA1  |    | GPA0  |    |

Table 5-7 GPIOA Alternate Function Register (GPA\_ALT address 0x5000\_0038)

| GPIO    | Power Domain | GPA <sub>n</sub> =01 |      | GPA <sub>n</sub> =10 |      | GPA <sub>n</sub> =11 |      |
|---------|--------------|----------------------|------|----------------------|------|----------------------|------|
|         |              | Function             | Type | Function             | Type | Function             | Type |
| GPIOA0  | VDD33        | SPI_MOSI0            | O    | MCLK                 | O    |                      |      |
| GPIOA1  | VDD33        | SPI_SCLK             | IO   | I2C_SCL              | IO   |                      |      |
| GPIOA2  | VDD33        | SPI_SSB0             | IO   |                      |      |                      |      |
| GPIOA3  | VDD33        | SPI_MISO0            | I    | I2C_SDA              | IO   |                      |      |
| GPIOA4  | VDD33        | I2S_FS               | IO   |                      |      |                      |      |
| GPIOA5  | VDD33        | I2S_BCLK             | IO   |                      |      |                      |      |
| GPIOA6  | VDD33        | I2S_SDI              | I    |                      |      |                      |      |
| GPIOA7  | VDD33        | I2S_SDO              | O    |                      |      |                      |      |
| GPIOA8  | VCCD         | UART_TX              | O    | I2S_FS               | IO   |                      |      |
| GPIOA9  | VCCD         | UART_RX              | I    | I2S_BCLK             | IO   |                      |      |
| GPIOA10 | VCCD         | I2C_SDA              | IO   | I2S_SDI              | I    | UART_RTSn            | O    |

|                |      |         |    |         |   |           |    |
|----------------|------|---------|----|---------|---|-----------|----|
| <b>GPIOA11</b> | VCCD | I2C_SCL | IO | I2S_SDO | O | UART_CTSn | I  |
| <b>GPIOA12</b> | VCCD | PWM0    | O  | SPKP    | O | I2S_FS    | IO |
| <b>GPIOA13</b> | VCCD | PWM1    | O  | SPKM    | O | I2S_BCLK  | IO |
| <b>GPIOA14</b> | VCCD | TM0     | I  | SDCLK   | O | !SDCLK    | O  |
| <b>GPIOA15</b> | VCCD | TM1     | I  | SDIN    | I |           |    |

Table 5-8 GPIOB Alternate Function Register (GPB\_ALT address 0x5000\_003C)

| <b>GPIO</b>   | <b>Power Domain</b> | <b>GPBn=01</b>  |             | <b>GPBn =10</b> |             | <b>GPBn =11</b> |             |
|---------------|---------------------|-----------------|-------------|-----------------|-------------|-----------------|-------------|
|               |                     | <b>Function</b> | <b>Type</b> | <b>Function</b> | <b>Type</b> | <b>Function</b> | <b>Type</b> |
| <b>GPIOB0</b> | VCCD                | SPI_SSB1        | O           | CMP0            | AIO         | SPI_SSB0        | IO          |
| <b>GPIOB1</b> | VCCD                | MCLK            | O           | CMP1            | AIO         | SPI_SSB1        | O           |
| <b>GPIOB2</b> | VCCD                | I2C_SCL         | IO          | CMP2            | AIO         | SPI_SCLK        | IO          |
| <b>GPIOB3</b> | VCCD                | I2C_SDA         | IO          | CMP3            | AIO         | SPI_MISO0       | I           |
| <b>GPIOB4</b> | VCCD                | PWM0B           | O           | CMP4            | AIO         | SPI_MOSI0       | O           |
| <b>GPIOB5</b> | VCCD                | PWM1B           | O           | CMP5            | AIO         | SPI_MISO1       | I           |
| <b>GPIOB6</b> | VCCD                | I2S_SDI         | I           | CMP6            | AIO         | SPI_MOSI1       | O           |
| <b>GPIOB7</b> | VCCD                | I2S_SDO         | O           | CMP7            | AIO         |                 |             |

**Wakeup Pin Control Register (WAKECR)**

The WAKEUP pin of the ISD9160 is a special purpose pin that can be used to wake the device from a deep power down condition when all other pins of the device are inactive. When the device is active, this register can be used to set the state of the WAKEUP pin. The default state of the pin is as a tri-state input.

| Register | Offset    | R/W | Description                 |  |  |  | Reset Value |
|----------|-----------|-----|-----------------------------|--|--|--|-------------|
| WAKECR   | GCR_BA+54 | R/W | Wakeup Pin control register |  |  |  | 0x0000_0006 |

|          |   |   |   |          |          |           |           |
|----------|---|---|---|----------|----------|-----------|-----------|
| 7        | 6 | 5 | 4 | 3        | 2        | 1         | 0         |
| Reserved |   |   |   | WAKE_DIN | WAKE_TRI | WAKE_OENB | WAKE_DOUT |

Table 5-9 Wakeup Pin Control Register (WAKECR, address 0x5000\_0054) Bit Description.

| Bits | Descriptions |                                                                                                                        |
|------|--------------|------------------------------------------------------------------------------------------------------------------------|
| [3]  | WAKE_DOUT    | Output state. Default=0                                                                                                |
| [2]  | WAKE_OENB    | Pin output enable bar. 1= tristate (default), 0=drive WAKE_DOUT to pin.                                                |
| [1]  | WAKE_TRI     | Pin pull-up control. 1= tristate (default). 0=pull-up enable. This signal is latched in deep power down and preserved. |
| [0]  | WAKE_DIN     | State of WAKEUP pin. Read only.                                                                                        |

### Protected Register Lock Key Register (REGLOCK)

Certain critical system control registers are protected against inadvertent write operations which may disturb chip operation. These system control registers are locked after power on reset until the user specifically issues an unlock sequence to open the lock. The unlock sequence is to write to REGLOCK the data 0x59, 0x16, 0x88. Any different sequence, data or a write to any other address will abort the unlock sequence.

MDK provides the defined function UNLOCKREG(x); which will execute this sequence.

The status of the lock can be determined by reading REGLOCK bit0: "1" is unlocked, "0" is locked. Once unlocked, user can update protected register values. To lock registers again, write any data to REGLOCK.

This register is write accessible for writing key values and read accessible to determine RegUnLock status.

| Register | Offset     | R/W | Description                        |  |  |  | Reset Value |
|----------|------------|-----|------------------------------------|--|--|--|-------------|
| REGLOCK  | GCR_BA+100 | R/W | Register Lock Key Address register |  |  |  | 0x0000_0000 |

|   |   |   |   |   |   |   |           |
|---|---|---|---|---|---|---|-----------|
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|   |   |   |   |   |   |   | RegUnLock |

Table 5-10 Protected Register Lock Key Register (REGLOCK address 0x5000\_0100) Bit Description.

| Bits    | Descriptions |                                                                                                                          |
|---------|--------------|--------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved     | Reserved                                                                                                                 |
| [0]     | RegUnLock    | 1 = Protected registers are unlocked<br>0 = Protected registers are locked. Any write to the target register is ignored. |

**Oscillator Trim Control Register (OSCTRIM)**

The master oscillator of the ISD9160 has an adjustable frequency and is controlled by the OSCTRIM register. This register contains two oscillator frequency trim values, which one is active depends upon the setting of register CLKSEL0 OSCFSel bit. If this bit is 0, OSCTRIM[0] is active, if 1 then OSCTRIM[1] is active. Upon power on reset this register is loaded from flash memory with factory stored values to give oscillator frequencies of 49.152MHz for OSCTRIM[0] and 32.768MHz for OSCTRIM[1]. If users wish to change either of the default frequencies it is possible to do so by setting this register. An additional SUPERFINE trim register is also available to interpolate frequencies between the available OSCTRIM settings (see [Table 7-36](#))

This register is a protected register, to write to register first issue the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#))

| Register | Offset     | R/W | Description                                      |  |  |  |  | Reset Value |
|----------|------------|-----|--------------------------------------------------|--|--|--|--|-------------|
| OSCTRIM  | GCR_BA+110 | R/W | Oscillator Frequency Adjustment control register |  |  |  |  | 0xXXXX_XXXX |

|                 |    |    |    |    |    |    |    |                   |
|-----------------|----|----|----|----|----|----|----|-------------------|
| 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 |                   |
| Reserved        |    |    |    |    |    |    |    | OSCTRIM[1]. RANGE |
| 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                   |
| OSCTRIM[1].TRIM |    |    |    |    |    |    |    |                   |
| 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  |                   |
| Reserved        |    |    |    |    |    |    |    | OSCTRIM[0]. RANGE |
| 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                   |
| OSCTRIM[0].TRIM |    |    |    |    |    |    |    |                   |

Table 5-11 Oscillator Frequency Adjustment Control Register (OSCTRIM, address 0x5000\_0110).

| Bits    | Descriptions     |                                                                                                                                                              |
|---------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [24]    | OSCTRIM[1].RANGE | Range bit for oscillator. 1= low range, 0= high range.                                                                                                       |
| [23:16] | OSCTRIM[1].TRIM  | 8 bit trim for oscillator. TRIM[7:5] are 8 coarse trim ranges which overlap in frequency. TRIM[4:0] are 32 fine trim steps of approximately 0.5% resolution. |
| [8]     | OSCTRIM[0].RANGE | Range bit for oscillator. 1= low range, 0= high range.                                                                                                       |
| [7:0]   | OSCTRIM[0].TRIM  | 8 bit trim for oscillator. TRIM[7:5] are 8 coarse trim ranges which overlap in frequency. TRIM[4:0] are 32 fine trim steps of approximately 0.5% resolution. |

### 5.2.6 System Timer (SysTick)

The Cortex-M0 includes an integrated system timer, SysTick. SysTick provides a simple, 24-bit, clear-on-write, decrementing, wrap-on-zero counter with a flexible control mechanism. The counter can be used in several different ways, for example:

- An RTOS tick timer which fires at a programmable rate (for example 100Hz) and invokes a SysTick routine.
- A high speed alarm timer using Core clock.
- A variable rate alarm or signal timer – the duration range dependent on the reference clock used and the dynamic range of the counter.
- A simple counter. Software can use this to measure time to completion and time used.
- An internal clock source control based on missing/meeting durations. The COUNTFLAG bit-field in the control and status register can be used to determine if an action completed within a set duration, as part of a dynamic clock management control loop.

When enabled, the timer will count down from the value in the SysTick Current Value Register (SYST\_CVR) to zero, reload (wrap) to the value in the SysTick Reload Value Register (SYST\_RVR) on the next clock edge, then decrement on subsequent clocks. When the counter transitions to zero, the COUNTFLAG status bit is set. The COUNTFLAG bit clears on reads.

The SYST\_CVR value is UNKNOWN on reset. Software should write to the register to clear it to zero before enabling the feature. This ensures the timer will count from the SYST\_RVR value rather than an arbitrary value when it is enabled.

If the SYST\_RVR is zero, the timer will be maintained with a current value of zero after it is reloaded with this value. This mechanism can be used to disable the feature independently from the timer enable bit.

In DEEPSLEEP and power down modes, the SysTick timer is disabled so cannot be used to wake up the device.

For more detailed information, please refer to the documents “ARM® Cortex™-M0 Technical Reference Manual” and “ARM® v6-M Architecture Reference Manual”.

#### 5.2.6.1 System Timer Control Register Map

R: read only, W: write only, R/W: both read and write, W&C: Write 1 clear

| Register             | Offset       | R/W | Description                | Reset Value |
|----------------------|--------------|-----|----------------------------|-------------|
| SCS_BA = 0xE000_E000 |              |     |                            |             |
| CTRL                 | SCS_BA + 010 | R/W | SysTick Control and Status | 0x0000_0004 |
| LOAD                 | SCS_BA + 014 | R/W | SysTick Reload value       | 0xFFFF_FFFF |
| VAL                  | SCS_BA + 018 | R/W | SysTick Current value      | 0xFFFF_FFFF |

#### 5.2.6.2 System Timer Control Register Description

##### SysTick Control and Status (SysTick->CTRL)

| Register | Offset | R/W | Description | Reset Value |
|----------|--------|-----|-------------|-------------|
|----------|--------|-----|-------------|-------------|

|             |              |     |                            |             |
|-------------|--------------|-----|----------------------------|-------------|
| <b>CTRL</b> | SCS_BA + 010 | R/W | SysTick Control and Status | 0x0000_0004 |
|-------------|--------------|-----|----------------------------|-------------|

Table 5-12 SysTick Control and Status Register (SysTick-&gt;CTRL, address 0xE000\_E010)

|                 |    |    |    |    |               |                |               |
|-----------------|----|----|----|----|---------------|----------------|---------------|
| 31              | 30 | 29 | 28 | 27 | 26            | 25             | 24            |
| <b>Reserved</b> |    |    |    |    |               |                |               |
| 23              | 22 | 21 | 20 | 19 | 18            | 17             | 16            |
| <b>Reserved</b> |    |    |    |    |               |                |               |
| 15              | 14 | 13 | 12 | 11 | 10            | 9              | 8             |
| <b>Reserved</b> |    |    |    |    |               |                |               |
| 7               | 6  | 5  | 4  | 3  | 2             | 1              | 0             |
| <b>Reserved</b> |    |    |    |    | <b>CLKSRC</b> | <b>TICKINT</b> | <b>ENABLE</b> |

| <b>Bits</b> | <b>Descriptions</b> |                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17]     | Reserved            | Reserved                                                                                                                                                                                                                                                                                                                                                                       |
| [16]        | <b>COUNTFLAG</b>    | Returns 1 if timer counted to 0 since last time this register was read.<br>COUNTFLAG is set by a count transition from 1 to 0.<br>COUNTFLAG is cleared on read or by a write to the Current Value register.                                                                                                                                                                    |
| [15:3]      | Reserved            | Reserved                                                                                                                                                                                                                                                                                                                                                                       |
| [2]         | <b>CLKSRC</b>       | 1 : Core clock used for SysTick, this bit will read as 1 and ignore writes.                                                                                                                                                                                                                                                                                                    |
| [1]         | <b>TICKINT</b>      | Enables SysTick Exception request.<br>1 : Counting down to 0 will cause SysTick exception to be pended. Clearing the SysTick Current Value register by a register write in software will not cause SysTick to be pended.<br>0 : Counting down to 0 does not cause the SysTick exception to be pended. Software can use COUNTFLAG to determine if a count to zero has occurred. |
| [0]         | <b>ENABLE</b>       | 1 : The counter will operate in a multi-shot manner.<br>0 : The counter is disabled                                                                                                                                                                                                                                                                                            |

SysTick Reload Value Register (SysTick->LOAD)

| <b>Register</b> | <b>Offset</b> | <b>R/W</b> | <b>Description</b>            | <b>Reset Value</b> |
|-----------------|---------------|------------|-------------------------------|--------------------|
| LOAD            | SCS_BA + 014  | R/W        | SysTick Reload Value Register | 0xFFFF_FFFF        |

Table 5-13 SysTick Reload Value Register (SysTick-&gt;LOAD, address 0xE000\_E014)

|    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----|----|----|----|----|----|----|

| Reserved      |    |    |    |    |    |    |    |
|---------------|----|----|----|----|----|----|----|
| 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| RELOAD[23:16] |    |    |    |    |    |    |    |
| 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
| RELOAD[15:8]  |    |    |    |    |    |    |    |
| 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| RELOAD[7:0]   |    |    |    |    |    |    |    |

| Bits    | Descriptions |                                                                                                                                                                                                                                                                             |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved     | Reserved                                                                                                                                                                                                                                                                    |
| [23:0]  | RELOAD       | Value to load into the Current Value register when the counter reaches 0. To generate a multi-shot timer with a period of N processor clock cycles, use a RELOAD value of N-1. For example, if the SysTick interrupt is required every 200 clock pulses, set RELOAD to 199. |

#### SysTick Current Value Register (SysTick->VAL)

| Register | Offset       | R/W | Description                    | Reset Value |
|----------|--------------|-----|--------------------------------|-------------|
| VAL      | SCS_BA + 018 | R/W | SysTick Current Value Register | 0xXXXX_XXXX |

Table 5-14 SysTick Current Value Register (SysTick->VAL, address 0xE000\_E018)

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

| Bits    | Descriptions |                                                                                                                                                                                                                                                                         |
|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved     | Reserved                                                                                                                                                                                                                                                                |
| [23:0]  | CURRENT      | Current counter value. This is the value of the counter at the time it is sampled. The counter does not provide read-modify-write protection. The register is write-clear. A software write of any value will clear the register to 0 and also clear the COUNTFLAG bit. |

### 5.2.7 Nested Vectored Interrupt Controller (NVIC)

Cortex-M0 includes an interrupt controller the “Nested Vectored Interrupt Controller (NVIC)”. It is closely coupled to the processor kernel and provides following features:

- Nested and Vectored interrupt support
- Automatic processor state saving and restoration
- Dynamic priority changing
- Reduced and deterministic interrupt latency

The NVIC prioritizes and handles all supported exceptions. All exceptions are handled in “Handler Mode”. This NVIC architecture supports 32 (IRQ[31:0]) discrete interrupts with 4 levels of priority. All of the interrupts and most of the system exceptions can be configured to different priority levels. When an interrupt occurs, the NVIC will compare the priority of the new interrupt to the current running one’s priority. If the priority of the new interrupt is higher than the current one, the new interrupt handler will override the current handler.

When any interrupt is accepted, the starting address of the interrupt service routine (ISR) is fetched from a vector table in memory. There is no need to determine which interrupt is accepted and branch to the starting address of the corresponding ISR by software. While the starting address is fetched, NVIC will also automatically save processor state including the registers “PC, PSR, LR, R0~R3, R12” to the stack. At the end of the ISR, the NVIC will restore the above mentioned registers from the stack and resume normal execution. This provides a high speed and deterministic time to process any interrupt request.

The NVIC supports “Tail Chaining” which handles back-to-back interrupts efficiently without the overhead of state saving and restoration and therefore reduces delay time in switching to a pending ISR at the end of the current ISR. The NVIC also supports “Late Arrival” which improves the efficiency of concurrent ISRs. When a higher priority interrupt request occurs before the current ISR starts to execute (at the stage of state saving and starting address fetching), the NVIC will give priority to the higher one without delay penalty. This aids real-time, high priority, interrupt capability.

For more detailed information, please refer to the documents [“ARM® Cortex™-M0 Technical Reference Manual”](#) and [“ARM® v6-M Architecture Reference Manual”](#).

#### 5.2.7.1 Exception Model and System Interrupt Map

The following table lists the exception model supported by ISD9160. Software can set four levels of priority on certain exceptions as well as on all interrupts. The highest user-configurable priority is denoted as “0” and the lowest priority is denoted as “3”. The default priority of all the user-configurable interrupts is “0”. Note that priority “0” is treated as the fourth priority on the system, after three system exceptions “Reset”, “NMI” and “Hard Fault”.

Table 5-15 Exception Model

| <b>Exception Name</b>           | <b>Vector Number</b> | <b>Priority</b> |
|---------------------------------|----------------------|-----------------|
| <b>Reset</b>                    | 1                    | -3              |
| <b>NMI</b>                      | 2                    | -2              |
| <b>Hard Fault</b>               | 3                    | -1              |
| <b>Reserved</b>                 | 4 ~ 10               | N/A             |
| <b>SVCall</b>                   | 11                   | Configurable    |
| <b>Reserved</b>                 | 12 ~ 13              | N/A             |
| <b>PendSV</b>                   | 14                   | Configurable    |
| <b>SysTick</b>                  | 15                   | Configurable    |
| <b>Interrupt (IRQ0 ~ IRQ31)</b> | 16 ~ 47              | Configurable    |

Table 5-16 System Interrupt Map

| <b>Vector Number</b> | <b>Interrupt Number<br/>(Bit in Interrupt Registers)</b> | <b>Interrupt Name</b> | <b>Source IP</b> | <b>Interrupt description</b>                      |
|----------------------|----------------------------------------------------------|-----------------------|------------------|---------------------------------------------------|
| 0 ~ 15               | -                                                        | -                     | -                | System exceptions                                 |
| 16                   | 0                                                        | <b>BOD_IRQn</b>       | Brown-Out        | Brownout low voltage detector interrupt           |
| 17                   | 1                                                        | <b>WDT_IRQn</b>       | WDT              | Watch Dog Timer interrupt                         |
| 18                   | 2                                                        | <b>EINT0_IRQn</b>     | GPIO             | External signal interrupt from PB.0 pin           |
| 19                   | 3                                                        | <b>EINT1_IRQn</b>     | GPIO             | External signal interrupt from PB.1 pin           |
| 20                   | 4                                                        | <b>GPAB_IRQn</b>      | GPIO             | External signal interrupt from PA[15:0] / PB[7:2] |
| 21                   | 5                                                        | <b>ALC_IRQn</b>       | ALC              | Automatic Level Control Interrupt                 |
| 22                   | 6                                                        | <b>PWMA_IRQn</b>      | PWM01            | PWM0, PWM1 interrupt                              |
| 23                   | 7                                                        | Reserved              |                  |                                                   |
| 24                   | 8                                                        | <b>TMR0_IRQn</b>      | TMR0             | Timer 0 interrupt                                 |

|    |    |                    |        |                                                          |
|----|----|--------------------|--------|----------------------------------------------------------|
| 25 | 9  | <b>TMR1_IRQn</b>   | TMR1   | Timer 1 interrupt                                        |
| 26 | 10 | Reserved           |        |                                                          |
| 27 | 11 | Reserved           |        |                                                          |
| 28 | 12 | <b>UART0_IRQn</b>  | UART0  | UART0 interrupt                                          |
| 29 | 13 | Reserved           |        |                                                          |
| 30 | 14 | <b>SPI0_IRQn</b>   | SPI0   | SPI0 interrupt                                           |
| 31 | 15 | Reserved           |        |                                                          |
| 32 | 16 | Reserved           |        |                                                          |
| 33 | 17 | Reserved           |        |                                                          |
| 34 | 18 | <b>I2C0_IRQn</b>   | I2C0   | I2C0 interrupt                                           |
| 35 | 19 | Reserved           |        |                                                          |
| 36 | 20 | Reserved           |        |                                                          |
| 37 | 21 | <b>TALARM_IRQn</b> | TALARM | Temperature Alarm Interrupt                              |
| 38 | 22 | Reserved           |        |                                                          |
| 39 | 23 | Reserved           |        |                                                          |
| 40 | 24 | Reserved           |        |                                                          |
| 41 | 25 | <b>ACMP_IRQn</b>   | ACMP   | Analog Comparator-0 or Comaprator-1 interrupt            |
| 42 | 26 | <b>PDMA_IRQn</b>   | PDMA   | PDMA interrupt                                           |
| 43 | 27 | <b>I2S_IRQn</b>    | I2S    | I2S interrupt                                            |
| 44 | 28 | <b>CAPS_IRQn</b>   | ANA    | Capacitive Touch Sensing Relaxation Oscillator Interrupt |
| 45 | 29 | <b>ADC_INT</b>     | SDADC  | Audio ADC interrupt                                      |
| 46 | 30 | Reserved           |        |                                                          |
| 47 | 31 | <b>RTC_INT</b>     | RTC    | Real time clock interrupt                                |

### 5.2.7.2 Vector Table

When an interrupt is accepted, the processor will automatically fetch the starting address of the interrupt service routine (ISR) from the vector table in memory. For ARMv6-M, the vector table base address is fixed in flash at 0x00000000. The vector table contains the initialization value for the stack pointer on reset, and the entry point addresses for all exception handlers. The vector number on previous page defines the order of entries in the vector table.

| <b>Vector Table Word Offset</b> | <b>Description</b>                               |
|---------------------------------|--------------------------------------------------|
| 0                               | SP_main - The Main stack pointer                 |
| Vector Number                   | Exception Entry Pointer using that Vector Number |

Table 5-17 Vector Table Format

### 5.2.7.3 Operation Description

NVIC interrupts can be enabled and disabled by writing to their corresponding Interrupt Set-Enable or Interrupt Clear-Enable register bit-field. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current enabled state of the corresponding interrupts. When an interrupt is disabled, interrupt assertion will cause the interrupt to become Pending, however, the interrupt will not activate. If an interrupt is Active when it is disabled, it remains in its Active state until cleared by reset or an exception return. Clearing the enable bit prevents new activations of the associated interrupt.

NVIC interrupts can be pended/un-pended using a complementary pair of registers to those used to enable/disable the interrupts, named the Set-Pending Register and Clear-Pending Register respectively. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current pended state of the corresponding interrupts. The Clear-Pending Register has no effect on the execution status of an Active interrupt.

NVIC interrupts are prioritized by updating an 8-bit field within a 32-bit register (each register supporting four interrupts).

The general registers associated with the NVIC are all accessible from a block of memory in the System Control Space and will be described in next section.

## 5.2.7.4 NVIC Control Registers

R: read only, W: write only, R/W: both read and write, W&C: Write 1 clear

| Register             | Offset       | R/W | Description                                 | Reset Value | Reference                  |
|----------------------|--------------|-----|---------------------------------------------|-------------|----------------------------|
| SCS_BA = 0xE000_E000 |              |     |                                             |             |                            |
| NVIC_ISER            | SCS_BA + 100 | R/W | IRQ0 ~ IRQ31 Set-Enable Control Register    | 0x0000_0000 | <a href="#">Table 5-18</a> |
| NVIC_ICER            | SCS_BA + 180 | R/W | IRQ0 ~ IRQ31 Clear-Enable Control Register  | 0x0000_0000 | <a href="#">Table 5-19</a> |
| NVIC_ISPR            | SCS_BA + 200 | R/W | IRQ0 ~ IRQ31 Set-Pending Control Register   | 0x0000_0000 | <a href="#">Table 5-20</a> |
| NVIC_ICPR            | SCS_BA + 280 | R/W | IRQ0 ~ IRQ31 Clear-Pending Control Register | 0x0000_0000 | <a href="#">Table 5-21</a> |
| NVIC_IPR0            | SCS_BA + 400 | R/W | IRQ0 ~ IRQ3 Priority Control Register       | 0x0000_0000 | <a href="#">Table 5-22</a> |
| NVIC_IPR1            | SCS_BA + 404 | R/W | IRQ4 ~ IRQ7 Priority Control Register       | 0x0000_0000 | <a href="#">Table 5-23</a> |
| NVIC_IPR2            | SCS_BA + 408 | R/W | IRQ8 ~ IRQ11 Priority Control Register      | 0x0000_0000 | <a href="#">Table 5-24</a> |
| NVIC_IPR3            | SCS_BA + 40C | R/W | IRQ12 ~ IRQ15 Priority Control Register     | 0x0000_0000 | <a href="#">Table 5-25</a> |
| NVIC_IPR4            | SCS_BA + 410 | R/W | IRQ16 ~ IRQ19 Priority Control Register     | 0x0000_0000 | <a href="#">Table 5-26</a> |
| NVIC_IPR5            | SCS_BA + 414 | R/W | IRQ20 ~ IRQ23 Priority Control Register     | 0x0000_0000 | <a href="#">Table 5-27</a> |
| NVIC_IPR6            | SCS_BA + 418 | R/W | IRQ24 ~ IRQ27 Priority Control Register     | 0x0000_0000 | <a href="#">Table 5-28</a> |
| NVIC_IPR7            | SCS_BA + 41C | R/W | IRQ28 ~ IRQ31 Priority Control Register     | 0x0000_0000 | <a href="#">Table 5-29</a> |

IRQ0 ~ IRQ31 Set-Enable Control Register (NVIC\_ISER)

| Register  | Offset       | R/W | Description                              | Reset Value |
|-----------|--------------|-----|------------------------------------------|-------------|
| NVIC_ISER | SCS_BA + 100 | R/W | IRQ0 ~ IRQ31 Set-Enable Control Register | 0x0000_0000 |

If a pending interrupt is enabled, the NVIC activates the interrupt based on its priority. If an interrupt is not enabled, asserting its interrupt signal changes the interrupt state to pending, but the NVIC never activates the interrupt, regardless of its priority.

Table 5-18 Interrupt Set-Enable Control Register (ISER, address 0xE000\_E100) Bit Description

| Bits   | Descriptions                                                                                                                                                                                                                                                                            |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>SETENA</b><br>Enable one or more interrupts within a group of 32. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47). Writing 1 will enable the associated interrupt. Writing 0 has no effect. The register reads back the current enable state. |

IRQ0 ~ IRQ31 Clear-Enable Control Register (NVIC\_ICER)

| Register  | Offset       | R/W | Description                                | Reset Value |
|-----------|--------------|-----|--------------------------------------------|-------------|
| NVIC_ICER | SCS_BA + 180 | R/W | IRQ0 ~ IRQ31 Clear-Enable Control Register | 0x0000_0000 |

Table 5-19 Interrupt Clear-Enable Control Register (ICER, address 0xE000\_E180) Bit Description

| Bits   | Descriptions                                                                                                                                                                                                                                                                                   |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CLRENA</b><br>Disable one or more interrupts within a group of 32. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47). Writing 1 will disable the associated interrupt. Writing 0 has no effect. The register reads back with the current enable state. |

IRQ0 ~ IRQ31 Set-Pending Control Register (NVIC\_ISPR)

| Register  | Offset       | R/W | Description                               | Reset Value |
|-----------|--------------|-----|-------------------------------------------|-------------|
| NVIC_ISPR | SCS_BA + 200 | R/W | IRQ0 ~ IRQ31 Set-Pending Control Register | 0x0000_0000 |

Table 5-20 Interrupt Set-Pending Control Register (ISPR, address 0xE000\_E200)

| Bits   | Descriptions                                                                                                                                                                                                                                                                              |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>SETPEND</b><br>Writing 1 to a bit forces pending state of the associated interrupt under software control. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47). Writing 0 has no effect.<br>The register reads back with the current pending state. |

IRQ0 ~ IRQ31 Clear-Pending Control Register (NVIC\_ICPR)

| Register  | Offset       | R/W | Description                                 | Reset Value |
|-----------|--------------|-----|---------------------------------------------|-------------|
| NVIC_ICPR | SCS_BA + 280 | R/W | IRQ0 ~ IRQ31 Clear-Pending Control Register | 0x0000_0000 |

Table 5-21 Interrupt Clear-Pending Control Register (ICPR, address 0xE000\_E280)

| Bits   | Descriptions                                                                                                                                                                                                                                                                                |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CLRPEND</b><br>Writing 1 to a bit to clear the pending state of associated interrupt under software control. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47). Writing 0 has no effect.<br>The register reads back with the current pending state. |

IRQ0 ~ IRQ3 Interrupt Priority Register (NVIC\_IPR0)

| Register  | Offset       | R/W | Description                                     |  |  |  |  | Reset Value |
|-----------|--------------|-----|-------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR0 | SCS_BA + 400 | R/W | IRQ0 ~ IRQ3 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-22 Interrupt Priority Register (IPR0, address 0xE000\_E400)

| Bits    | Descriptions |                                                                                      |
|---------|--------------|--------------------------------------------------------------------------------------|
| [31:30] | PRI_3        | Priority of IRQ3<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_2        | Priority of IRQ2<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_1        | Priority of IRQ1<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_0        | Priority of IRQ0<br>“0” denotes the highest priority and “3” denotes lowest priority |

IRQ4 ~ IRQ7 Interrupt Priority Register (NVIC\_IPR1)

| Register  | Offset       | R/W | Description                                     |  |  |  |  | Reset Value |
|-----------|--------------|-----|-------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR1 | SCS_BA + 404 | R/W | IRQ4 ~ IRQ7 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-23 Interrupt Priority Register (IPR1, address 0xE000\_E404)

| Bits    | Descriptions |                                                                                      |
|---------|--------------|--------------------------------------------------------------------------------------|
| [31:30] | PRI_7        | Priority of IRQ7<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_6        | Priority of IRQ6<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_5        | Priority of IRQ5<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_4        | Priority of IRQ4<br>“0” denotes the highest priority and “3” denotes lowest priority |

IRQ8 ~ IRQ11 Interrupt Priority Register (NVIC\_IPR2)

| Register  | Offset       | R/W | Description                                      |  |  |  |  | Reset Value |
|-----------|--------------|-----|--------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR2 | SCS_BA + 408 | R/W | IRQ8 ~ IRQ11 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-24 Interrupt Priority Register (IPR2, address 0xE000\_E408)

| Bits    | Descriptions |                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------|
| [31:30] | PRI_11       | <b>Priority of IRQ11</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_10       | <b>Priority of IRQ10</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_9        | <b>Priority of IRQ9</b><br>“0” denotes the highest priority and “3” denotes lowest priority  |
| [7:6]   | PRI_8        | <b>Priority of IRQ8</b><br>“0” denotes the highest priority and “3” denotes lowest priority  |

IRQ12 ~ IRQ15 Interrupt Priority Register (NVIC\_IPR3)

| Register  | Offset       | R/W | Description                                       |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR3 | SCS_BA + 40C | R/W | IRQ12 ~ IRQ15 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-25 Interrupt Priority Register (IPR3, address 0xE000\_E40C)

| Bits    | Descriptions |                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------|
| [31:30] | PRI_15       | <b>Priority of IRQ15</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_14       | <b>Priority of IRQ14</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_13       | <b>Priority of IRQ13</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_12       | <b>Priority of IRQ12</b><br>“0” denotes the highest priority and “3” denotes lowest priority |

IRQ16 ~ IRQ19 Interrupt Priority Register (NVIC\_IPR4)

| Register  | Offset       | R/W | Description                                       |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR4 | SCS_BA + 410 | R/W | IRQ16 ~ IRQ19 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-26 Interrupt Priority Register (IPR4, address 0xE000\_E410)

| Bits    | Descriptions |                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------|
| [31:30] | PRI_19       | <b>Priority of IRQ19</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_18       | <b>Priority of IRQ18</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_17       | <b>Priority of IRQ17</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_16       | <b>Priority of IRQ16</b><br>“0” denotes the highest priority and “3” denotes lowest priority |

IRQ20 ~ IRQ23 Interrupt Priority Register (NVIC\_IPR5)

| Register  | Offset       | R/W | Description                                       |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR5 | SCS_BA + 414 | R/W | IRQ20 ~ IRQ23 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-27 Interrupt Priority Register (IPR5, address 0xE000\_E414)

| Bits    | Descriptions |                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------|
| [31:30] | PRI_23       | <b>Priority of IRQ23</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_22       | <b>Priority of IRQ22</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_21       | <b>Priority of IRQ21</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_20       | <b>Priority of IRQ20</b><br>“0” denotes the highest priority and “3” denotes lowest priority |

IRQ24 ~ IRQ27 Interrupt Priority Register (NVIC\_IPR6)

| Register  | Offset       | R/W | Description                                       |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR6 | SCS_BA + 418 | R/W | IRQ24 ~ IRQ27 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-28 Interrupt Priority Register (IPR6, address 0xE000\_E418)

| Bits    | Descriptions |                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------|
| [31:30] | PRI_27       | <b>Priority of IRQ27</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_26       | <b>Priority of IRQ26</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_25       | <b>Priority of IRQ25</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_24       | <b>Priority of IRQ24</b><br>“0” denotes the highest priority and “3” denotes lowest priority |

IRQ28 ~ IRQ31 Interrupt Priority Register (NVIC\_IPR7)

| Register  | Offset       | R/W | Description                                       |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|--|--|--|--|-------------|
| NVIC_IPR7 | SCS_BA + 41C | R/W | IRQ28 ~ IRQ31 Interrupt Priority Control Register |  |  |  |  | 0x0000_0000 |

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

Table 5-29 Interrupt Priority Register (IPR7, address 0xE000\_E41C)

| Bits    | Descriptions |                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------|
| [31:30] | PRI_31       | <b>Priority of IRQ31</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_30       | <b>Priority of IRQ30</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [15:14] | PRI_29       | <b>Priority of IRQ29</b><br>“0” denotes the highest priority and “3” denotes lowest priority |
| [7:6]   | PRI_28       | <b>Priority of IRQ28</b><br>“0” denotes the highest priority and “3” denotes lowest priority |

### 5.2.7.5 Interrupt Source Control Registers

Along with the interrupt control registers associated with the NVIC, the ISD9160 also implements some specific control registers to facilitate the interrupt functions, including "interrupt source identify", "NMI source selection" and "interrupt test mode". They are described as below.

R: read only, W: write only, R/W: both read and write, W&C: Write 1 clear

| Register             | Offset        | R/W | Description                                     | Reset Value |
|----------------------|---------------|-----|-------------------------------------------------|-------------|
| INT_BA = 0x5000_0300 |               |     |                                                 |             |
| IRQn_SRC             | INT_BA+0x04*n | R   | MCU IRQn interrupt source identify (n=0,...,31) | 0xFFFF_FFFF |
| NMI_SEL              | INT_BA+0x80   | R/W | NMI source interrupt select control register    | 0x0000_0000 |
| MCU_IRQ              | INT_BA+0x84   | R/W | MCU IRQ Number identity register                | 0x0000_0000 |

#### Interrupt Source Identify Register (IRQn\_SRC)

| Register | Offset                              | R/W | Description                                                                        | Reset Value |
|----------|-------------------------------------|-----|------------------------------------------------------------------------------------|-------------|
| IRQn_SRC | INT_BA+0x00<br>.....<br>INT_BA+0x7C | R   | MCU IRQ0 interrupt source identify<br>.....<br>MCU IRQ31 interrupt source identify | 0xFFFF_FFFF |

|          |   |   |   |   |   |              |   |
|----------|---|---|---|---|---|--------------|---|
| 7        | 6 | 5 | 4 | 3 | 2 | 1            | 0 |
| Reserved |   |   |   |   |   | INT_SRC[2:0] |   |

The IRQn\_SRC register reports which of multiple sources generated an interrupt. For the ISD9160 the only interrupts that have multiple sources are IRQ4 and IRQ6. The return of the IRQn\_SRC register for these interrupts is shown below. All other IRQn\_SRC registers will report the interrupt status in bit 0 of field.

| Address     | INT-Num | Bits  | Descriptions                                 |
|-------------|---------|-------|----------------------------------------------|
| INT_BA+0x10 | 4       | [2:0] | Bit2: 1'b0<br>Bit1: GPB_INT<br>Bit0: GPA_INT |
| INT_BA+0x18 | 6       | [2:0] | Bit1: PWM1_INT<br>Bit0: PWM0_INT             |

**NMI Interrupt Source Select Control Register (NMI\_SEL)**

| Register | Offset      | R/W | Description                                  |  |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------------------------|--|--|--|--|-------------|
| NMI_SEL  | INT_BA+0x80 | R/W | NMI source interrupt select control register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Descriptions |                                                                                                                                                                                                                                                                 |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved     | Reserved                                                                                                                                                                                                                                                        |
| [7]    | IRQ_TM       | IRQ Test mode. If set to 1 then peripheral IRQ signals (0-31) are replaced by the value in the MCU_IRQ register. This is a protected register to program first issue the unlock sequence ( <a href="#">see Protected Register Lock Key Register (REGLOCK)</a> ) |
| [4:0]  | NMI_SEL      | The NMI interrupt to Cortex-M0 can be selected from one of the interrupt[31:0]<br>The NMI_SEL bit[4:0] used to select the NMI interrupt source                                                                                                                  |

**MCU Interrupt Request Source Test Mode Register (MCU\_IRQ)**

| Register | Offset      | R/W | Description                           |  |  |  |  | Reset Value |
|----------|-------------|-----|---------------------------------------|--|--|--|--|-------------|
| MCU_IRQ  | INT_BA+0x84 | R/W | MCU Interrupt Request Source Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <p><b>MCU IRQ Source Test Mode Register</b></p> <p>In Normal mode (NMI_SEL register bit [7] = 0) The device collects interrupts from each peripheral and synchronizes them to interrupt the Cortex-M0.</p> <p>In Test mode (NMI_SEL register bit [7] = 1), the interrupts from peripherals are blocked, and the interrupts are replaced by MCU_IRQ[31:0].</p> <p>When MCU_IRQ[n] is “0” : Writing MCU_IRQ[n] “1” will generate an interrupt to Cortex_M0 NVIC[n].</p> <p>When MCU_IRQ[n] is “1” (meaning an interrupt is asserted) writing MCU_bit[n] ‘1’ will clear the interrupt</p> <p>Writing MCU_IRQ[n] “0” : has no effect.</p> |

### 5.2.8 System Control Registers

Key control and status features of Cotex-M0 are managed centrally in a System Control Block within the System Control Registers.

For more detailed information, please refer to the documents "[ARM® Cortex™-M0 Technical Reference Manual](#)" and "[ARM® v6-M Architecture Reference Manual](#)".

R: read only, W: write only, R/W: both read and write, W&C: Write 1 clear

| Register             | Offset       | R/W | Description                                    | Reset Value |
|----------------------|--------------|-----|------------------------------------------------|-------------|
| SCS_BA = 0xE000_E000 |              |     |                                                |             |
| CPUID                | SCS_BA + D00 | R   | CPUID Base Register                            | 0x0000_0000 |
| ICSR                 | SCS_BA + D04 | R/W | Interrupt Control State Register               | 0x0000_0000 |
| AIRCR                | SCS_BA + D0C | R.W | Application Interrupt / Reset Control Register | 0x0000_0000 |
| SCR                  | SCS_BA + D10 | R/W | System Control Register                        | 0x0000_0000 |
| SHPR2                | SCS_BA + D1C | R/W | System Handler Priority Register 2             | 0x0000_0000 |
| SHPR3                | SCS_BA + D20 | R/W | System Handler Priority Register 3             | 0x0000_0000 |

**CPUID Base Register (CPUID)**

| Register | Offset       | R/W | Description         |  |  |  |  | Reset Value |
|----------|--------------|-----|---------------------|--|--|--|--|-------------|
| CPUID    | SCS_BA + D00 | R   | CPUID Base Register |  |  |  |  | 0x 410CC200 |

|                         |    |    |    |                      |    |    |    |
|-------------------------|----|----|----|----------------------|----|----|----|
| 31                      | 30 | 29 | 28 | 27                   | 26 | 25 | 24 |
| <b>IMPLEMENTER[7:0]</b> |    |    |    |                      |    |    |    |
| 23                      | 22 | 21 | 20 | 19                   | 18 | 17 | 16 |
| Reserved                |    |    |    | <b>PART[3:0]</b>     |    |    |    |
| 15                      | 14 | 13 | 12 | 11                   | 10 | 9  | 8  |
| <b>PARTNO[11:4]</b>     |    |    |    |                      |    |    |    |
| 7                       | 6  | 5  | 4  | 3                    | 2  | 1  | 0  |
| <b>PARTNO[3:0]</b>      |    |    |    | <b>REVISION[3:0]</b> |    |    |    |

| Bits    | Descriptions       |                                                 |
|---------|--------------------|-------------------------------------------------|
| [31:24] | <b>IMPLEMENTER</b> | Implementer code assigned by ARM. ( ARM = 0x41) |
| [23:20] | Reserved           | Reserved                                        |
| [19:16] | <b>PART</b>        | Reads as 0xC for ARMv6-M parts                  |
| [15:4]  | <b>PARTNO</b>      | Reads as 0xC20.                                 |
| [3:0]   | <b>REVISION</b>    | Reads as 0x0                                    |

Interrupt Control State Register (ICSR)

| Register | Offset       | R/W | Description                      |  |  |  |  | Reset Value |
|----------|--------------|-----|----------------------------------|--|--|--|--|-------------|
| ICSR     | SCS_BA + D04 | R/W | Interrupt Control State Register |  |  |  |  | 0x 00000000 |

|                  |             |          |                  |           |           |           |               |
|------------------|-------------|----------|------------------|-----------|-----------|-----------|---------------|
| 31               | 30          | 29       | 28               | 27        | 26        | 25        | 24            |
| NMIPENDSET       | Reserved    |          | PENDSVSET        | PENDSVCLR | PENDSTSET | PENDSTCLR | Reserved      |
| 23               | 22          | 21       | 20               | 19        | 18        | 17        | 16            |
| ISRPREEMPT       | ISR PENDING | Reserved | VECTPENDING[8:4] |           |           |           |               |
| 15               | 14          | 13       | 12               | 11        | 10        | 9         | 8             |
| VECTPENDING[3:0] |             |          |                  | Reserved  |           |           | VECTACTIVE[8] |
| 7                | 6           | 5        | 4                | 3         | 2         | 1         | 0             |
| VECTACTIVE[7:0]  |             |          |                  |           |           |           |               |

| Bits    | R/W | Descriptions       |                                                                                                                                                                                                                                                                                   |
|---------|-----|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | R/W | <b>NMIPENDSET</b>  | Setting this bit will activate an NMI. Since NMI is the highest priority exception, it will activate as soon as it is registered. Reads back with current state (1 if Pending, 0 if not).                                                                                         |
| [28]    | R/W | <b>PENDSVSET</b>   | Set a pending PendSV interrupt. This is normally used to request a context switch. Reads back with current state (1 if Pending, 0 if not).                                                                                                                                        |
| [27]    | W   | <b>PENDSVCLR</b>   | Write 1 to clear a pending PendSV interrupt.                                                                                                                                                                                                                                      |
| [26]    | R/W | <b>PENDSTSET</b>   | Set a pending SysTick. Reads back with current state (1 if Pending, 0 if not).                                                                                                                                                                                                    |
| [25]    | W   | <b>PENDSTCLR</b>   | Write 1 to clear a pending SysTick.                                                                                                                                                                                                                                               |
| [23]    | R   | <b>ISRPREEMPT</b>  | If set, a pending exception will be serviced on exit from the debug halt state.                                                                                                                                                                                                   |
| [22]    | R   | <b>ISR PENDING</b> | Indicates if an external configurable (NVIC generated) interrupt is pending.                                                                                                                                                                                                      |
| [20:12] | R   | <b>VECTPENDING</b> | Indicates the exception number for the highest priority pending exception. The pending state includes the effect of memory-mapped enable and mask registers. It does not include the PRIMASK special-purpose register qualifier. A value of zero indicates no pending exceptions. |
| [8:0]   | R   | <b>VECTACTIVE</b>  | 0: Thread mode<br>Value > 1: the exception number for the current executing exception.                                                                                                                                                                                            |

Application Interrupt and Reset Control Register (AIRCR)

| Register | Offset       | R/W | Description                                             |  |  |  | Reset Value |
|----------|--------------|-----|---------------------------------------------------------|--|--|--|-------------|
| AIRCR    | SCS_BA + D0C | R/W | <b>Application Interrupt and Reset Control Register</b> |  |  |  | 0x 00000000 |

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

| Bits    | Descriptions  |                                                                                                                                                                                                                                                                 |
|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | VECTKEY       | Vector Key. The value 0x05FA must be written to this register, otherwise a write to register is UNPREDICTABLE.                                                                                                                                                  |
| [15]    | ENDIANESS     | Read Only. Reads 0 indicating little endian machine.                                                                                                                                                                                                            |
| [2]     | SYSRESETREQ   | System Reset Request:<br><b>0</b> do not request a reset.<br><b>1</b> request reset.<br>Writing 1 to this bit asserts a signal to request a reset by the external system.                                                                                       |
| [1]     | VECTCLRACTIVE | Clears all active state information for fixed and configurable exceptions:<br><b>0</b> do not clear state information.<br><b>1</b> clear state information.<br>The effect of writing a 1 to this bit if the processor is not halted in Debug, is UNPREDICTABLE. |

System Control Register (SCR)

| Register | Offset       | R/W | Description             |  |  |  | Reset Value |
|----------|--------------|-----|-------------------------|--|--|--|-------------|
| SCR      | SCS_BA + D10 | R/W | System Control Register |  |  |  | 0x 00000000 |

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

| Bits | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]  | <b>SEVONPEND</b><br>Send Event on Pending bit:<br>0 = only enabled interrupts or events can wake-up the processor, disabled interrupts are excluded.<br>1 = enabled events and all interrupts, including disabled interrupts, can wake-up the processor.<br>When enabled, interrupt transitions from Inactive to Pending are included in the list of wakeup events for the WFE instruction.<br>When an event or interrupt enters pending state, the event signal wakes up the processor from WFE. If the processor is not waiting for an event, the event is registered and affects the next WFE.<br>The processor also wakes up on execution of an SEV instruction. |
| [2]  | <b>SLEEPDEEP</b><br>Controls whether the processor uses sleep or deep sleep as its low power mode:<br>0 = sleep<br>1 = deep sleep.<br>The SLEEPDEEP flag is also used in conjunction with PWRCON register to enter deeper power-down states than purely core sleep states.                                                                                                                                                                                                                                                                                                                                                                                           |
| [1]  | <b>SLEEPONEXIT</b><br>When set to 1, the core can enter a sleep state on an exception return to Thread mode. This is the mode and exception level entered at reset, the base level of execution. Setting this bit to 1 enables an interrupt driven application to avoid returning to an empty main application.                                                                                                                                                                                                                                                                                                                                                      |

System Handler Priority Register 2 (SHPR2)

| Register | Offset       | R/W | Description                        |  |  |  | Reset Value |
|----------|--------------|-----|------------------------------------|--|--|--|-------------|
| SHPR2    | SCS_BA + D1C | R/W | System Handler Priority Register 2 |  |  |  | 0x 00000000 |

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

| Bits    | Descriptions |                                                                                                            |  |
|---------|--------------|------------------------------------------------------------------------------------------------------------|--|
| [31:30] | PRI_11       | Priority of system handler 11 – SVCAll<br>“0” denotes the highest priority and “3” denotes lowest priority |  |

System Handler Priority Register 3 (SHPR3)

| Register | Offset       | R/W | Description                        |  |  |  |  | Reset Value |
|----------|--------------|-----|------------------------------------|--|--|--|--|-------------|
| SHPR3    | SCS_BA + D20 | R/W | System Handler Priority Register 3 |  |  |  |  | 0x 00000000 |

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

| Bits    | Descriptions |                                                                                                             |
|---------|--------------|-------------------------------------------------------------------------------------------------------------|
| [31:30] | PRI_15       | Priority of system handler 15 – SysTick<br>“0” denotes the highest priority and “3” denotes lowest priority |
| [23:22] | PRI_14       | Priority of system handler 14 – PendSV<br>“0” denotes the highest priority and “3” denotes lowest priority  |

### 5.3 Clock Controller and Power Management Unit (PMU)

The clock controller generates the clock sources for the whole device, including all AMBA interface modules and all peripheral clocks. Clock gating is provided on all peripheral clocks to minimize power consumption. The Power Management Unit (PMU) implements power control functions which can place the device into various power saving modes. The device will enter these various modes by requesting a power mode then requesting the Cortex-M0 to execute the WFI or the WFE instruction.

#### 5.3.1 Clock Generator

The clock generator consists of 3 sources listed below:

- An internal programmable high frequency oscillator factory trimmed to provide frequencies of 49.152MHz and 32.768MHz to 1% accuracy.
- An external 32kHz crystal
- An internal low power 10 kHz oscillator.



Figure 5-3 Clock generator block diagram

### 5.3.2 System Clock & SysTick Clock

The system clock has 3 clock sources from clock generator block. The clock source switch depends on the register HCLK\_S (CLKSEL0[2:0]). The clock is then divided by HCLK\_N+1 to produce the master clock for the device.



Figure 5-4 System Clock Block Diagram

The SysTick clock (STCLK) has five clock sources. The clock source switch depends on the setting of the register STCLK\_S (CLKSEL0[5:3]).



Figure 5-5 SysTick Clock Control Block Diagram

### 5.3.3 Peripheral Clocks

Each peripheral has a selectable clock gate. The register APBCLK determines whether the clock is active for each peripheral. In addition, the CLK\_SLEEP register determines whether these clocks remain on during M0 sleep mode. Certain peripheral clocks have selectable sources these are controlled by the CLKSEL1 & CLKSEL2 register.

### 5.3.4 Power Management

The ISD9160 is equipped with a Power Management Unit (PMU) that implements a variety of power saving modes. There are four levels of power control with increasing functionality (and power consumption):

- Level0 : Deep Power Down (DPD)
- Level1 : Standby Power Down (SPD)
- Level2 : Deep Sleep
- Level3 : Sleep
- Level4 : Normal Operation

Within each of these levels there are further options to optimize power consumption.

#### 5.3.4.1 Level0: Deep Power Down (DPD)

Deep Power Down (DPD) is the lowest power state the device can obtain. In this state there is no power provided to the logic domain and power consumption is only from the higher voltage chip supply domain. All logic state in the Cortex-M0 is lost as is contents of all RAM. All IO pins of the device are in a high impedance state. On a release from DPD the Cortex-M0 boots as if from a power-on reset. There are certain registers that can be interrogated to allow software to determine that previous state was a DPD state.

In DPD there are three ways to wake up the device:

1. A high to low transition on the WAKEUP pin.
2. A timed wakeup where the 10kHz oscillator is configured active and reaches a certain count.
3. A power cycle of main chip supply triggering a POR event.

To assist software in determining previous state of device before a DPD, a one-byte register is available PD\_STATE[7:0] that can be loaded with a value to be preserved before issuing a DPD request.

To configure the device for DPD the user sets the following options:

- SYSCLK->PWRCON.PIN\_ENB: If set to '1' then the WAKEUP pin is disabled and will not wake up the chip.
- SYSCLK->PWRCON.OSC10K\_ENB: If set to '1' then the 10kHz oscillator will power down in DPD. No timed wakeup is possible.
- SYSCLK->PWRCON.TIMER\_SEL: Each bit in this register will trigger a wakeup event after a certain number of OSC10K clock cycles.

When a WAKEUP event occurs the PMU will start the Cortex-M0 processor and execute the reset vector. The condition that generated the WAKEUP event can be interrogated by reading the registers SYSCLK->PWRCON.PIN\_WAKE, SYSCLK->PWRCON.TIMER\_WAKE and SYSCLK->PWRCON.POI\_WAKE.

To enter the DPD state the user must set the register bit SYSCLK->PWRCON.DEEP\_PD then execute a WFI or WFE instruction. Note that when debug interface is active, device will not enter DPD. Also once device enters DPD the debug interface will be inactive. It is possible that user could write

code that makes it impossible to activate the debug interface and reprogram device, for instance if device re-enters DPD mode with insufficient time to allow an ICE tool to activate the SWD debug port. Especially during development it is recommended that some checks are placed in the boot sequence to prevent device going to power down. A register bit, SYSCLK->DBGPD.DISABLE\_PD is included for this purpose that will disable power down features. A check such as:

```
void Reset_Handler(void) {
    /* check ICE_CLK and ICE_DAT to disable power down to the chip */
    if (SYSCLK->DBGPD.ICE_CLK == 0 && SYSCLK->DBGPD.ICE_DAT == 0)
        SYSCLK->DBGPD.DISABLE_PD = 1;
    __main();
}
```

Can check the SWD pin state on boot and prevent power down from occurring.

#### 5.3.4.2 Level1: Standby Power Down (SPD) mode.

Standby Power Down mode is the lowest power state that some logic operation can be performed. In this mode power is removed from the majority of the core logic, including the Cortex-M0 and main RAM. A low power standby reference is enabled however that supplies power to a subset of logic including the IO ring, GPIO control, RTC module, 32kHz Crystal Oscillator, Brownout Detector and a 256Byte Standby RAM.

In Standby mode there are three ways to wake up the device:

1. An interrupt from the GPIO block, for instance a pin transition.
2. An interrupt from the RTC module, for instance an alarm or timer event.
3. A power cycle of main chip supply triggering a POR event.

When a wake up event occurs the PMU will start the Cortex-M0 processor and execute the reset vector. Software can determine whether the device woke up from SPD by interrogating the register bit SYSCLK-> PFLAGCON.PD\_FLAG.

To enter the SPD state the user must set the register bit SYSCLK->PWRCON.PD then execute a WFI or WFE instruction. Note that when debug interface is active, device will not enter SPD. Also once device enters SPD the debug interface will be inactive.

#### 5.3.4.3 Level2: Deep Sleep mode.

The Deep Sleep mode is the lowest power state where the Cortex-M0 and all logic state are preserved. In Deep Sleep mode the CLK48M oscillator is shutdown and a low speed oscillator is selected, if CLK32K is active this source is selected, if not then CLK10K is enabled and selected. All clocks to the Cortex-M0 core are gated eliminating dynamic power in the core. Clocks to peripheral are gated according to the CLK\_SLEEP register, note however that HCLK is operating at a low frequency and CLK48M is not available. Deep Sleep mode is entered by setting System Control register bit 2: SCB->SCR |= (1UL << 2) and executing a WFI/WFE instruction. Software can determine whether the device woke up from Deep Sleep by interrogating the register bit SYSCLK-> PFLAGCON.DS\_FLAG.

#### 5.3.4.4 Level3: Sleep mode.

The Sleep mode gates all clocks to the Cortex-M0 eliminating dynamic power in the core. In addition, clocks to peripherals are gated according to the CLK\_SLEEP register. The mode is entered by executing a WFI/WFE instruction and is released when an event occurs. Peripheral functions, including PDMA can be continued while in Sleep mode. Using this mode power consumption can be minimized while waiting for events such as a PDMA operation collecting data from the ADC, once

PDMA has finished the core can be woken up to process the data.

### 5.3.5 Clock Control Register Map

R: read only, W: write only, R/W: both read and write

| Register             | Offset      | R/W | Description                              | Reset Value | Reference                  |
|----------------------|-------------|-----|------------------------------------------|-------------|----------------------------|
| CLK_BA = 0x5000_0200 |             |     |                                          |             |                            |
| PWRCON               | CLK_BA + 00 | R/W | System Power Control Register            | 0x0000_001x | <a href="#">Table 5-30</a> |
| AHBCLK               | CLK_BA + 04 | R/W | AHB Device Clock Enable Control Register | 0x0000_0001 | <a href="#">Table 5-32</a> |
| APBCLK               | CLK_BA + 08 | R/W | APB Device Clock Enable Control Register | 0x0000_0000 | <a href="#">Table 5-33</a> |
| DPDSTATE             | CLK_BA + 0C | R/W | DPD State Register                       | 0x0000_xx00 | <a href="#">Table 5-34</a> |
| CLKSEL0              | CLK_BA + 10 | R/W | Clock Source Select Control Register 0   | 0x0000_0038 | <a href="#">Table 5-35</a> |
| CLKSEL1              | CLK_BA + 14 | R/W | Clock Source Select Control Register 1   | 0x3300_771F | <a href="#">Table 5-36</a> |
| CLKDIV               | CLK_BA + 18 | R/W | Clock Divider Register                   | 0x0000_0000 | <a href="#">Table 5-37</a> |
| CLKSEL2              | CLK_BA + 1C | R/W | Clock Source Select Control Register 2   | 0xFFFF_FFFx | <a href="#">Table 5-38</a> |
| CLKSLEEP             | CLK_BA + 20 | R/W | Sleep Clock Source Select Register       | 0xFFFF_FFFF | <a href="#">Table 5-39</a> |
| PDFLAG               | CLK_BA + 24 | R/W | Power Down Flag Register                 | 0x0000_0000 | <a href="#">Table 5-40</a> |
| DBGPD                | CLK_BA + 28 | R/W | Debug Port Power Down Disable Register   | 0x0000_00XX | <a href="#">Table 5-41</a> |

### 5.3.6 Clock Control Register Description

#### System Power Control Register (PWRCON)

This is a protected register, to write to register, first issue the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#))

| Register | Offset      | R/W | Description                   |  |  |  | Reset Value |
|----------|-------------|-----|-------------------------------|--|--|--|-------------|
| PWRCON   | CLK_BA + 00 | R/W | System Power Control Register |  |  |  | 0xXX00_0006 |

Table 5-30 System Power Control Register (PWRCON, address 0x5000\_0200)

| 31 | 30       | 29           | 28 | 27        | 26         | 25         | 24         |
|----|----------|--------------|----|-----------|------------|------------|------------|
|    |          | TIMER_SEL_RD |    |           | Reserved   | POI_WAKE   | TIMER_WAKE |
| 23 | 22       | 21           | 20 | 19        | 18         | 17         | 16         |
|    |          | TIMER_SEL    |    |           | Reserved   | OSC10K_ENB | PIN_ENB    |
| 15 | 14       | 13           | 12 | 11        | 10         | 9          | 8          |
|    |          |              |    | DEEP_PD   | STANDBY_PD | STOP       | Reserved   |
| 7  | 6        | 5            | 4  | 3         | 2          | 1          | 0          |
|    | Reserved |              |    | OSC10K_EN | OSC49M_EN  | XTL32K_EN  | Reserved   |

Table 5-31 System Power Control Register (PWRCON, address 0x5000\_0200) Bit Description.

| Bits    | Descriptions                                                                                                                                                                                                                                                                              |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | <b>TIMER_SEL_RD</b><br>Read-Only. Read back of the current WAKEUP timer setting. This value is updated with TIMER_SEL upon entering DPD mode.                                                                                                                                             |
| [27]    | <b>Reserved</b>                                                                                                                                                                                                                                                                           |
| [26]    | <b>POI_WAKE</b><br>Read Only. This flag indicates that wakeup of device was requested with a power-on reset. Flag is cleared when DPD mode is entered.                                                                                                                                    |
| [25]    | <b>TIMER_WAKE</b><br>Read Only. This flag indicates that wakeup of device was requested with TIMER count of the 10Khz oscillator. Flag is cleared when DPD mode is entered.                                                                                                               |
| [24]    | <b>PIN_WAKE</b><br>Read Only. This flag indicates that wakeup of device was requested with a high to low transition of the WAKEUP pin. Flag is cleared when DPD mode is entered.                                                                                                          |
| [23:20] | <b>TIMER_SEL</b><br>Select WAKEUP Timer:<br>TIMER_SEL[0]=1: WAKEUP after 128 OSC10K clocks (12.8 ms)<br>TIMER_SEL[1]=1: WAKEUP after 256 OSC10K clocks (25.6 ms)<br>TIMER_SEL[2]=1: WAKEUP after 512 OSC10K clocks (51.2 ms)<br>TIMER_SEL[3]=1: WAKEUP after 1024 OSC10K clocks (102.4ms) |
| [19:18] | <b>Reserved</b>                                                                                                                                                                                                                                                                           |

|         |                   |                                                                                                                                                          |
|---------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]    | <b>OSC10K_ENB</b> | Determines whether OSC10K is enabled in DPD mode. 0=enabled, 1=disabled in DPD. If OSC10K is disabled, device cannot wake from DPD with TIMER_SEL delay. |
| [16]    | <b>PIN_ENB</b>    | Determines whether WAKEUP pin is enabled in DPD mode. 0=enabled, 1=disabled.                                                                             |
| [15:12] | <b>Reserved</b>   |                                                                                                                                                          |
| [11]    | <b>DEEP_PD</b>    | Deep Power Down (DPD) bit. Set to '1' and issue WFI/WFE instruction to enter DPD mode.                                                                   |
| [10]    | <b>STANDBY_PD</b> | Standby Power Down (SPD) bit. Set to '1' and issue WFI/WFE instruction to enter SPD mode.                                                                |
| [9]     | <b>STOP</b>       | Reserved – do not set to '1'                                                                                                                             |
| [8:4]   | <b>Reserved</b>   |                                                                                                                                                          |
| [3]     | <b>OSC10K_EN</b>  | OSC10K Oscillator enable bit. 1=enable (default), 0=disable                                                                                              |
| [2]     | <b>OSC49M_EN</b>  | OSC49M Oscillator enable bit. 1=enable (default), 0=disable                                                                                              |
| [1]     | <b>XTAL32K_EN</b> | External 32.768 kHz Crystal Enable bit. 1=enable, 0=disable (default).                                                                                   |
| [0]     | <b>Reserved</b>   |                                                                                                                                                          |

AHB Device Clock Enable Control Register (AHBCLK)

These register bits are used to enable/disable the clock source for AHB (Advanced High-Performance Bus) blocks. This is a protected register, to write to register, first issue the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#))

| Register | Offset      | R/W | Description                              |  |  |  |  | Reset Value |
|----------|-------------|-----|------------------------------------------|--|--|--|--|-------------|
| AHBCLK   | CLK_BA + 04 | R/W | AHB Device Clock Enable Control Register |  |  |  |  | 0x0000_0005 |

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

Table 5-32 AHB Device Clock Enable Register (AHBCLK, address 0x5000\_0204) Bit Description.

| Bits   | Symbol   | Description                                                                                                                                  |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved | Reserved                                                                                                                                     |
| [2]    | ISP_EN   | <b>Flash ISP Controller Clock Enable Control.</b><br>1 = To enable the Flash ISP engine clock.<br>0 = To disable the Flash ISP engine clock. |
| [1]    | PDMA_EN  | <b>PDMA Controller Clock Enable Control.</b><br>1 = To enable the PDMA engine clock.<br>0 = To disable the PDMA engine clock                 |
| [0]    | CPU_EN   | CPU Clock Enable (HCLK) must be left as '1' for normal operation.                                                                            |

**APB Device Clock Enable Control Register (APBCLK)**

These register bits are used to enable/disable clocks for APB (Advanced Peripheral Bus) peripherals. To enable the clocks write '1' to the appropriate bit. To reduce power consumption and disable the peripheral, write '0' to the appropriate bit.

| Register | Offset      | R/W | Description                              |  |  |  | Reset Value |
|----------|-------------|-----|------------------------------------------|--|--|--|-------------|
| APBCLK   | CLK_BA + 08 | R/W | APB Device Clock Enable Control Register |  |  |  | 0x0000_000x |

|          |          |          |          |          |           |          |          |
|----------|----------|----------|----------|----------|-----------|----------|----------|
| 31       | 30       | 29       | 28       | 27       | 26        | 25       | 24       |
| Reserved | ANA_EN   | I2S_EN   | ADC_EN   | Reserved | SBRAM_EN  | Reserved | Reserved |
| 23       | 22       | 21       | 20       | 19       | 18        | 17       | 16       |
| Reserved | ACMP_EN  | Reserved | PWM01_EN | CRC_EN   | BIQALC_EN | Reserved | UART0_EN |
| 15       | 14       | 13       | 12       | 11       | 10        | 9        | 8        |
| Reserved | Reserved | DPWM_EN  | SPI0_EN  | Reserved | Reserved  | Reserved | I2C0_EN  |
| 7        | 6        | 5        | 4        | 3        | 2         | 1        | 0        |
| TMR1_EN  | TMR0_EN  | RTC_EN   | WDG_EN   | Reserved | Reserved  | Reserved | Reserved |

Table 5-33 APB Device Clock Enable Control Register (APBCLK, address 0x5000\_0208) Bit Description.

| Bits | Symbol    | Description                                                   |
|------|-----------|---------------------------------------------------------------|
| [30] | ANA_EN    | Analog Block Clock Enable.                                    |
| [29] | I2S_EN    | I2S Clock Enable Control.                                     |
| [28] | ADC_EN    | Audio Analog-Digital-Converter (ADC) Clock Enable Control.    |
| [26] | SBRAM_EN  | Standby RAM Clock Enable Control.                             |
| [22] | ACMP_EN   | Analog Comparator Clock Enable Control.                       |
| [20] | PWM01_EN  | PWM Block Clock Enable Control.                               |
| [19] | CRC_EN    | Cyclic Redundancy Check Block clock enable.                   |
| [18] | BIQALC_EN | Biquad filter and Automatic Level Control block clock enable. |
| [16] | UART0_EN  | UART0 Clock Enable Control.                                   |
| [13] | DPWM_EN   | Differential PWM Speaker Driver Clock Enable Control.         |
| [12] | SPI0_EN   | SPI0 Clock Enable Control.                                    |
| [8]  | I2C0_EN   | I2C0 Clock Enable Control.                                    |
| [7]  | TMR1_EN   | Timer1 Clock Enable Control                                   |

|     |         |                                              |
|-----|---------|----------------------------------------------|
| [6] | TMR0_EN | Timer0 Clock Enable Control                  |
| [5] | RTC_EN  | Real-Time-Clock APB Interface Clock Control. |
| [4] | WDG_EN  | Watchdog Clock Enable Control                |

### DPD State Register (DPDSTATE)

The Deep Power Down State register is a user settable register that is preserved during Deep Power Down (DPD). Software can use this register to store a single byte during a DPD event. The DPD\_STATE\_RD register reads back the current state of the DPDSTATE register. To write to this register, set desired value in the DPD\_STATE\_WR register, this value will be latched in to the DPDSTATE register on next DPD event.

| Register | Offset      | R/W | Description                    |  |  |  |  | Reset Value |
|----------|-------------|-----|--------------------------------|--|--|--|--|-------------|
| DPDSTATE | CLK_BA + 0C | R/W | Deep Power Down State Register |  |  |  |  | 0x0000_XX00 |

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

Table 5-34 DPD State Register (DPDSTATE, address 0x5000\_020C) Bit Description.

| Bits   | Symbol       | Description                                                                                    |
|--------|--------------|------------------------------------------------------------------------------------------------|
| [15:8] | DPD_STATE_RD | Read back of DPDSTATE register. This register was preserved from last DPD event.               |
| [7:0]  | DPD_STATE_WR | To set the DPDSTATE register, write value to this register. Data is latched on next DPD event. |

Clock Source Select Control Register 0 (CLKSEL0)

| Register | Offset      | R/W | Description                            |  |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------------------|--|--|--|--|-------------|
| CLKSEL0  | CLK_BA + 10 | R/W | Clock Source Select Control Register 0 |  |  |  |  | 0x0000_0038 |

|          |         |         |   |   |        |   |   |
|----------|---------|---------|---|---|--------|---|---|
| 7        | 6       | 5       | 4 | 3 | 2      | 1 | 0 |
| Reserved | OSCFSel | STCLK_S |   |   | HCLK_S |   |   |

Table 5-35 Clock Source Select Register 0 (CLKSEL0, address 0x5000\_0210) Bit Description.

| Bits  | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]   | OSCFSel      | <b>OSC48M Frequency Select.</b> Determines which trim setting to use for OSC48M internal oscillator. Oscillator is factory trimmed within 1% to:<br>0: 49.152MHz (Default)<br>1: 32.768MHz                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [5:3] | STCLK_S      | <b>MCU Cortex_M0 SysTick clock source select.</b><br>These bits are protected, to write to bits first perform the unlock sequence ( <a href="#">see Protected Register Lock Key Register (REGLOCK)</a> )<br>000 = clock source from 10 kHz internal clock<br>001 = clock source from external 32kHz crystal clock<br>010 = clock source from 10 kHz internal oscillator divided by 2<br>011 = clock source from OSC49M internal oscillator divided by 2<br>1xx = clock source from HCLK ÷ 2 ( <b>Default</b> )<br><b>Note that to use STCLK_S as source of SysTic timer the CLKSRC bit of SysTick-&gt;CTRL must be set to 0.</b> |
| [2:0] | HCLK_S       | <b>HCLK clock source select.</b><br><b>Note:</b> <ol style="list-style-type: none"> <li>1. Ensure that related clock sources (pre-select and new-select) are enabled before updating register.</li> <li>2. These bits are protected, to write to bits first perform the unlock sequence (<a href="#">see Protected Register Lock Key Register (REGLOCK)</a>)</li> </ol> 000 = clock source from internal OSC48M oscillator. (001 = clock source from external 32kHz crystal clock<br>010 = clock source from internal 10 kHz oscillator clock<br>Others = reserved                                                               |

Clock Source Select Control Register 1 (CLKSEL1)

Clock multiplexors are a glitch free design to ensure smooth transitions between asynchronous clock sources. As such, both the current clock source and the target clock source must be enabled for switching to occur. Beware when switching from a low speed clock to a high speed clock that low speed clock remains on for at least one period before disabling.

| Register | Offset      | R/W | Description                            |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------------------|--|--|--|-------------|
| CLKSEL1  | CLK_BA + 14 | R/W | Clock Source Select Control Register 1 |  |  |  | 0x3300_771F |

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

Table 5-36 Clock Source Select Register 1 (CLKSEL1, address 0x5000\_0214) Bit Description.

| Bits    | Descriptions                                                                                                                                                                                                                                                                                                              |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [29:28] | <b>PWM01_S</b><br><br>PWM0 and PWM1 clock source select.<br>PWM0 and PWM1 uses the same clock source, and prescaler<br>00 = clock source from internal 10 kHz oscillator<br>01 = clock source from external 32kHz crystal clock<br>10 = clock source from HCLK<br>11 = clock source from internal OSC48M oscillator clock |
| [14:12] | <b>TMR1_S</b><br><br>TIMER1 clock source select.<br>000 = clock source from internal 10 kHz oscillator<br>001 = clock source from external 32kHz crystal clock<br>010 = clock source from HCLK<br>011 = clock source from external pin (GPIOA[15])<br>1xx = clock source from internal OSC48M oscillator clock            |

|        |               |                                                                                                                                                                                                                                                                                                  |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10:8] | <b>TMR0_S</b> | <b>TIMER0 clock source select.</b><br>000 = clock source from internal 10 kHz oscillator<br>001 = clock source from external 32kHz crystal clock<br>010 = clock source from HCLK<br>011 = clock source from external pin (GPIOA[14])<br>1xx = clock source from internal OSC48M oscillator clock |
| [4]    | <b>DPWM_S</b> | <b>Differential Speaker Driver PWM Clock Source Select.</b><br>0 = OSC48M clock<br>1 = 2x OSC48M clock                                                                                                                                                                                           |
| [1:0]  | <b>WDG_S</b>  | <b>WDG CLK clock source select.</b><br>00 = clock source from internal OSC48M oscillator clock<br>01 = clock source from external 32kHz crystal clock<br>10 = clock source from HCLK/2048 clock<br>11 = clock source from internal 10 kHz oscillator clock                                       |

Clock Divider Register (CLKDIV)

| Register | Offset      | R/W | Description                   |  |  |  |  | Reset Value |
|----------|-------------|-----|-------------------------------|--|--|--|--|-------------|
| CLKDIV   | CLK_BA + 18 | R/W | Clock Divider Number Register |  |  |  |  | 0x0000_0000 |

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

Table 5-37 Clock Divider Register (CLKDIV, address 0x5000\_0218) Bit Description.

| Bits    | Symbol | Description                                                                                                                        |
|---------|--------|------------------------------------------------------------------------------------------------------------------------------------|
| [23:16] | ADC_N  | <b>ADC clock divide number from ADC clock source</b><br>The ADC clock frequency = (ADC clock source frequency ) / (ADC_N + 1)      |
| [11:8]  | UART_N | <b>UART clock divide number from UART clock source</b><br>The UART clock frequency = (UART clock source frequency ) / (UART_N + 1) |
| [3:0]   | HCLK_N | <b>HCLK clock divide number from HCLK clock source</b><br>The HCLK clock frequency = (HCLK clock source frequency) / (HCLK_N + 1)  |

**Clock Source Select Control Register 2 (CLKSEL2)**

Before changing clock source, ensure that related clock sources (pre-select and new-select) are enabled.

| Register | Offset      | R/W | Description                            |  |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------------------|--|--|--|--|-------------|
| CLKSEL2  | CLK_BA + 1C | R/W | Clock Source Select Control Register 2 |  |  |  |  | 0xFFFF_FFFx |

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

Table 5-38 Clock Source Select Control Register 2 (CLKSEL2, address 0x5000\_021C) Bit Description.

| Bits   | Descriptions |                                                                                                                                                                                                                                      |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved     | Reserved                                                                                                                                                                                                                             |
| [1:0]  | <b>I2S_S</b> | <b>I2S Clock Source Select</b><br>00 = clock source from internal 10 kHz oscillator<br>01 = clock source from external 32kHz crystal clock<br>10 = clock source from HCLK<br>11 = clock source from internal OSC48M oscillator clock |

**Sleep Clock Enable Control Register (CLKSLEEP)**

These register bits are used to enable/disable clocks during sleep mode. It works in conjunction with **AHBCLK** and **APBCLK** clock register to determine whether a clock source remains active during CPU Sleep mode. For a clock to be active in Sleep mode, the appropriate clock must be enabled in the **AHBCLK** or **APBCLK** register **and** the bit must also be enabled in the **CLKSLEEP** register. In other words, to disable a clock in Sleep mode, write '0' to the appropriate bit in **CLKSPEEP**.

| Register | Offset      | R/W | Description                              |  | Reset Value |
|----------|-------------|-----|------------------------------------------|--|-------------|
| CLKSLEEP | CLK_BA + 20 | R/W | APB Device Clock Enable Control Register |  | 0xFFFF_FFFF |

Table 5-39 Sleep Clock Enable Control Register (CLKSLEEP, address 0x5000\_0220). Bit Description.

| 31       | 30       | 29       | 28       | 27       | 26        | 25       | 24       |
|----------|----------|----------|----------|----------|-----------|----------|----------|
| Reserved | ANA_EN   | I2S_EN   | ADC_EN   | Reserved | SBRAM_EN  | Reserved | Reserved |
| 23       | 22       | 21       | 20       | 19       | 18        | 17       | 16       |
| Reserved | ACMP_EN  | Reserved | PWM01_EN | CRC_EN   | BIQALC_EN | Reserved | UART0_EN |
| 15       | 14       | 13       | 12       | 11       | 10        | 9        | 8        |
| Reserved | Reserved | DPWM_EN  | SPI0_EN  | Reserved | Reserved  | Reserved | I2C0_EN  |
| 7        | 6        | 5        | 4        | 3        | 2         | 1        | 0        |
| TMR1_EN  | TMR0_EN  | RTC_EN   | WDG_EN   | Reserved | ISP_EN    | PDMA_EN  | CPU_EN   |

| Bits | Symbol    | Description                                                             |
|------|-----------|-------------------------------------------------------------------------|
| [30] | ANA_EN    | Analog Block Sleep Clock Enable.                                        |
| [29] | I2S_EN    | I2S Sleep Clock Enable Control.                                         |
| [28] | ADC_EN    | Audio Analog-Digital-Converter (ADC) Sleep Clock Enable Control.        |
| [26] | SBRAM_EN  | Standby RAM Sleep Clock Enable Control.                                 |
| [22] | ACMP_EN   | Analog Comparator Sleep Clock Enable Control.                           |
| [20] | PWM01_EN  | PWM Block Sleep Clock Enable Control.                                   |
| [19] | CRC_EN    | Cyclic Redundancy Check Sleep Block clock enable.                       |
| [18] | BIQALC_EN | Biquad filter/ALC block Sleep Clock Enable Control.                     |
| [16] | UART0_EN  | UART0 Sleep Clock Enable Control.                                       |
| [13] | DPWM_EN   | Differential PWM Speaker Driver Sleep Clock Enable Control.             |
| [12] | SPI0_EN   | SPI0 Sleep Clock Enable Control.                                        |
| [8]  | I2C0_EN   | I2C0 Sleep Clock Enable Control.                                        |
| [7]  | TMR1_EN   | Timer1 Sleep Clock Enable Control                                       |
| [6]  | TMR0_EN   | Timer0 Sleep Clock Enable Control                                       |
| [5]  | RTC_EN    | Real-Time- Sleep Clock APB Interface Clock Control.                     |
| [4]  | WDG_EN    | Watchdog Sleep Clock Enable Control                                     |
| [2]  | ISP_EN    | Flash ISP Controller Sleep Clock Enable Control                         |
| [1]  | PDMA_EN   | PDMA Controller Sleep Clock Enable Control.                             |
| [0]  | CPU_EN    | CPU Clock Sleep Enable (HCLK) must be left as '1' for normal operation. |

Preliminary

Power State Flag Register (PFLAGCON)

| Register | Offset     | R/W | Description               | Reset Value |
|----------|------------|-----|---------------------------|-------------|
| PFLAGCON | CLK_BA+ 24 | R/W | Power State Flag Register | 0x0000_0000 |

|          |   |   |   |         |           |         |   |
|----------|---|---|---|---------|-----------|---------|---|
| 7        | 6 | 5 | 4 | 3       | 2         | 1       | 0 |
| Reserved |   |   |   | PD_FLAG | STOP_FLAG | DS_FLAG |   |

Table 5-40 Power State Flag Register (PFLAGCON, address 0x5000\_0224) Bit Description.

| Bits | Descriptions |                                                                                            |
|------|--------------|--------------------------------------------------------------------------------------------|
| [2]  | PD_FLAG      | This flag is set if core logic was powered down to Standby (SPD). Write '1' to clear flag. |
| [1]  | STOP_FLAG    | This flag is set if core logic was stopped but not powered down. Write '1' to clear flag.  |
| [0]  | DS_FLAG      | This flag is set if core logic was placed in Deep Sleep mode. Write '1' to clear flag.     |

Debug Power Down Register (DBGPD)

| Register | Offset     | R/W | Description               | Reset Value |
|----------|------------|-----|---------------------------|-------------|
| DBGPD    | CLK_BA+ 28 | R/W | Debug Power Down Register | 0x0000_000X |

Table 5-41 Debug Power Down Register (DBGPD, address 0x5000\_0228) Bit Description.

|         |         |          |   |   |   |            |   |
|---------|---------|----------|---|---|---|------------|---|
| 7       | 6       | 5        | 4 | 3 | 2 | 1          | 0 |
| ICE_DAT | ICE_CLK | Reserved |   |   |   | DISABLE_PD |   |

| Bits | Descriptions |                                                                  |
|------|--------------|------------------------------------------------------------------|
| [7]  | ICE_DAT      | Read Only. Current state of ICE_DAT pin.                         |
| [6]  | ICE_CLK      | Read Only. Current state of ICE_CLK pin.                         |
| [0]  | DISABLE_PD   | 1 = Disable power down requests. 0 = enable power down requests. |

**5.4 General Purpose I/O**

### 5.4.1 Overview and Features

Up to 24 General Purpose I/O pins are available on the ISD9160. These are shared peripheral special function pins under control of the alternate configuration registers. These 24 pins are arranged in 2 ports named with GPIOA, and GPIOB. GPIOA has sixteen pins and GPIOB has eight. Each one of the 24 pins is independent and has corresponding register bits to control the pin mode function and data.

The I/O type of each GPIO pin can be independently configured as an input, output, open-drain or in a quasi-bidirectional mode. Upon chip reset, all GPIO pins are configured in quasi-bidirectional mode and port data register resets high.

When device is in deep power down (DPD) mode, all GPIO pins become high impedance.

GPIO can generate interrupt signals to the core as either level sensitive or edge sensitive inputs. Edge sensitive inputs can also be de-bounced.

In quasi-bidirectional mode, each GPIO pin has a weak pull-up resistor which is approximately  $110\text{K}\Omega\sim300\text{K}\Omega$  for  $V_{DD}$  from 5.0V to 2.4V.

Each pin can generate and interrupt exception to the Cortex M0 core. GPIOB[0] and GPIOB[1] can generate interrupts to system interrupt number IRQ2 and IRQ3 respectively (see Table 5-15). All other GPIO generate and exception to interrupt number IRQ4.

### 5.4.2 GPIO I/O Modes

The I/O mode of each GPIO pin is controlled by the register GPIOx->PMD. ( $x=A$  or  $B$ ). Each pin has two bits of control giving four possible states:

#### 5.4.2.1 Input Mode

For GPIOx->PMD.PMD $n$  = 00b the GPIOx port [ $n$ ] pin is in Input Mode. The GPIO pin is in a tri-state (high impedance) condition without output drive capability. The GPIOx->PIN value reflects the status of the corresponding port pins.

#### 5.4.2.2 Output Mode

For GPIOx->PMD.PMD $n$  = 01b the GPIOx port [ $n$ ] pin is in Output Mode. The GPIO pin supports a digital output function with current source/sink capability. The bit value in the corresponding bit [ $n$ ] of GPIOx->DOUT is driven to the pin.



Figure 5-6 Output Mode: Push-Pull Output

#### 5.4.2.3 Open-Drain Mode

For GPIOx->PMD.PMD $n$  = 10b the GPIOx port [n] pin is in Open-Drain mode. The GPIO pin supports a digital output function but only with sink current capability, an additional pull-up resistor is needed for defining a high state. If the bit value in the corresponding bit [n] of GPIOx\_DOUT is "0", pin is driven low. If the bit value in the corresponding bit [n] of GPIOx\_DOUT is "1", the pin state is defined by the external load on the pin.



Figure 5-7 Open-Drain Output

#### 5.4.2.4 Quasi-bidirectional Mode Explanation

For GPIOx->PMD.PMD $n$  = 11b the GPIOx port [n] pin is in Quasi-bidirectional mode and the I/O pin supports digital output and input function where the source current is only between 30-200 $\mu$ A. Before input function is performed the corresponding bit in GPIOx\_DOUT must be set to 1. The quasi-bidirectional output is common on the 80C51 and most of its derivatives. If the bit value in the corresponding bit [n] of GPIOx\_DOUT is "0", the pin will drive a "low" output to the pin. If the bit value in the corresponding bit [n] of GPIOx\_DOUT is "1", the pin will check the pin value. If pin value is high, no action is taken. If pin state is low, then pin will drive a strong high for 2 clock cycles. After this the pin has an internal pull-up resistor connected. Note that the source current capability in quasi-bidirectional mode is approximately 200 $\mu$ A to 30 $\mu$ A for VDD from 5.0V to 2.5V.



Figure 5-8 Quasi-bidirectional GPIO Mode

### 5.4.3 GPIO Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                   | Offset      | R/W  | Description                        | Reset Value   | Reference                  |
|----------------------------|-------------|------|------------------------------------|---------------|----------------------------|
| <b>GP_BA = 0x5000_4000</b> |             |      |                                    |               |                            |
| <b>GPIOA_PMD</b>           | GP_BA+0x000 | R/W  | GPIO Port A Bit Mode Control       | 0xFFFF_FFFF   | <a href="#">Table 5-42</a> |
| <b>GPIOA_INDIS</b>         | GP_BA+0x004 | R/W  | GPIO Port A Bit Input Disable      | 0x0000_0000   | <a href="#">Table 5-43</a> |
| <b>GPIOA_DOUT</b>          | GP_BA+0x008 | R/W  | GPIO Port A Data Output Value      | 0x0000_FFFF   | <a href="#">Table 5-44</a> |
| <b>GPIOA_DMASK</b>         | GP_BA+0x00C | R/W  | GPIO Port A Data Output Write Mask | 0x0000_0000   | <a href="#">Table 5-45</a> |
| <b>GPIOA_PIN</b>           | GP_BA+0x010 | R    | GPIO Port A Pin Value              | 0x0000_XXXX   | <a href="#">Table 5-46</a> |
| <b>GPIOA_DBEN</b>          | GP_BA+0x014 | R/W  | GPIO Port A De-bounce Enable       | 0x0000_0000   | <a href="#">Table 5-47</a> |
| <b>GPIOA_IMD</b>           | GP_BA+0x018 | R/W  | GPIO Port A Interrupt Mode Control | 0x0000_0000   | <a href="#">Table 5-48</a> |
| <b>GPIOA_IEN</b>           | GP_BA+0x01C | R/W  | GPIO Port A Interrupt Enable       | 0x0000_0000   | <a href="#">Table 5-49</a> |
| <b>GPIOA_ISRC</b>          | GP_BA+0x020 | R/WC | GPIO Port A Interrupt Source Flag  | 0xXXXX_XXXX   | <a href="#">Table 5-50</a> |
| <b>GPIOB_PMD</b>           | GP_BA+0x040 | R/W  | GPIO Port B Bit Mode Enable        | 0xFFFF_FFFF   | <a href="#">Table 5-42</a> |
| <b>GPIOB_INDIS</b>         | GP_BA+0x044 | R/W  | GPIO Port B Bit Input Disable      | 0x0000_0000   | <a href="#">Table 5-43</a> |
| <b>GPIOB_DOUT</b>          | GP_BA+0x048 | R/W  | GPIO Port B Data Output Value      | 0x0000_FFFF   | <a href="#">Table 5-44</a> |
| <b>GPIOB_DMASK</b>         | GP_BA+0x04C | R/W  | GPIO Port B Data Output Write Mask | 0x0000_0000   | <a href="#">Table 5-45</a> |
| <b>GPIOB_PIN</b>           | GP_BA+0x050 | R    | GPIO Port B Pin Value              | 0x0000_XXXX   | <a href="#">Table 5-46</a> |
| <b>GPIOB_DBEN</b>          | GP_BA+0x054 | R/W  | GPIO Port B De-bounce Enable       | 0x0000_0000   | <a href="#">Table 5-47</a> |
| <b>GPIOB_IMD</b>           | GP_BA+0x058 | R/W  | GPIO Port B Interrupt Mode Control | 0x0000_0000   | <a href="#">Table 5-48</a> |
| <b>GPIOB_IEN</b>           | GP_BA+0x05C | R/W  | GPIO Port B Interrupt Enable       | 0x0000_0000   | <a href="#">Table 5-49</a> |
| <b>GPIOB_ISRC</b>          | GP_BA+0x060 | R/WC | GPIO Port B Interrupt Source Flag  | 0xXXXX_XXXX   | <a href="#">Table 5-50</a> |
| <b>DBNCECON</b>            | GP_BA+0x180 | R/W  | De-bounce Cycle Control            | Re0x0000_0020 | <a href="#">Table 5-51</a> |

#### 5.4.4 GPIO Control Register Description

##### GPIO Port [A/B] I/O Mode Control (GPIOx PMD)

| Register  | Offset      | R/W | Description                      | Reset Value |
|-----------|-------------|-----|----------------------------------|-------------|
| GPIOA_PMD | GP_BA+0x000 | R/W | GPIO Port A Pin I/O Mode Control | 0xFFFF_FFFF |
| GPIOB_PMD | GP_BA+0x040 | R/W | GPIO Port B Pin I/O Mode Control | 0xFFFF_FFFF |

Table 5-42 GPIO Mode Control Register

|              |    |              |    |    |              |    |              |
|--------------|----|--------------|----|----|--------------|----|--------------|
| 31           | 30 | 29           | 28 | 27 | 26           | 25 | 24           |
| <b>PMD15</b> |    | <b>PMD14</b> |    |    | <b>PMD13</b> |    | <b>PMD12</b> |
| 23           | 22 | 21           | 20 | 19 | 18           | 17 | 16           |
| <b>PMD11</b> |    | <b>PMD10</b> |    |    | <b>PMD9</b>  |    | <b>PMD8</b>  |
| 15           | 14 | 13           | 12 | 11 | 10           | 9  | 8            |
| <b>PMD7</b>  |    | <b>PMD6</b>  |    |    | <b>PMD5</b>  |    | <b>PMD4</b>  |
| 7            | 6  | 5            | 4  | 3  | 2            | 1  | 0            |
| <b>PMD3</b>  |    | <b>PMD2</b>  |    |    | <b>PMD1</b>  |    | <b>PMD0</b>  |

| Bits       | Descriptions             |                                                                                                                                                                                                                                                                                                                |
|------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2n+1 :2n] | <b>PMD<math>n</math></b> | <b>GPIO<math>x</math> I/O Pin[<math>n</math>] Mode Control</b><br>Determine each I/O type of GPIO $x$ pins<br>00 = GPIO port [n] pin is in INPUT mode.<br>01 = GPIO port [n] pin is in OUTPUT mode.<br>10 = GPIO port [n] pin is in Open-Drain mode.<br>11 = GPIO port [n] pin is in Quasi-bidirectional mode. |

GPIO Port [A/B] Input Disable (GPIOx\_INDIS)

| Register    | Offset      | R/W | Description                   | Reset Value |
|-------------|-------------|-----|-------------------------------|-------------|
| GPIOA_INDIS | GP_BA+0x004 | R/W | GPIO Port A Pin Input Disable | 0x0000_0000 |
| GPIOB_INDIS | GP_BA+0x044 | R/W | GPIO Port B Pin Input Disable | 0x0000_0000 |

Table 5-43 GPIO Input Disable Register

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

| Bits    | Descriptions |                                                                                                                                                                |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | INDIS        | <b>INDIS: GPIOx Pin[n] OFF digital input path Enable</b><br>1 = Disable IO digital input path (low leakage mode)<br>0 = Enable IO digital input path (Default) |
| [15:0]  | Reserved     | Reserved                                                                                                                                                       |

GPIO Port [A/B] Data Output Value (GPIOx\_DOUT)

| Register   | Offset      | R/W | Description                   | Reset Value |
|------------|-------------|-----|-------------------------------|-------------|
| GPIOA_DOUT | GP_BA+0x008 | R/W | GPIO Port A Data Output Value | 0x0000_FFFF |
| GPIOB_DOUT | GP_BA+0x048 | R/W | GPIO Port B Data Output Value | 0x0000_XXFF |

Table 5-44 GPIO Data Output Register (GPIOx\_DOUT)

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

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n]  | DOUT[n]      | <p><b>GPIOx Pin[n] Output Value</b></p> <p>Each of these bits controls the status of a GPIO pin when the GPIO pin is configured as output, open-drain or quasi-bidirectional mode.</p> <p>1 = GPIO port [A/B] Pin[n] will drive High if the corresponding output mode bit is set.</p> <p>0 = GPIO port [A/B] Pin[n] will drive Low if the corresponding output mode bit is set.</p> |

GPIO Port [A/B] Data Output Write Mask (GPIOx\_DMASK)

| Register    | Offset      | R/W | Description                        | Reset Value |
|-------------|-------------|-----|------------------------------------|-------------|
| GPIOA_DMASK | GP_BA+0x00C | R/W | GPIO Port A Data Output Write Mask | 0xFFFF_0000 |
| GPIOB_DMASK | GP_BA+0x04C | R/W | GPIO Port B Data Output Write Mask | 0xFFFF_0000 |

Table 5-45 GPIO Data Output Write Mask Register (GPIOx\_MASK)

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

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                                               |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n]  | DMASK[n]     | <p><b>Port [A/B] Data Output Write Mask</b></p> <p>These bits are used to protect the corresponding register of GPIOx_DOUT bit[n]. When set the DMASK bit[n] to “1”, the corresponding DOUTn bit is write protected.</p> <p>0 = The corresponding GPIO_DOUT[n] bit can be updated<br/>1 = The corresponding GPIO_DOUT[n] bit is read only</p> |

GPIO Port [A/B] Pin Value (GPIOx\_PIN)

| Register  | Offset      | R/W | Description           | Reset Value |
|-----------|-------------|-----|-----------------------|-------------|
| GPIOA_PIN | GP_BA+0x010 | R   | GPIO Port A Pin Value | 0x0000_XXXX |
| GPIOB_PIN | GP_BA+0x050 | R   | GPIO Port B Pin Value | 0x0000_XXXX |

Table 5-46 GPIO PIN Value Register (GPIOx\_PIN)

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

| Bits | Descriptions |                                                                                                                             |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------|
| [n]  | PIN[n]       | <b>Port [A/B] Pin Values</b><br>The value read from each of these bit reflects the actual status of the respective GPIO pin |

GPIO Port [A/B] De-bounce Enable (GPIOx\_DBEN)

| Register   | Offset      | R/W | Description                  | Reset Value |
|------------|-------------|-----|------------------------------|-------------|
| GPIOA_DBEN | GP_BA+0x014 | R/W | GPIO Port A De-bounce Enable | 0xFFFF_0000 |
| GPIOB_DBEN | GP_BA+0x054 | R/W | GPIO Port B De-bounce Enable | 0xFFFF_0000 |

Table 5-47 GPIO Debounce Enable Register (GPIOx\_DBEN)

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

| Bits | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n]  | <p><b>Port [A/B] Input Signal De-bounce Enable</b></p> <p>DBEN[n] used to enable the de-bounce function for each corresponding bit. For an edge triggered interrupt to be generated, input signal must be valid for two consecutive de-bounce periods. The de-bounce time is controlled by the <b>DBNCECON</b> register.</p> <p>The DBEN[n] is used for “edge-trigger” interrupt only; it is ignored for “level trigger” interrupt</p> <p>0 = The bit[n] de-bounce function is disabled<br/>1 = The bit[n] de-bounce function is enabled</p> |

GPIO Port [A/B] Interrupt Mode Control (GPIOx\_IMD)

| Register  | Offset      | R/W | Description                        | Reset Value |
|-----------|-------------|-----|------------------------------------|-------------|
| GPIOA_IMD | GP_BA+0x018 | R/W | GPIO Port A Interrupt Mode Control | 0xFFFF_0000 |
| GPIOB_IMD | GP_BA+0x058 | R/W | GPIO Port B Interrupt Mode Control | 0xFFFF_0000 |

Table 5-48 GPIO Interrupt Mode Control (GPIOx\_IMD)

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

| Bits | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n]  | <b>Port [A/B] Edge or Level Detection Interrupt Control</b><br>IMD[n] used to control whether the interrupt mode is level triggered or edge triggered. If the interrupt mode is edge triggered, edge de-bounce is controlled by the DBEN register. If the interrupt mode is level triggered, the input source is sampled each clock to generate an interrupt<br>0 = Edge triggered interrupt<br>1 = Level triggered interrupt<br>If level triggered interrupt is selected, then only one level can be selected in the GPIOX_IEN register. If both levels are set no interrupt will occur |

GPIO Port [A/B] Interrupt Enable Control (GPIOx\_IEN)

| Register  | Offset      | R/W | Description                  | Reset Value |
|-----------|-------------|-----|------------------------------|-------------|
| GPIOA_IEN | GP_BA+0x01C | R/W | GPIO Port A Interrupt Enable | 0x0000_0000 |
| GPIOB_IEN | GP_BA+0x05C | R/W | GPIO Port B Interrupt Enable | 0x0000_0000 |

Table 5-49 GPIO Interrupt Enable Control Register (GPIOx\_IEN)

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

| Bits   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n+16] | <p><b>Port [A/B] Interrupt Enable by Input Rising Edge or Input Level High</b></p> <p>IR_EN[n] is used to enable the rising/high interrupt for each of the corresponding GPIO pins. It also enables the pin wakeup function.</p> <p>If the interrupt is configured in level trigger mode, a level “high” will generate an interrupt.</p> <p>If the interrupt is configured in edge trigger mode, a state change from “low-to-high” will generate an interrupt.</p> <p>GPB.0 and GPB.1 trigger individual IRQ vectors (IRQ2/IRQ3) while remaining GPIO trigger a single interrupt vector IRQ4.</p> <p>1 = Enable GPIOx[n] for level-high or low-to-high interrupt<br/>0 = Disable GPIOx[n] for level-high or low-to-high interrupt.</p> |
| [n]    | <p><b>Port [A/B] Interrupt Enable by Input Falling Edge or Input Level Low</b></p> <p>IF_EN[n] is used to enable the falling/low interrupt for each of the corresponding GPIO pins. It also enables the pin wakeup function.</p> <p>If the interrupt is configured in level trigger mode, a level “low” will generate an interrupt.</p> <p>If the interrupt is configured in edge trigger mode, a state change from “high-to-low” will generate an interrupt.</p> <p>GPB.0 and GPB.1 trigger individual IRQ vectors (IRQ2/IRQ3) while remaining GPIO trigger a single interrupt vector IRQ4.</p> <p>1 = Enable GPIOx[n] for low-level or high-to-low interrupt<br/>0 = Disable GPIOx[n] for low-level or high-to-low interrupt</p>     |

GPIO Port [A/B] Interrupt Trigger Source (GPIOx\_ISRC)

| Register   | Offset      | R/W  | Description                                    |  |  |  | Reset Value |
|------------|-------------|------|------------------------------------------------|--|--|--|-------------|
| GPIOA_ISRC | GP_BA+0x020 | R/WC | GPIO Port A Interrupt Trigger Source Indicator |  |  |  | 0x0000_0000 |
| GPIOB_ISRC | GP_BA+0x060 | R/WC | GPIO Port B Interrupt Trigger Source Indicator |  |  |  | 0x0000_0000 |

Table 5-50 GPIO Interrupt Trigger Source Register (GPIOx\_ISRC)

|               |    |    |    |    |    |   |   |
|---------------|----|----|----|----|----|---|---|
| 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| IF_ISRC[15:8] |    |    |    |    |    |   |   |
| 7             | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| IF_ISRC[7:0]  |    |    |    |    |    |   |   |

| Bits | Descriptions |                                                                                                                                                                                                                                                              |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n]  | ISRC[n]      | <p><b>Port [A/B] Interrupt Trigger Source Indicator</b></p> <p>Read :</p> <p>1 = Indicates GPIOx[n] generated an interrupt</p> <p>0 = No interrupt from GPIOx[n]</p> <p>Write :</p> <p>1= Clear the corresponding pending interrupt.</p> <p>0= No action</p> |

Interrupt De-bounce Control (DBNCECON)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| DBNCECON | GP_BA+0x180 | R/W | External Interrupt De-bounce Control | 0x0000_0020 |

Table 5-51 GPIO Interrupt De-bounce Control Register (DBNCECON)

| 7        | 6 | 5       | 4        | 3        | 2 | 1 | 0 |
|----------|---|---------|----------|----------|---|---|---|
| Reserved |   | ICLK_ON | DBCLKSRC | DBCLKSEL |   |   |   |

| Bits  | Descriptions |                                                                                                                                                                                                                                                                                                                                          |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5]   | ICLK_ON      | <p><b>Interrupt clock On mode</b><br/> Set this bit “0” will gate the clock to the interrupt generation circuit if the GPIOx[n] interrupt is disabled.<br/> 0 = disable the clock if the GPIOx[n] interrupt is disabled<br/> 1 = Interrupt generation clock always active.</p>                                                           |
| [4]   | DBCLKSRC     | <p><b>De-bounce counter clock source select</b><br/> 1 = De-bounce counter clock source is the internal 10 kHz clock<br/> 0 = De-bounce counter clock source is HCLK</p>                                                                                                                                                                 |
| [3:0] | DBCLKSEL     | <p><b>De-bounce sampling cycle selection.</b><br/> For edge level interrupt GPIO state is sampled every <math>2^{(DBCLKSEL)}</math> de-bounce clocks. For example if <b>DBCLKSRC= 6</b>, then interrupt is sampled every <math>2^6=64</math> de-bounce clocks. If <b>DBCLKSRC</b> is 10kHz oscillator this would be a 64ms debounce.</p> |

## 5.5 Brownout Detection and Temperature Alarm

The ISD9160 is equipped with a Brown-Out voltage detector and Over Temperature Alarm. The Brown-Out detector features a configurable trigger level and can be configured by flash to be active upon reset. The Brown-Out detector also has a power saving mode where detection can be set up to be active for a configurable on and off time.

TALARM and BOD operation require that the OSC10K low power oscillator is enabled (SYSCLK->PWRCON.OSC10K\_ENB = 0).

The over temperature alarm is designed to protect the chip from dangerously high internal temperatures, generally associated with excessive load (or short circuit) on the speaker driver. The temperature alarm can generate an interrupt to which the CPU can respond and shut down the speaker driver. It is recommended that users implement this function due to the drive strength of the speaker driver has the capability of damaging the chip.

### 5.5.1 Brownout and Temperature Alarm Register Map

R: read only, W: write only, R/W: both read and write

| Register                    | Offset       | R/W | Description                       | Reset Value | Reference                  |
|-----------------------------|--------------|-----|-----------------------------------|-------------|----------------------------|
| <b>BOD_BA = 0x4008_4000</b> |              |     |                                   |             |                            |
| <b>BOD_SEL</b>              | BOD_BA +0x00 | R/W | Brownout Detector Select Register | 0x0000_0000 | <a href="#">Table 5-52</a> |
| <b>BOD_EN</b>               | BOD_BA +0x04 | R/W | Brownout Detector Enable Register | 0x0000_00XX | <a href="#">Table 5-53</a> |
| <b>TALARM_SEL</b>           | BOD_BA +0x08 | R/W | Temperature Alarm Select Register | 0x0000_0000 | <a href="#">Table 5-55</a> |
| <b>TALARM_EN</b>            | BOD_BA +0x0C | R/W | Temperature Alarm Enable Register | 0x0000_0000 | <a href="#">Table 5-56</a> |
| <b>DET_TIMER</b>            | BOD_BA +0x10 | R/W | Brownout Detector Timer Register  | 0x0000_0000 | <a href="#">Table 5-54</a> |

Brown-Out Detector Select Register (BOD\_SEL)

| Register | Offset   | R/W | Description                        | Reset Value |
|----------|----------|-----|------------------------------------|-------------|
| BOD_SEL  | BOD_BA+0 | R/W | Brown Out Detector Select Register | 0x0000_0000 |

Table 5-52 Brownout Detector Select Register (BOD\_SEL, address 0x4008\_4000)

| 7        | 6 | 5 | 4 | 3              | 2              | 1 | 0 |
|----------|---|---|---|----------------|----------------|---|---|
| Reserved |   |   |   | <b>BOD_HYS</b> | <b>BOD_LVL</b> |   |   |

| Bits   | Descriptions   |                                                                                                                                                    |
|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved       | Reserved                                                                                                                                           |
| [3]    | <b>BOD_HYS</b> | <b>BOD Hysteresis</b><br>1= Enable Hysteresis of BOD detection.<br>0= Hysteresis Disabled.                                                         |
| [2:0]  | <b>BOD_LVL</b> | <b>BOD Voltage Level</b><br>111b = 4.6V<br>110b = 3.0V<br>101b = 2.8V<br>100b = 2.625V<br>011b = 2.5V<br>010b = 2.4V<br>001b = 2.2V<br>000b = 2.1V |

**Brown-Out Detector Enable Register (BOD\_EN)**

This register is initialized by user flash configuration bit config0[23] (see [Section 6.7](#)). If config0[23]=1, then reset value of BODEN is 0x7. The effect of this is to generate a NMI interrupt (default NMI interrupt is BOD interrupt) if BOD circuit detects a voltage below 2.1V. The NMI ISR can be defined by the user to respond to this low voltage level.

| Register      | Offset   | R/W | Description                        | Reset Value |
|---------------|----------|-----|------------------------------------|-------------|
| <b>BOD_EN</b> | BOD_BA+4 | R/W | Brown Out Detector Enable Register | 0x0000_00XX |

Table 5-53 Detector Enable Register (BOD\_EN, address 0x4008\_4004)

|   |          |   |                |     |    |   |           |
|---|----------|---|----------------|-----|----|---|-----------|
| 7 | 6        | 5 | 4              | 3   | 2  | 1 | 0         |
|   | Reserved |   | <b>BOD_OUT</b> | INT | IE |   | <b>EN</b> |

| Bits   | Descriptions   |                                                                                                                                                                      |
|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved       | Reserved                                                                                                                                                             |
| [4]    | <b>BOD_OUT</b> | Output of BOD detection block. This signal can be monitored to determine the current state of the BOD comparator. BOD_OUT=1 implies that VCC is less than BOD_LVL.   |
| [3]    | <b>INT</b>     | <b>Current status of interrupt.</b><br>Latched whenever a BOD event occurs and IE=1. Write '1' to clear.                                                             |
| [2]    | <b>IE</b>      | <b>BOD Interrupt Enable</b><br>1= Enable BOD Interrupt.<br>0= Disable BOD Interrupt.                                                                                 |
| [1:0]  | <b>EN</b>      | <b>BOD Enable.</b><br>1xb = Enable continuous BOD detection.<br>01b = Enable time multiplexed BOD detection. See DET_TIMER register.<br>00b = Disable BOD Detection. |

**Detection Time Multiplex Register (DET\_TIMER)**

The BOD detector can be set up to take periodic samples of the supply voltage to minimize power consumption. The circuit can be configured and used in Standby Power Down (SPD) mode and can wake up the device if a BOD is event detected. The detection timer uses the OSC10K oscillator as time base so this oscillator must be active for timer operation. When active the BOD circuit requires ~165uA. With default timer settings, average current reduces to 500nA  $165\mu\text{A} \times \text{ON\_DUR}/(\text{ON\_DUR}+\text{OFF\_DUR})$ .

| Register  | Offset    | R/W | Description                       |  |  |  | Reset Value |
|-----------|-----------|-----|-----------------------------------|--|--|--|-------------|
| DET_TIMER | BOD_BA+10 | R/W | Detection Time Multiplex Register |  |  |  | 0x0003_03E3 |

Table 5-54 Detection Time Multiplex Register (DET\_TIMER, address 0x4008\_4010)

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

| Bits    | Descriptions   |                                                                                                          |
|---------|----------------|----------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved       | Reserved                                                                                                 |
| [19:16] | <b>ON_DUR</b>  | Time BOD detector is active: $(\text{ON\_DUR}+1) * 100\text{us}$ . Minimum value is 1. (default = 400us) |
| [15:0]  | <b>OFF_DUR</b> | Time BOD detector is off: $(\text{OFF\_DUR}+1)*100\text{us}$ . Minimum value is 7. (default = 99.6ms)    |

Temperature Alarm Select Register (TALARM\_SEL)

| Register   | Offset   | R/W | Description                       | Reset Value |
|------------|----------|-----|-----------------------------------|-------------|
| TALARM_SEL | BOD_BA+8 | R/W | Temperature Alarm Select Register | 0x0000_0000 |

Table 5-55 Temperature Alarm Select Register (TALARM\_SEL, address 0x4008\_4008)

|          |   |   |   |     |   |   |   |
|----------|---|---|---|-----|---|---|---|
| 7        | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
| Reserved |   |   |   | LVL |   |   |   |

| Bits   | Descriptions |                                                                                                                          |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved     | Reserved                                                                                                                 |
| [3:0]  | LVL          | <b>Temperature Alarm Sense Level</b><br>1000b = 145C      0100b = 135C<br>0010b = 125C      0001b = 115C<br>0000b = 105C |

Temperature Alarm Enable Register (TALARM\_EN)

| Register  | Offset   | R/W | Description                       | Reset Value |
|-----------|----------|-----|-----------------------------------|-------------|
| TALARM_EN | BOD_BA+C | R/W | Temperature Alarm Enable Register | 0x0000_00XX |

Table 5-56 Temperature Alarm Enable Register (TALARM\_EN, address 0x4008\_400C)

|          |   |   |   |     |    |        |    |
|----------|---|---|---|-----|----|--------|----|
| 7        | 6 | 5 | 4 | 3   | 2  | 1      | 0  |
| Reserved |   |   |   | INT | IE | TALARM | EN |

| Bits   | Descriptions |                                                                                                                        |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved     | Reserved                                                                                                               |
| [3]    | INT          | <b>Current status of interrupt.</b><br>Latched whenever a Temperature Sense event occurs and IE=1. Write '1' to clear. |
| [2]    | IE           | <b>TALARM Interrupt Enable</b><br>1= Enable TALARM Interrupt, 0= Disable TALARM Interrupt.                             |
| [1]    | TALARM       | <b>Output of TALARM block.</b> Can be polled to determine whether TALARM active (=1).                                  |
| [0]    | EN           | <b>TALARM Enable.</b><br>1 = Enable TALARM detection, 0 = Disable TALARM Detection.                                    |

Preliminary

## 5.6 I2C Serial Interface Controller (Master/Slave)

### 5.6.1 Introduction

I2C is a two-wire, bi-directional serial bus that provides a simple and efficient method of data exchange between devices. The I2C standard is a true multi-master bus including collision detection and arbitration that prevents data corruption if two or more masters attempt to control the bus simultaneously. Serial, 8-bit oriented, bi-directional data transfers can be made up 1.0 Mbps.

Data is transferred between a Master and a Slave synchronously to SCL on the SDA line on a byte-by-byte basis. Each data byte is 8 bits long. There is one SCL clock pulse for each data bit with the MSB being transmitted first. An acknowledge bit follows each transferred byte. Each bit is sampled during the high period of SCL; therefore, the SDA line may be changed only during the low period of SCL and must be held stable during the high period of SCL. A transition on the SDA line while SCL is high is interpreted as a command (START or STOP). Please refer to Figure 5-9 for more detail I2C BUS Timing.



Figure 5-9 I2C Bus Timing

The device's on-chip I2C logic provides the serial interface that meets the I2C bus standard mode specification. The I2C port handles byte transfers autonomously. To enable this port, the bit ENS1 in I2C->CON should be set to '1'. The I2C H/W interfaces to the I2C bus via two pins: I2C\_SDA (which can be configured as GPIOA[10], GPIOB[3] or GPIOA[3], serial data line) and I2C\_SCL (which can be configured as GPIOA[11], GPIOB[2] or GPIOA[1], serial clock line). See [Table 5-7](#) and [Table 5-8](#) for alternate GPIO pin functions. Pull up resistor is needed for these pins for I2C operation as these are open drain pins.

The I2C bus uses two wires (SDA and SCL) to transfer information between devices connected to the bus. The main features of the bus are:

- Master/Slave up to 1Mbit/s
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allows devices with different bit rates to communicate via one serial bus
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer
- Built-in a 14-bit time-out counter will request the I2C interrupt if the I2C bus hangs up and timer-out counter overflows.
- External pull-up are needed for high output

- Programmable clocks allow versatile rate control
- Supports 7-bit addressing mode
- I2C-bus controllers support multiple address recognition ( Four slave address with mask option)

#### 5.6.1.1 I<sup>2</sup>C Protocol

Normally, a standard communication consists of four parts:

- 1) START or Repeated START signal generation
- 2) Slave address transfer
- 3) Data transfer
- 4) STOP signal generation



Figure 5-10 I2C Protocol

#### 5.6.1.2 Data transfer on the I2C-bus

A master-transmitter always begins by addressing a slave receiver with a 7-bit address. For a transaction where the master-transmitter is sending data to the slave, the transfer direction is not changed, master is always transmitting and slave acknowledges the data, see Figure 5-11.



Figure 5-11 Master Transmits Data to Slave

For a master to read data from a slave, master addresses slave with the R/W bit set to '1', immediately after the first byte (address) is acknowledged by the slave the transfer direction is changed and slave sends data to the master and master acknowledges the data transfer.



Figure 5-12 Master Reads Data from Slave

### 5.6.1.3 START or Repeated START signal

When the bus is free/idle, meaning no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal, usually referred to as the S-bit, is defined as a HIGH to LOW transition on the SDA line while SCL is HIGH. The START signal denotes the beginning of a new data transfer.

A Repeated START (Sr) is a START signal without first generating a STOP signal. The master uses this method to communicate with another slave or the same slave in a different transfer direction (e.g. from writing to a device to reading from a device) without releasing the bus.

#### STOP signal

The master can terminate the communication by generating a STOP signal. A STOP signal, usually referred to as the P-bit, is defined as a LOW to HIGH transition on the SDA line while SCL is HIGH.



Figure 5-13 START and STOP condition

### 5.6.1.4 Slave Address Transfer

The first byte of data transferred by the master immediately after the START signal is the slave address. This is a 7-bits calling address followed by a RW bit. The RW bit signals the slave the data transfer direction. No two slaves in the system can have the same address. Only the slave with an address that matches the one transmitted by the master will respond by returning an acknowledge bit by pulling the SDA low at the 9th SCL clock cycle.

### 5.6.1.5 Data Transfer

Once successful slave addressing has been achieved, the data transfer can proceed on a byte-by-byte basis in the direction specified by the RW bit sent by the master. Each transferred byte is followed by an acknowledge bit on the 9th SCL clock cycle. If the slave signals a Not Acknowledge (NACK), the master can generate a STOP signal to abort the data transfer or generate a Repeated START signal and start a new transfer cycle.

If the master, as the receiving device, does Not Acknowledge (NACK) the slave, the slave releases the SDA line for the master to generate a STOP or Repeated START signal.



Figure 5-14 Bit Transfer on the I2C bus



Figure 5-15 Acknowledge on the I2C bus

### 5.6.2 I2C Protocol Registers

The CPU interfaces to the SIO port through the following thirteen special function registers: I2C->CON (control register), I2C->STATUS (status register), I2C->DATA (data register), I2C->ADDRn (address registers, n=0~3), I2C->ADRMn (address mask registers, n=0~3), I2C->CLK (clock rate register) and I2C->TOC (Time-out counter register). Bits 31~ bit 8 of these I2C special function registers are reserved. These bits do not have any functions and are all zero if read back.

When I2C port is enabled by setting ENSI (I2C->CON[6]) to high, the internal states will be controlled by I2C->CON and I2C logic hardware. Once a new status code is generated and stored in I2C->STATUS, the I2C Interrupt Flag bit SI (I2C->CON[3]) will be set automatically. If the Enable Interrupt bit EI (I2C->CON[7]) is set high at this time, the I2C interrupt will be generated. The bit field I2C->STATUS[7:3] stores the internal state code, the lowest 3 bits of I2C->STATUS are always zero and the contents are stable until SI is cleared by software. The base address of the I2C peripheral on the ISD9160 is 0x4002\_0000.

#### 5.6.2.1 Address Registers (I2C->ADDR)

I2C port is equipped with four slave address registers I2C->ADDRn (n=0~3). The contents of the register are irrelevant when I2C is in master mode. In the slave mode, the bit field I2C->ADDRn[7:1] must be loaded with the MCU's own slave address. The I2C hardware will react if the contents of I2C->ADDR are matched with the received slave address.

The I2C ports support the "General Call" function. If the GC bit (I2C->ADDRn[0]) is set the I2C port hardware will respond to General Call address (00H). Clear GC bit to disable general call function.

When GC bit is set, the I2C is in Slave mode, it can be received the general call address by 00H after Master send general call address to I2C bus, then it will follow status of GC mode. If it is in master mode, the AA bit (I2C->CON[2], Assert Acknowledge control bit) must be cleared when it will send general call address of 00H to I2C bus.

I2C-bus controllers support multiple address recognition with four address mask registers I2ADRMn (n=0~3). When the bit in the address mask register is set to one, it means the received corresponding address bit is don't-care. If the bit is set to zero, that means the received corresponding register bit should be exact the same as address register.

#### 5.6.2.2 Data Register (I2C->DATA)

This register contains a byte of serial data to be transmitted or a byte which has just been received. The CPU can read from or write to this 8-bit (I2C->DATA[7:0]) directly addressable SFR while it is not in the process of shifting a byte. This occurs when SIO is in a defined state and the serial interrupt flag (SI) is set. Data in I2C->DATA[7:0] remains stable as long as SI bit is set. While data is being shifted out, data on the bus is simultaneously being shifted in; I2C->DATA[7:0] always contains the last data byte present on the bus. Thus, in the event of arbitration lost, the transition from master transmitter to slave receiver is made with the correct data in I2C->DATA[7:0].

I2C->DATA[7:0] and the acknowledge bit form a 9-bit shift register, the acknowledge bit is controlled by the SIO hardware and cannot be accessed by the CPU. Serial data is shifted through the acknowledge bit into I2C->DATA[7:0] on the rising edges of serial clock pulses on the SCL line. When a byte has been shifted into I2C->DATA[7:0], the serial data is available in I2C->DATA[7:0], and the acknowledge bit (ACK or NACK) is returned by the control logic during the ninth clock pulse. Serial data is shifted out from I2C->DATA[7:0] on the falling edges of SCL clock pulses, and is shifted into I2C->DATA[7:0] on the rising edges of SCL clock pulses.



Figure 5-16 I2C Data Shift Direction

#### 5.6.2.3 Control Register (I2C->CON)

The CPU can read from and write to this 8-bit field of I2C->CON[7:0], directly addressable SFR. Two bits are affected by hardware: the SI bit is set when the I2C hardware requests a serial interrupt, and the STO bit is cleared when a STOP condition is present on the bus. The STO bit is also cleared when ENS1 = "0".

|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EI   | Enable Interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ENSI | Set to enable I2C serial function block. When ENS=1 the I2C serial function enables. The port latches of SDA and SCL must be set to logic high.                                                                                                                                                                                                                                                                                                                                       |
| STA  | I2C START Control Bit. Setting STA to logic 1 to enter master mode, the I2C hardware sends a START or repeat START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                                             |
| STO  | I2C STOP Control Bit. In master mode, setting STO to transmit a STOP condition to bus then I2C hardware will check the bus condition if a STOP condition is detected this flag will be cleared by hardware automatically. In a slave mode, setting STO resets I2C hardware to the defined "not addressed" slave mode. This means it is NO LONGER in the slave receiver mode to receive data from the master transmit device.                                                          |
| SI   | I2C Interrupt Flag. When a new SIO state is present in the I2C->STATUS register, the SI flag is set by hardware, and if bit EI (I2C->CON[7]) is set, the I2C interrupt is requested. SI must be cleared by software. Clear SI is by writing one to this bit.                                                                                                                                                                                                                          |
| AA   | Assert Acknowledge Control Bit. When AA=1 prior to address or data received, an acknowledged (low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when 1.) A slave is acknowledging the address sent from master, 2.) The receiver devices are acknowledging the data sent by transmitter. When AA=0 prior to address or data received, a Not acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on the SCL line. |

#### 5.6.2.4 Status Register (I2C->STATUS)

I2C->STATUS[7:0] is an 8-bit read-only register. The three least significant bits are always 0. The bit field I2C->STATUS[7:3] contains the status code. There are 26 possible status codes. When I2C->STATUS[7:0] contains F8H, no serial interrupt is requested. All other I2C->STATUS[7:3] values correspond to defined SIO states. When each of these states is entered, a status interrupt is requested (SI = 1). A valid status code is present in I2C->STATUS[7:3] one machine cycle after SI is set by hardware and is still present one machine cycle after SI has been reset by software.

In addition, state 00H stands for a Bus Error. A Bus Error occurs when a START or STOP condition is present at an illegal position in the format frame. Examples of illegal positions are during the serial transfer of an address byte, a data byte or an acknowledge bit. To recover I2C from bus error, STO should be set and SI should be clear to enter not addressed slave mode. Then clear STO to release bus and to wait new communication. I2C bus cannot recognize stop condition during this action when bus error occurs.

#### 5.6.2.5 I2C Clock Baud Rate Bits (I2C->CLK)

The data baud rate of I2C is determined by I2C->CLK[7:0] register when SIO is in a master mode. It is

not important when SIO is in a slave mode. In the slave modes, SIO will automatically synchronize with any clock frequency up to 400 kHz from master I2C device.

Data Baud Rate of I2C =  $PCLK / (4 \times (I2C->CLK[7:0] + 1))$ . If  $PCLK=16MHz$ , the  $I2C->CLK[7:0] = 40$  (28H), data baud rate of I2C =  $16MHz / (4 \times (40 + 1)) = 97.5Kbits/sec$ .

#### 5.6.2.6 The I2C Time-out Counter Register (I2C->TOC)

There is a 14-bit time-out counter which can be configured to deal with an I2C bus hang-up. If the time-out counter is enabled, the counter starts up-counting until it overflows (TIF=1) and generates I2C interrupt to CPU or stops counting by clearing ENTI to 0. When time-out counter is enabled, setting flag SI to high will reset counter. Counter will re-start after SI is cleared. If the I2C bus hangs up, counter will overflow and generate a CPU interrupt. Refer to Figure 5-17 for the 14-bit time-out counter. User can clear TIF by writing one to this bit.



Figure 5-17: I2C Time-out Count Block Diagram

### 5.6.3 Register Mapping

R: read only, W: write only, R/W: both read and write

| Register    | Offset      | R/W | Description                   | Reset Value |
|-------------|-------------|-----|-------------------------------|-------------|
| I2C->CON    | I2C_BA+0x00 | R/W | I2C Control Register          | 0x0000_0000 |
| I2C->ADRR0  | I2C_BA+0x04 | R/W | I2C Slave address Register0   | 0x0000_0000 |
| I2C->DATA   | I2C_BA+0x08 | R/W | I2C DATA Register             | 0x0000_0000 |
| I2C->STATUS | I2C_BA+0x0C | R   | I2C Status Register           | 0x0000_00F8 |
| I2C->CLK    | I2C_BA+0x10 | R/W | I2C clock divided Register    | 0x0000_0000 |
| I2C->TOC    | I2C_BA+0x14 | R/W | I2C Time out control Register | 0x0000_0000 |
| I2C->ADDR1  | I2C_BA+0x18 | R/W | Slave address Register1       | 0x0000_0000 |
| I2C->ADDR2  | I2C_BA+0x1C | R/W | Slave address Register2       | 0x0000_0000 |
| I2C->ADDR3  | I2C_BA+0x20 | R/W | Slave address Register3       | 0x0000_0000 |
| I2C->ADM0   | I2C_BA+0x24 | R/W | Slave address Mask Register0  | 0x0000_0000 |
| I2C->ADM1   | I2C_BA+0x28 | R/W | Slave address Mask Register1  | 0x0000_0000 |
| I2C->ADM2   | I2C_BA+0x2C | R/W | Slave address Mask Register2  | 0x0000_0000 |
| I2C->ADM3   | I2C_BA+0x30 | R/W | Slave address Mask Register3  | 0x0000_0000 |

### 5.6.4 Register Description

#### I2C CONTROL REGISTER (I2C->CON)

| Register | Offset       | R/W | Description          |  |  |  | Reset Value |
|----------|--------------|-----|----------------------|--|--|--|-------------|
| I2C->CON | I2C_BA+0x00H | R/W | I2C Control Register |  |  |  | 0x0000_0000 |

|    |      |     |     |    |    |          |          |
|----|------|-----|-----|----|----|----------|----------|
| 7  | 6    | 5   | 4   | 3  | 2  | 1        | 0        |
| EI | ENSI | STA | STO | SI | AA | Reserved | Reserved |

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]  | <b>EI</b>    | <b>Enable Interrupt.</b><br>1 = Enable interrupt CPU.<br>0 = Disable interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [6]  | <b>ENSI</b>  | <b>I2C Controller Enable Bit.</b><br>1 = Enable<br>0 = Disable<br>Set to enable I2C serial function block.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [5]  | <b>STA</b>   | <b>I2C START Control Bit.</b><br>Setting STA to logic 1 will enter master mode, the I2C hardware sends a START or repeat START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                                                                                                                |
| [4]  | <b>STO</b>   | <b>I2C STOP Control Bit.</b><br>In master mode, set STO to transmit a STOP condition to bus. I2C hardware will check the bus condition, when a STOP condition is detected this bit will be cleared by hardware automatically. In slave mode, setting STO resets I2C hardware to the defined "not addressed" slave mode. This means it is NO LONGER in the slave receiver mode able receive data from the master transmit device.                                                                                                                                     |
| [3]  | <b>SI</b>    | <b>I2C Interrupt Flag.</b><br>When a new SIO state is present in the I2C->STATUS register, the SI flag is set by hardware, and if bit EI (I2C->CON[7]) is set, the I2C interrupt is requested. SI must be cleared by software. Clear SI by writing one to this bit.                                                                                                                                                                                                                                                                                                  |
| [2]  | <b>AA</b>    | <b>Assert Acknowledge Control Bit.</b><br>When AA=1 prior to address or data received, an acknowledge (ACK - low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when:<br><ol style="list-style-type: none"> <li>1. A slave is acknowledging the address sent from master,</li> <li>2. The receiver devices are acknowledging the data sent by transmitter.</li> </ol><br>When AA=0 prior to address or data received, a Not acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on the SCL line. |

I2C DATA REGISTER (I2C->DATA)

| Register  | Offset      | R/W | Description       | Reset Value |
|-----------|-------------|-----|-------------------|-------------|
| I2C->DATA | I2C_BA+0x08 | R/W | I2C DATA Register | 0x0000_0000 |

|                |   |   |   |   |   |   |   |
|----------------|---|---|---|---|---|---|---|
| 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| I2C->DATA[7:0] |   |   |   |   |   |   |   |

| Bits  | Descriptions |                                                                                                                                                                                                                         |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | I2C->DATA    | <b>I2C Data Register.</b><br>During master or slave transmit mode, data to be transmitted is written to this register. During master or slave receive mode, data that has been received may be read from this register. |

I2C STATUS REGISTER (I2C->STATUS )

| Register    | Offset      | R/W | Description         | Reset Value |
|-------------|-------------|-----|---------------------|-------------|
| I2C->STATUS | I2C_BA+0x0C | R/W | I2C STATUS Register | 0x0000_0000 |

|                  |   |   |   |   |   |   |   |
|------------------|---|---|---|---|---|---|---|
| 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| I2C->STATUS[7:0] |   |   |   |   |   |   |   |

| Bits  | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | <p><b>I2C Status Register</b></p> <p>The status register of I2C:</p> <p>The three least significant bits are always 0. The five most significant bits contain the status code. There are 26 possible status codes. When I2C-&gt;STATUS contains F8H, no serial interrupt is requested. All other I2C-&gt;STATUS values correspond to defined I2C states. When each of these states is entered, a status interrupt is requested (SI = 1). A valid status code is present in I2C-&gt;STATUS one PCLK cycle after SI is set by hardware and is still present one PCLK cycle after SI has been reset by software. In addition, states 00H stands for a Bus Error. A Bus Error occurs when a START or STOP condition is present at an illegal position in the frame. Example of illegal position are during the serial transfer of an address byte, a data byte or an acknowledge bit.</p> |

I2C BAUD RATE CONTROL REGISTER (I2C->CLK)

| Register | Offset      | R/W | Description                | Reset Value |
|----------|-------------|-----|----------------------------|-------------|
| I2C->CLK | I2C_BA+0x10 | R/W | I2C clock divided Register | 0x0000_0000 |

|               |   |   |   |   |   |   |   |
|---------------|---|---|---|---|---|---|---|
| 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| I2C->CLK[7:0] |   |   |   |   |   |   |   |

| Bits  | Descriptions |                                                                                                               |
|-------|--------------|---------------------------------------------------------------------------------------------------------------|
| [7:0] | I2C->CLK     | <b>I2C clock divided Register</b><br>The I2C clock rate bits: Data Baud Rate of I2C = PCLK /(4x(I2C->CLK+1)). |

I2C TIME-OUT COUNTER REGISTER (I2C->TOC)

| Register | Offset      | R/W | Description                   | Reset Value |
|----------|-------------|-----|-------------------------------|-------------|
| I2C->TOC | I2C_BA+0x14 | R/W | I2C Time-Out Counter Register | 0x0000_0000 |

|          |   |   |   |      |      |     |   |
|----------|---|---|---|------|------|-----|---|
| 7        | 6 | 5 | 4 | 3    | 2    | 1   | 0 |
| Reserved |   |   |   | ENTI | DIV4 | TIF |   |

| Bits | Descriptions                                                                                                                                                                                                                                                       |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]  | <b>ENTI</b><br><b>Time-out counter is enabled/disable</b><br>1 = Enable<br>0 = Disable<br>When enabled, the 14 bit time-out counter will start counting when SI is clear. Setting flag SI to high will reset counter and re-start up counting after SI is cleared. |
| [1]  | <b>DIV4</b><br><b>Time-Out counter input clock divide by 4</b><br>1 = Enable<br>0 = Disable<br>When enabled, the time-out clock is PCLK/4.                                                                                                                         |
| [0]  | <b>TIF</b><br><b>Time-Out Flag</b><br>1 = Time-out flag is set by H/W. It can interrupt CPU. Write 1 to clear..<br>0 = No time-out.                                                                                                                                |

I2C SLAVE ADDRESS REGISTER (I2CADDRx)

| Register   | Offset      | R/W | Description                 | Reset Value |
|------------|-------------|-----|-----------------------------|-------------|
| I2C->ADDR0 | I2C_BA+0x04 | R/W | I2C slave Address Register0 | 0x0000_0000 |
| I2C->ADDR1 | I2C_BA+0x18 | R/W | I2C slave Address Register1 | 0x0000_0000 |
| I2C->ADDR2 | I2C_BA+0x1C | R/W | I2C slave Address Register2 | 0x0000_0000 |
| I2C->ADDR3 | I2C_BA+0x20 | R/W | I2C slave Address Register3 | 0x0000_0000 |

|           |   |   |   |   |   |   |    |
|-----------|---|---|---|---|---|---|----|
| 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
| ADDR[7:1] |   |   |   |   |   |   | GC |

| Bits  | Descriptions |                                                                                                                                                                                                                                                                      |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:1] | <b>ADDR</b>  | <b>I2C Address Register</b><br>The content of this register is irrelevant when I2C is in master mode. In the slave mode, the seven most significant bits must be loaded with the MCU's own address. The I2C hardware will react if any of the addresses are matched. |
| [0]   | <b>GC</b>    | <b>General Call Function</b><br>0 = Disable General Call Function.<br>1 = Enable General Call Function.                                                                                                                                                              |

I2C SLAVE ADDRESS MASK REGISTER (I2CADMx)

| Register  | Offset      | R/W | Description                      | Reset Value |
|-----------|-------------|-----|----------------------------------|-------------|
| I2C->ADM0 | I2C_BA+0x24 | R/W | I2C slave Address Mask Register0 | 0x0000_0000 |
| I2C->ADM1 | I2C_BA+0x28 | R/W | I2C slave Address Mask Register1 | 0x0000_0000 |
| I2C->ADM2 | I2C_BA+0x2C | R/W | I2C slave Address Mask Register2 | 0x0000_0000 |
| I2C->ADM3 | I2C_BA+0x30 | R/W | I2C slave Address Mask Register3 | 0x0000_0000 |

|           |   |   |   |   |   |   |          |
|-----------|---|---|---|---|---|---|----------|
| 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
| ADMx[7:1] |   |   |   |   |   |   | Reserved |

| Bits  | Descriptions |                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:1] | ADMx         | <p><b>I2C Address Mask register</b></p> <p>1 = Mask enable (the received corresponding address bit is don't care.)</p> <p>0 = Mask disable.</p> <p>I2C bus controllers support multiple address recognition with four address mask registers. Bits in this field mask the ADDR<sub>x</sub> registers masking bits from the address comparison.</p> |

### 5.6.5 Modes of Operation

The on-chip I2C ports support five operation modes, Master transmitter, Master receiver, Slave transmitter, Slave receiver, and GC call.

In a given application, I2C port may operate as a master or as a slave. In the slave mode, the I2C port hardware looks for its own slave address and the general call address. If one of these addresses is detected, and if the slave is willing to receive or transmit data from/to master (by setting the AA bit), an acknowledge pulse will be transmitted out on the 9th clock. An interrupt is requested on both master and slave devices if interrupt is enabled. When the microcontroller wishes to become the bus master, the hardware waits until the bus is free before the master mode is entered so that a possible slave action is not interrupted. If bus arbitration is lost in the master mode, I2C port switches to the slave mode immediately and can detect its own slave address in the same serial transfer.

#### 5.6.5.1 Master Transmitter Mode

Serial data output through SDA while SCL outputs the serial clock. The first byte transmitted contains the slave address of the receiving device (7 bits) and the data direction bit. In this case the data direction bit (R/W) will be logic 0, and it is represented by "W" in the flow diagrams. Thus the first byte transmitted is SLA+W. Serial data is transmitted 8 bits at a time. After each byte is transmitted, an acknowledge bit is received. START and STOP conditions are output to indicate the beginning and the end of a serial transfer.

#### 5.6.5.2 Master Receiver Mode

In this case the data direction bit (R/W) will be logic 1, and it is represented by "R" in the flow diagrams. Thus the first byte transmitted is SLA+R. Serial data is received via SDA while SCL outputs the serial clock. Serial data is received 8 bits at a time. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are output to indicate the beginning and end of a serial transfer.

#### 5.6.5.3 Slave Receiver Mode

Serial data and the serial clock are received through SDA and SCL. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are recognized as the beginning and end of a serial transfer. Address recognition is performed by hardware after reception of the slave address and direction bit.

#### 5.6.5.4 Slave Transmitter Mode

The first byte is received and handled as in the slave receiver mode. However, in this mode, the direction bit will indicate that the transfer direction is reversed. Serial data is transmitted via SDA while the serial clock is input through SCL. START and STOP conditions are recognized as the beginning and end of a serial transfer.

### 5.6.6 Data Transfer Flow in Five Operating Modes

The five operating modes are: Master/Transmitter, Master/Receiver, Slave/Transmitter, Slave/Receiver and GC Call. Bits STA, STO and AA in I2C->CON register will determine the next state of the SIO hardware after SI flag is cleared. Upon completion of the new action, a new status code will be updated and the SI flag will be set. If the I2C interrupt control bit EI (I2C->CON[7]) is set, appropriate action or software branch of the new status code can be performed in the Interrupt service routine.

Data transfers in each mode are shown in the following figures.

\*\*\* Legend for the following five figures:



Figure 5-18 Legend for the following four figures



Figure 5-19 Master Transmitter Mode



Figure 5-20 Master Receiver Mode



Figure 5-21 Slave Transmitter Mode



Figure 5-22 Slave Receiver Mode



Figure 5-23 GC Mode

## 5.7 PWM Generator and Capture Timer

### 5.7.1 Introduction

The ISD9160 has a PWM Generator which can be configured as 2 independent PWM outputs, PWM0~PWM1, or as a complementary PWM pair, (PWM0, PWM1) with a programmable dead-zone generator. The PWM Generator has an 8-bit prescaler, a clock divider providing 5 divided frequencies (1, 1/2, 1/4, 1/8, 1/16), two PWM Timers including two clock selectors, two 16-bit PWM down-counters for PWM period control, two 16-bit comparators for PWM duty control and one dead-zone generator. The PWM Generator provides PWM interrupt flags which are set by hardware when the corresponding PWM period down counter reaches zero. Each PWM interrupt source, with its corresponding enable bit, can generate a PWM interrupt request to the CPU. The PWM generator can be configured in one-shot mode to produce only one PWM cycle signal or continuous mode to output a periodic PWM waveform.

When PCR.DZEN01 is set, PWM0 and PWM1 perform complementary paired PWM function; the paired PWM timing, period, duty and dead-time are determined by PWM0 timer and Dead-zone generator 0. Refer to Figure 5-25 for the architecture of PWM Timers.

To prevent PWM driving glitches to an output pin, the 16-bit period down-counter and 16-bit comparator are implemented with a double buffer. When user writes data to the counter/comparator registers, the updated value will not be load into the 16-bit down-counter/comparator until the down-counter reaches zero.

When the 16-bit period down-counter reaches zero, the interrupt request is generated. If PWM timer is configured in continuous mode, when the down counter reaches zero, it is reloaded with PWM Counter Register (CNRx) automatically and begins decrementing again. If the PWM timer is configured in one-shot mode, the down counter will stop and generate a single interrupt request when it reaches zero.

The value of PWM counter comparator is used for pulse width modulation. The counter control logic inverts the output level when down-counter value matches the value of compare register.

The alternate function of the PWM-timer is as a digital input capture timer. If Capture function is enabled the PWM output pin is switched as a capture input pin. The Capture0 and PWM0 share one timer which is included in PWM0; and the Capture1 and PWM1 share PWM1 timer. User must setup the PWM-timer before enabling the Capture feature. After the capture feature is enabled, the count is latched to the Capture Rising Latch Register (CRLR) when input channel has a rising transition and latched to Capture Falling Latch Register (CFLR) when input channel has a falling transition. Capture channel 0 interrupt is programmable by setting CCR0.CRL\_IE0[1] (Rising latch Interrupt enable) and CCR0.CFL\_IE0[2]] (Falling latch Interrupt enable) to determine the condition of interrupt occurrence. Capture channel 1 has the same feature by setting CCR0.CRL\_IE1[17] and CCR0.CFL\_IE1[18]. Whenever Capture issues interrupt, the PWM counter will also be reloaded.

### 5.7.2 Features

#### 5.7.2.1 PWM function features:

- PWM Generator, incorporating an 8-bit pre-scaler, clock divider, two PWM-timers (down counters), a dead-zone generator and two PWM outputs.
- Up to 2 PWM channels or a paired PWM channel.
- 16 bits resolution.
- PWM Interrupt request synchronous with PWM period.
- Single-shot or Continuous mode PWM.
- Dead-Zone generator.

#### 5.7.2.2 Capture Function Features:

- Timing control logic shared with PWM Generators.
- 2 Capture input channels shared with 2 PWM output channels.
- Each channel supports a rising latch register (CRLR), a falling latch register (CFLR) and Capture interrupt flag (CAPIFx)

### 5.7.3 PWM Generator Architecture

The following figures illustrate the architecture of the PWM.



Figure 5-24 PWM Generator Clock Source Control



Figure 5-25 PWM Generator Architecture Diagram

### 5.7.4 PWM-Timer Operation

The PWM period and duty control are configured by the PWM down-counter register (CNR) and PWM comparator register (CMR). Formulas for calculating the pulse width modulation are shown below and demonstrated in Figure 5-26. Note that the corresponding GPIO pins must be configured as the alternate function before PWM function is enabled.

- PWM frequency =  $\text{PWM01\_CLK}/(\text{prescale}+1)*(\text{clock divider})/(\text{CNR}+1)$ ;
- Duty cycle =  $(\text{CMR}+1)/(\text{CNR}+1)$ .
- $\text{CMR} \geq \text{CNR}$ : PWM output is always high.
- $\text{CMR} < \text{CNR}$ : PWM low width=  $(\text{CNR}-\text{CMR})$  unit<sup>1</sup>; PWM high width =  $(\text{CMR}+1)$  unit.

- CMR = 0: PWM low width = (CNR) unit; PWM high width = 1 unit

Note: 1. Unit = one PWM clock cycle.



Figure 5-26 PWM Generation Timing

The procedure to operate the PWM generator is shown in Figure 5-27. First initialize the PWM settings. At the same time ensure that GPIO are configured to PWM function. Next step is to enable PWM channel. After this, if CNR or CMR register is written by software, it is double buffered until the next counter reload, at which time the registers are updated to new values.



Figure 5-27 PWM-Timer Operation Timing

### 5.7.5 PWM Double Buffering, Auto-reload and One-shot Operation

The ISD9160 PWM Timers are double buffered, the reload value is updated at the start of next period without affecting current timer operation. The PWM counter reset value can be written into CNR0~1 and current PWM counter value can be read from PDR0~1.

The bit CHxMOD in PWM Control Register (PCR) determines whether PWMx operates in auto-reload or one-shot mode. If CHxMOD is set to one, the auto-reload operation loads CNRx to PWM counter when PWM counter reaches zero. If CNRx is set to zero, PWM counter will halt when PWM counter counts to zero. If CHxMOD is set as zero, counter will stop immediately.



Figure 5-28 PWM Double Buffering.

### 5.7.6 Modulate Duty Cycle

The double buffering allows CMR to be written at any point in current cycle. The loaded value will take effect from next cycle. This is demonstrated in Figure 5-29.



Figure 5-29 PWM Controller Duty Cycle Modulation (CNR = 150).

### 5.7.7 Dead-Zone Generator

The ISD9160 PWM generator includes a Dead Zone generator. This is used to ensure neither PWM output is active simultaneously for power device protection. The function generates a programmable time gap between rising PWM outputs. The user can program PPRx.DZI to determine the Dead Zone interval. The Dead Zone generator behavior is demonstrated in Figure 5-30.



Figure 5-30 Paired-PWM Output with Dead Zone Generation Operation

### 5.7.8 Capture Timer Operation

Instead of using the PWM generator to output a modulated signal, it can be configured as a capture timer to measure a modulated input. Capture channel 0 and PWM0 share one timer and Capture channel 1 and PWM1 share another timer. The capture timer latches PWM-counter to CRLR when input channel has a rising transition and latches PWM-counter to CFLR when input channel has a falling transition. Capture channel 0 interrupt is programmable by setting CCR0[1] (Rising latch Interrupt enable) and CCR0[2] (Falling latch Interrupt enable) to decide the condition of interrupt occurrence. Capture channel 1 has the same feature by setting CCR0[17] and CCR0[18]. Whenever the Capture module issues a capture interrupt, the corresponding PWM counter will be reloaded with CNRx at this moment. Note that the corresponding GPIO pins must be configured as their alternate function before Capture function is enabled.



Figure 5-31 Capture Operation Timing

Figure 5-31 demonstrates the case where CNR = 8:

1. The PWM counter will be reloaded with CNRx=8 when a capture interrupt flag (CAPIFx) is set by a transition on the capture input.
2. The channel low pulse width is given by (CNR - CRLR).
3. The channel high pulse width is given by (CNR - CFLR).

### 5.7.9 PWM-Timer Interrupt Architecture

There are two PWM interrupts, PWM0\_INT, PWM1\_INT, which are multiplexed into PWMA\_IRQ. PWM 0 and Capture 0 share one interrupt, PWM1 and Capture 1 share the same interrupt. Figure 5-32 demonstrates the architecture of PWM-Timer interrupts.



Figure 5-32 PWM-Timer Interrupt Architecture Diagram

### 5.7.10 PWM-Timer Initialization Procedure

The following procedure is recommended for starting a PWM generator.

1. Setup clock selector (CSR)
2. Setup prescaler (PPR)
3. Setup inverter on/off, dead zone generator on/off, auto-reload/one-shot mode and Stop PWM-timer (PCR)
4. Setup comparator register (CMR) to set PWM duty cycle.
5. Setup PWM down-counter register (CNR) to set PWM period.
6. Setup interrupt enable register (PIER)
7. Setup PWM output enable (POE)
8. Setup the corresponding GPIO pins to PWM function (GPA\_ALT)
9. Enable PWM timer start (Set CHxEN = 1 in PCR)

### 5.7.11 PWM-Timer Stop Procedure

#### Method 1:

Set 16-bit down counter (CNR) as 0, and monitor PDR (current value of 16-bit down-counter). When PDR reaches to 0, disable PWM-Timer (CHxEN in PCR). (**Recommended**)

#### Method 2:

Set 16-bit down counter (CNR) as 0. When interrupt request occurs, disable PWM-Timer (CHxEN in PCR). (**Recommended**)

#### Method 3:

Disable PWM-Timer directly (CHxEN in PCR). (**Not recommended**)

### 5.7.12 Capture Start Procedure

1. Setup clock selector (CSR)
2. Setup prescaler (PPR)
3. Setup channel enable, rising/falling interrupt enable and input signal inverter on/off (CCR0, CCR1)
4. Setup PWM down-counter (CNR)
5. Set Capture Input Enable Register (CAPENR)
6. Setup the corresponding GPIO pins to PWM function (GPA\_ALT)
7. Enable PWM timer start running (Set CHxEN = 1 in PCR)

### 5.7.13 Register Map

R: read only, W: write only, R/W: both read and write, C: Only value 0 can be written

| Register                     | Offset        | R/W | Description                                | Reset Value | Reference                  |
|------------------------------|---------------|-----|--------------------------------------------|-------------|----------------------------|
| <b>PWMA_BA = 0x4004_0000</b> |               |     |                                            |             |                            |
| PPR                          | PWMA_BA+0x000 | R/W | PWM Prescaler Register                     | 0x0000_0000 | <a href="#">Table 5-57</a> |
| CSR                          | PWMA_BA+0x004 | R/W | PWM Clock Select Register                  | 0x0000_0000 | <a href="#">Table 5-58</a> |
| PCR                          | PWMA_BA+0x008 | R/W | PWM Control Register                       | 0x0000_0000 | <a href="#">Table 5-59</a> |
| CNR0                         | PWMA_BA+0x00C | R/W | PWM Counter Register 0                     | 0x0000_0000 | <a href="#">Table 5-60</a> |
| CMR0                         | PWMA_BA+0x010 | R/W | PWM Comparator Register 0                  | 0x0000_0000 | <a href="#">Table 5-61</a> |
| PDR0                         | PWMA_BA+0x014 | R   | PWM Data Register 0                        | 0x0000_0000 | <a href="#">Table 5-62</a> |
| CNR1                         | PWMA_BA+0x018 | R/W | PWM Counter Register 1                     | 0x0000_0000 | <a href="#">Table 5-60</a> |
| CMR1                         | PWMA_BA+0x01C | R/W | PWM Comparator Register 1                  | 0x0000_0000 | <a href="#">Table 5-61</a> |
| PDR1                         | PWMA_BA+0x020 | R   | PWM Data Register 1                        | 0x0000_0000 | <a href="#">Table 5-62</a> |
| PIER                         | PWMA_BA+0x040 | R/W | PWM Interrupt Enable Register              | 0x0000_0000 | <a href="#">Table 5-63</a> |
| PIFR                         | PWMA_BA+0x044 | R/C | PWM Interrupt Flag Register                | 0x0000_0000 | <a href="#">Table 5-64</a> |
| CCR0                         | PWMA_BA+0x050 | R/W | Capture Control Register 0                 | 0x0000_0000 | <a href="#">Table 5-65</a> |
| CRLR0                        | PWMA_BA+0x058 | R/W | Capture Rising Latch Register (Channel 0)  | 0x0000_0000 | <a href="#">Table 5-66</a> |
| CFLR0                        | PWMA_BA+0x05C | R/W | Capture Falling Latch Register (Channel 0) | 0x0000_0000 | <a href="#">Table 5-67</a> |
| CRLR1                        | PWMA_BA+0x060 | R/W | Capture Rising Latch Register (Channel 1)  | 0x0000_0000 | <a href="#">Table 5-66</a> |
| CFLR1                        | PWMA_BA+0x064 | R/W | Capture Falling Latch Register (Channel 1) | 0x0000_0000 | <a href="#">Table 5-67</a> |
| CAPENR                       | PWMA_BA+0x078 | R/W | Capture Input 0~1 Enable Register          | 0x0000_0000 | <a href="#">Table 5-68</a> |
| POE                          | PWMA_BA+0x07C | R/W | PWM Output Enable for PWM0~PWM3            | 0x0000_0000 | <a href="#">Table 5-69</a> |

### 5.7.14 Register Description

#### PWM Pre-Scale Register (PPR)

| Register | Offset        | R/W | Description            |  |  |  | Reset Value |
|----------|---------------|-----|------------------------|--|--|--|-------------|
| PPR      | PWMA_BA+0x000 | R/W | PWM Pre-scale Register |  |  |  | 0x0000_0000 |

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

Table 5-57 PWM Pre-Scaler Register (PPR, address 0x4004\_0000).

| Bits    | Descriptions                                                                                                                                                                                             |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:16] | <b>DZI01</b><br>Dead zone interval register for pair of PWM0 and PWM1<br>These 8 bits determine dead zone length.<br>The unit time of dead zone length is that from clock selector 0.                    |
| [7:0]   | <b>CP01</b><br>Clock pre-scaler<br>Clock input is divided by (CP01 + 1)<br><b>If CP01=0, then the pre-scaler output clock will be stopped.</b><br>This implies PWM counter 0 and 1 will also be stopped. |

PWM Clock Select Register (CSR)

| Register | Offset        | R/W | Description               |  |  |  | Reset Value |
|----------|---------------|-----|---------------------------|--|--|--|-------------|
| CSR      | PWMA_BA+0x004 | R/W | PWM Clock Select Register |  |  |  | 0x0000_0000 |

|          |      |   |   |          |      |   |   |
|----------|------|---|---|----------|------|---|---|
| 7        | 6    | 5 | 4 | 3        | 2    | 1 | 0 |
| Reserved | CSR1 |   |   | Reserved | CSR0 |   |   |

Table 5-58 PWM Clock Select Register (CSR, address 0x4004\_0004).

| Bits   | Descriptions           |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
|--------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------|-----|---|-----|----|-----|---|-----|---|-----|---|
| [31:7] | -                      | Reserved                                                                                                                                                                                                                                                                                                          |      |                        |     |   |     |    |     |   |     |   |     |   |
| [6:4]  | CSR1                   | <p><b>Timer 1 Clock Source Selection</b></p> <table border="1"> <tr> <th>CSR1</th> <th>Input clock divided by</th> </tr> <tr> <td>100</td> <td>1</td> </tr> <tr> <td>011</td> <td>16</td> </tr> <tr> <td>010</td> <td>8</td> </tr> <tr> <td>001</td> <td>4</td> </tr> <tr> <td>000</td> <td>2</td> </tr> </table> | CSR1 | Input clock divided by | 100 | 1 | 011 | 16 | 010 | 8 | 001 | 4 | 000 | 2 |
| CSR1   | Input clock divided by |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
| 100    | 1                      |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
| 011    | 16                     |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
| 010    | 8                      |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
| 001    | 4                      |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
| 000    | 2                      |                                                                                                                                                                                                                                                                                                                   |      |                        |     |   |     |    |     |   |     |   |     |   |
| [2:0]  | CSR0                   | <p><b>Timer 0 Clock Source Selection</b></p> <p>(Table is as CSR1)</p>                                                                                                                                                                                                                                            |      |                        |     |   |     |    |     |   |     |   |     |   |

PWM Control Register (PCR)

| Register | Offset        | R/W | Description                |  |  |  | Reset Value |
|----------|---------------|-----|----------------------------|--|--|--|-------------|
| PCR      | PWMA_BA+0x008 | R/W | PWM Control Register (PCR) |  |  |  | 0x0000_0000 |

|          |    |    |        |        |        |          |       |
|----------|----|----|--------|--------|--------|----------|-------|
| 15       | 14 | 13 | 12     | 11     | 10     | 9        | 8     |
| Reserved |    |    |        | CH1MOD | CH1INV | Reserved | CH1EN |
| 7        | 6  | 5  | 4      | 3      | 2      | 1        | 0     |
| Reserved |    |    | DZEN01 | CH0MOD | CH0INV | Reserved | CH0EN |

Table 5-59 PWM Control Register (PCR, address 0x4004\_008).

| Bits | Descriptions                                                                                                                                                                                        |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11] | <b>CH1MOD</b><br><b>PWM-Timer 1 Auto-reload/One-Shot Mode</b><br>1 = Auto-load Mode<br>0 = One-Shot Mode<br><b>Note:</b> A rising transition of this bit will cause CNR1 and CMR1 to be cleared.    |
| [10] | <b>CH1INV</b><br><b>PWM-Timer 1 Output Inverter ON/OFF</b><br>1 = Inverter ON, 0 = Inverter OFF                                                                                                     |
| [8]  | <b>CH1EN</b><br><b>PWM-Timer 1 Enable/Disable Start Run</b><br>1 = Enable PWM-Timer 1 Start/Run, 0 = Stop PWM-Timer 1                                                                               |
| [4]  | <b>DZEN01</b><br><b>Dead-Zone 0 Generator Enable/Disable</b><br>1 = Enable, 0 = Disable<br><b>Note:</b> When Dead-Zone Generator is enabled, the pair of PWM0 and PWM1 become a complementary pair. |
| [3]  | <b>CH0MOD</b><br><b>PWM-Timer 0 Auto-reload/One-Shot Mode</b><br>1 = Auto-reload Mode<br>0 = One-Shot Mode<br><b>Note:</b> A rising transition of this bit will cause CNR0 and CMR0 to be cleared.  |
| [2]  | <b>CH0INV</b><br><b>PWM-Timer 0 Output Inverter ON/OFF</b><br>1 = Inverter ON<br>0 = Inverter OFF                                                                                                   |
| [0]  | <b>CH0EN</b><br><b>PWM-Timer 0 Enable/Disable Start Run</b><br>1 = Enable PWM-Timer 0 Start/Run, 0 = Stop PWM-Timer 0 Running                                                                       |

PWM Counter Register 1-0 (CNR1-0)

| Register | Offset        | R/W | Description            |  |  |  | Reset Value |
|----------|---------------|-----|------------------------|--|--|--|-------------|
| CNR0     | PWMA_BA+0x00C | R/W | PWM Counter Register 0 |  |  |  | 0x0000_0000 |
| CNR1     | PWMA_BA+0x018 | R/W | PWM Counter Register 1 |  |  |  | 0x0000_0000 |

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

Table 5-60 PWM Counter Register (CNRx, address 0x4004\_00C+C\*x).

| Bits   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | <p><b>CNR</b></p> <p><b>PWM Counter/Timer Reload Value</b></p> <p>CNR determines the PWM period.</p> <ul style="list-style-type: none"> <li>• PWM frequency = PWM01_CLK/(prescale+1)*(clock divider)/(CNR+1);</li> <li>• Duty ratio = (CMR+1)/(CNR+1).</li> <li>• CMR &gt;= CNR: PWM output is always high.</li> <li>• CMR &lt; CNR: PWM low width = (CNR-CMR) unit; PWM high width = (CMR+1) unit.</li> <li>• CMR = 0: PWM low width = (CNR) unit; PWM high width = 1 unit<br/>(Unit = one PWM clock cycle)</li> </ul> <p><b>Note:</b></p> <p>Any write to CNR will take effect in next PWM cycle.</p> |

PWM Comparator Register 7-0 (CMR7-0)

| Register | Offset        | R/W | Description               |  |  |  | Reset Value |
|----------|---------------|-----|---------------------------|--|--|--|-------------|
| CMR0     | PWMA_BA+0x010 | R/W | PWM Comparator Register 0 |  |  |  | 0x0000_0000 |
| CMR1     | PWMA_BA+0x01C | R/W | PWM Comparator Register 1 |  |  |  | 0x0000_0000 |

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

Table 5-61 PWM Comparator Register (CMRx, address 0x4004\_0010 + C\*x).

| Bits   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | <b>CMR</b><br><b>PWM Comparator Register</b><br>CMR determines the PWM duty cycle. <ul style="list-style-type: none"> <li>• PWM frequency = PWM01_CLK/(prescale+1)*(clock divider)/(CNR+1);</li> <li>• Duty Cycle = (CMR+1)/(CNR+1).</li> <li>• CMR &gt;= CNR: PWM output is always high.</li> <li>• CMR &lt; CNR: PWM low width = (CNR-CMR) unit; PWM high width = (CMR+1) unit.</li> <li>• CMR = 0: PWM low width = (CNR) unit; PWM high width = 1 unit<br/>(Unit = one PWM clock cycle)</li> </ul> <b>Note:</b> Any write to CMR will take effect in next PWM cycle. |

PWM Data Register 1-0 (PDR1/PDR0)

| Register | Offset        | R/W | Description         | Reset Value |
|----------|---------------|-----|---------------------|-------------|
| PDR0     | PWMA_BA+0x014 | R   | PWM Data Register 0 | 0x0000_0000 |
| PDR1     | PWMA_BA+0x020 | R   | PWM Data Register 1 | 0x0000_0000 |



Table 5-62 PWM Data Register (PDRx, address 0x4004\_0014 + C\*x).

| Bits   | Descriptions |                                                                                   |
|--------|--------------|-----------------------------------------------------------------------------------|
| [15:0] | PDR          | <b>PWM Data Register</b><br>Reports the current value of the 16-bit down counter. |

PWM Interrupt Enable Register (PIER)

| Register | Offset        | R/W | Description                   | Reset Value |
|----------|---------------|-----|-------------------------------|-------------|
| PIER     | PWMA_BA+0x040 | R/W | PWM Interrupt Enable Register | 0x0000_0000 |

|          |   |   |   |   |   |        |        |
|----------|---|---|---|---|---|--------|--------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
| Reserved |   |   |   |   |   | PWMIE1 | PWMIE0 |

Table 5-63 PWM Interrupt Enable Register (PIER, address 0x4004\_0040).

| Bits | Descriptions  |  |                                                                |
|------|---------------|--|----------------------------------------------------------------|
| [1]  | <b>PWMIE1</b> |  | <b>PWM Timer 1 Interrupt Enable</b><br>1 = Enable, 0 = Disable |
| [0]  | <b>PWMIE0</b> |  | <b>PWM Timer 0 Interrupt Enable</b><br>1 = Enable, 0 = Disable |

PWM Interrupt Flag Register (PIFR)

| Register | Offset        | R/W | Description                 | Reset Value |
|----------|---------------|-----|-----------------------------|-------------|
| PIFR     | PWMA_BA+0x044 | R/W | PWM Interrupt Flag Register | 0x0000_0000 |

|          |   |   |   |   |   |        |        |
|----------|---|---|---|---|---|--------|--------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
| Reserved |   |   |   |   |   | PWMIF1 | PWMIF0 |

Table 5-64 PWM Interrupt Flag Register (PIFR, address 0x4004\_0044).

| Bits | Descriptions  |  |                                                                                                                                                     |
|------|---------------|--|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]  | <b>PWMIF1</b> |  | <b>PWM Timer 1 Interrupt Flag</b><br>Flag is set by hardware when PWM1 down counter reaches zero, software can clear this bit by writing '1' to it. |
| [0]  | <b>PWMIF0</b> |  | <b>PWM Timer 0 Interrupt Flag</b><br>Flag is set by hardware when PWM0 down counter reaches zero, software can clear this bit by writing '1' to it. |

Note: User can clear each interrupt flag by writing a one to corresponding bit in PIFR.

Capture Control Register (CCR0)

| Register | Offset        | R/W | Description              |  |  |  | Reset Value |
|----------|---------------|-----|--------------------------|--|--|--|-------------|
| CCR0     | PWMA_BA+0x050 | R/W | Capture Control Register |  |  |  | 0x0000_0000 |

|          |        |          |        |          |         |         |      |
|----------|--------|----------|--------|----------|---------|---------|------|
| 31       | 30     | 29       | 28     | 27       | 26      | 25      | 24   |
| Reserved |        |          |        |          |         |         |      |
| 23       | 22     | 21       | 20     | 19       | 18      | 17      | 16   |
| CFLRI1   | CRLRI1 | Reserved | CAPIF1 | CAPCH1EN | CFL_IE1 | CRL_IE1 | INV1 |
| 15       | 14     | 13       | 12     | 11       | 10      | 9       | 8    |
| Reserved |        |          |        |          |         |         |      |
| 7        | 6      | 5        | 4      | 3        | 2       | 1       | 0    |
| CFLRI0   | CRLRI0 | Reserved | CAPIF0 | CAPCH0EN | CFL_IE0 | CRL_IE0 | INV0 |

Table 5-65 Capture Control Register (CCR0, address 0x4004\_0050).

| Bits | Descriptions    |                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23] | <b>CFLRI1</b>   | <b>CFLR1 Latched Indicator Bit</b><br>When input channel 1 has a <b>falling</b> transition, CFLR1 was latched with the value of PWM down-counter and this bit is set by hardware, software can clear this bit by writing a <b>zero</b> to it.                                                                                                                      |
| [22] | <b>CRLRI1</b>   | <b>CRLR1 Latched Indicator Bit</b><br>When input channel 1 has a <b>rising</b> transition, CRLR1 was latched with the value of PWM down-counter and this bit is set by hardware, software can clear this bit by writing a <b>zero</b> to it.                                                                                                                       |
| [20] | <b>CAPIF1</b>   | <b>Capture1 Interrupt Indication Flag</b><br>If channel 1 rising latch interrupt is enabled (CRL_IE1=1), a rising transition at input channel 1 will result in CAPIF1 to high; Similarly, a falling transition will cause CAPIF1 to be set high if channel 1 falling latch interrupt is enabled (CFL_IE1=1). This flag is cleared by software writing a '1' to it. |
| [19] | <b>CAPCH1EN</b> | <b>Capture Channel 1 transition Enable/Disable</b><br>1 = Enable capture function on channel 1. 0 = Disable capture function on channel 1<br>When enabled, Capture function latches the PMW-counter to CRLR (Rising latch) and CFLR (Falling latch) registers on input edge transition.<br>When disabled, Capture function is inactive as is interrupt.            |
| [18] | <b>CFL_IE1</b>  | <b>Channel 1 Falling Latch Interrupt Enable</b><br>1 = Enable falling edge latch interrupt. 0 = Disable falling edge latch interrupt<br>When enabled, capture block generates an interrupt on falling edge of input.                                                                                                                                               |

|      |                 |                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17] | <b>CRL_IE1</b>  | <b>Channel 1 Rising Latch Interrupt Enable</b><br>1 = Enable rising edge latch interrupt. 0 = Disable rising edge latch interrupt<br>When enabled, capture block generates an interrupt on rising edge of input.                                                                                                                                                   |
| [16] | <b>INV1</b>     | <b>Channel 1 Inverter ON/OFF</b><br>1 = Inverter ON. Reverse the input signal from GPIO before Capture timer<br>0 = Inverter OFF                                                                                                                                                                                                                                   |
| [7]  | <b>CFLRIO</b>   | <b>CFLR0 Latched Indicator Bit</b><br>When input channel 0 has a <b>falling</b> transition, CFLR0 was latched with the value of PWM down-counter and this bit is set by hardware, software can clear this bit by writing a <b>zero</b> to it.                                                                                                                      |
| [6]  | <b>CRLRIO</b>   | <b>CRLR0 Latched Indicator Bit</b><br>When input channel 0 has a <b>rising</b> transition, CRLR0 was latched with the value of PWM down-counter and this bit is set by hardware, software can clear this bit by writing a <b>zero</b> to it.                                                                                                                       |
| [4]  | <b>CAPIF0</b>   | <b>Capture0 Interrupt Indication Flag</b><br>If channel 0 rising latch interrupt is enabled (CRL_IE0=1), a rising transition at input channel 0 will result in CAPIF0 to high; Similarly, a falling transition will cause CAPIF0 to be set high if channel 0 falling latch interrupt is enabled (CFL_IE0=1). This flag is cleared by software writing a '1' to it. |
| [3]  | <b>CAPCH0EN</b> | <b>Capture Channel 0 transition Enable/Disable</b><br>1 = Enable capture function on channel 0. 0 = Disable capture function on channel 0<br>When enabled, Capture function latches the PMW-counter to CRLR (Rising latch) and CFLR (Falling latch) registers on input edge transition.<br>When disabled, Capture function is inactive as is interrupt.            |
| [2]  | <b>CFL_IE0</b>  | <b>Channel 0 Falling Latch Interrupt Enable ON/OFF</b><br>1 = Enable falling latch interrupt. 0 = Disable falling latch interrupt<br>When enabled, capture block generates an interrupt on falling edge of input.                                                                                                                                                  |
| [1]  | <b>CRL_IE0</b>  | <b>Channel 0 Rising Latch Interrupt Enable ON/OFF</b><br>1 = Enable rising latch interrupt. 0 = Disable rising latch interrupt<br>When enabled, capture block generates an interrupt on rising edge of input.                                                                                                                                                      |
| [0]  | <b>INV0</b>     | <b>Channel 0 Inverter ON/OFF</b><br>1 = Inverter ON. Reverse the input signal from GPIO before Capture timer<br>0 = Inverter OFF                                                                                                                                                                                                                                   |

**Capture Rising Latch Register1-0 (CRLR0 CRLR1)**

| Register     | Offset        | R/W | Description                               | Reset Value |
|--------------|---------------|-----|-------------------------------------------|-------------|
| <b>CRLR0</b> | PWMA_BA+0x058 | R   | Capture Rising Latch Register (channel 0) | 0x0000_0000 |
| <b>CRLR1</b> | PWMA_BA+0x060 | R   | Capture Rising Latch Register (channel 1) | 0x0000_0000 |

|            |    |    |    |    |    |   |   |
|------------|----|----|----|----|----|---|---|
| 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| CRLR[15:8] |    |    |    |    |    |   |   |
| 7          | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| CRLR[7:0]  |    |    |    |    |    |   |   |

Table 5-66 Capture Rising Latch Register (CRLRx, address 0x4004\_0058 + C\*x).

| Bits   | Descriptions |                                                                                                                   |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------|
| [15:0] | CRLR         | In Capture mode, this register is latched with the value of the PWM counter on a rising edge of the input signal. |

**Capture Falling Latch Register1-0 (CFLR1 CFLR0)**

| Register | Offset        | R/W | Description                                | Reset Value |
|----------|---------------|-----|--------------------------------------------|-------------|
| CFLR0    | PWMA_BA+0x05C | R   | Capture Falling Latch Register (channel 0) | 0x0000_0000 |
| CFLR1    | PWMA_BA+0x064 | R   | Capture Falling Latch Register (channel 1) | 0x0000_0000 |

|            |    |    |    |    |    |   |   |
|------------|----|----|----|----|----|---|---|
| 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| CFLR[15:8] |    |    |    |    |    |   |   |
| 7          | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| CFLR[7:0]  |    |    |    |    |    |   |   |

Table 5-67 Capture Falling Latch Register (CFLRx, address 0x4004\_005C + C\*x).

| Bits   | Descriptions |                                                                                                                    |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------|
| [15:0] | CFLR         | In Capture mode, this register is latched with the value of the PWM counter on a falling edge of the input signal. |

Capture Input Enable Register (CAPENR)

| Register | Offset        | R/W | Description                   |  |  |  | Reset Value |
|----------|---------------|-----|-------------------------------|--|--|--|-------------|
| CAPENR   | PWMA_BA+0x078 | R/W | Capture Input Enable Register |  |  |  | 0x0000_0000 |

|          |   |   |   |   |   |             |   |
|----------|---|---|---|---|---|-------------|---|
| 7        | 6 | 5 | 4 | 3 | 2 | 1           | 0 |
| Reserved |   |   |   |   |   | CAPENR[1:0] |   |

Table 5-68 Capture Input Enable Register (CAPENR, address 0x4004\_0078).

| Bits  | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0] | CAPENR       | <p>Capture Input Enable Register<br/>           0 = OFF (GPA[13:12] pin input disconnected from Capture block)<br/>           1 = ON (GPA[13:12] pin, if in PWM alternative function, will be configured as an input and fed to capture function)</p> <p>CAPENR[1:0]</p> <p><u>Bit 10</u></p> <p>Bit x1 → Capture channel 0 is from GPA [12]<br/>           Bit 1x → Capture channel 1 is from GPA [13]</p> |

PWM Output Enable Register (POE) for PWM0~PWM1

| Register | Offset        | R/W | Description                              | Reset Value |
|----------|---------------|-----|------------------------------------------|-------------|
| POE      | PWMA_BA+0x07C | R/W | PWM Output Enable Register for PWM0~PWM1 | 0x0000_0000 |

|          |   |   |   |   |   |      |      |
|----------|---|---|---|---|---|------|------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
| Reserved |   |   |   |   |   | PWM1 | PWM0 |

Table 5-69 PWM Output Enable (POE, address 0x4004\_007C).

| Bits | Descriptions |                                                                                                                                                                                                                                     |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]  | PWM1         | <b>PWM1 Output Enable Register</b><br>1 = Enable PWM1 output to pin. 0 = Disable PWM1 output to pin.<br><b>Note:</b> The corresponding GPIO pin also must be switched to PWM function (refer to GPA_ALT <a href="#">Table 5-7</a> ) |
| [0]  | PWM0         | <b>PWM0 Output Enable Register</b><br>1 = Enable PWM0 output to pin. 0 = Disable PWM0 output to pin.<br><b>Note:</b> The corresponding GPIO pin also must be switched to PWM function (refer to GPA_ALT <a href="#">Table 5-7</a> ) |

## 5.8 Real Time Clock (RTC)

### 5.8.1 Overview

Real Time Clock (RTC) unit provides real time clock, calendar and alarm functions. The clock source of the RTC is an external 32.768 kHz crystal connected at pins XI32K and XO32K or from an external 32.768 kHz oscillator output fed to pin XI32K. The RTC unit provides the time (second, minute, hour) in Time Load Register (TLR) as well as calendar (day, month, year) in Calendar Load Register (CLR). The data is expressed in BCD (Binary Coded Decimal) format. The unit offers an alarm function whereby the user can preset the alarm time in the Time Alarm Register (TAR) and alarm calendar in Calendar Alarm Register (CAR).

The RTC unit supports periodic Time-Tick and Alarm-Match interrupts. The periodic interrupt has 8 period options 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second which are selected by TTR (TTR[2:0]). When RTC counter in TLR and CLR is equal to alarm setting registers TAR and CAR, the alarm interrupt flag (RIIR.AIF) is set and the alarm interrupt is requested if the alarm interrupt is enabled (RIER.AIER=1). The RTC Time Tick and Alarm Match can wake the CPU from sleep mode or Standby Power-Down (SPD) mode if the Wakeup CPU function is enabled (TWKE (TTR[3])=1).

### 5.8.2 RTC Features

- Consists of a time counter (second, minute, hour) and calendar counter (day, month, year).
- Alarm register (second, minute, hour, day, month, year).
- 12-hour or 24-hour mode is selectable.
- Automatic leap year compensation.
- Day of week counter.
- Frequency compensate register (FCR).
- All time and calendar registers are expressed in BCD code.
- Support periodic time tick interrupt with 8 period options 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second.
- Support RTC Time-Tick and Alarm-Match interrupt
- Support CPU wakeup from sleep or standby power-down mode.

### 5.8.3 RTC Block Diagram



Figure 5-33 RTC Block Diagram

### 5.8.4 RTC Function Description

#### 5.8.4.1 Access to RTC register

Due to clock frequency difference between RTC clock and system clock, when the user writes new data to any one of the RTC registers, the register will not be updated until 2 RTC clock periods later (60us). The programmer should take this into consideration for determining access sequence between TSSR, TAR and TLR.

In addition, the RTC block does not check whether written data is out of bounds for a valid BCD time or calendar load. RTC does not check validity of DWR and CLR write either.

#### 5.8.4.2 RTC Initiation

When RTC block is powered on, programmer must write 0xA5EB1357 to INIR register to reset all logic. INIR acts as a hardware reset circuit. Once INIR has been set to 0xA5EB1357, internal reset operation begins. When reset operation is finished, INIR[0] is set by hardware and RTC is ready for operation.

#### 5.8.4.3 RTC Read/Write Enable

Register AER[15:0] serves as the RTC read/write password to protect RTC registers. AER[15:0] have to be set to 0xA965 to enable access. Once set, it will take effect 512 RTC clocks later (about 15ms). Programmer can read RTC enabled status flag in AER.ENF to check whether RTC is access enabled. Access is automatically cleared after 200ms.

#### 5.8.4.4 Frequency Compensation

The RTC Frequency Compensation Register (FCR) allows software to configure digital compensation to the 32768Hz clock input. The FCR allows compensation of a clock input in the range from 32761Hz to 32776Hz. If desired, RTC clock can be measured during manufacture from a GPIO pin and compensation value calculated and stored in flash memory for retrieval when the product is first powered on. Following are compensation examples for a higher or lower measured frequency clock input.

Example 1:

Frequency counter measurement : 32773.65Hz (> 32768 Hz)

Integer part: 32773 = 0x8005

FCR.INTEGER = (32773 - 32761) = 12 = 0x0C

Fractional part: 0.65 x 60 = 39 = 0x27

FCR.FRACTION = 0x27

Example 2

Frequency counter measurement : 32765.27Hz (< 32768 Hz)

Integer part: 32765 = 0x7ffd

FCR.INTEGER = (32765 - 32761) = 4 = 0x04

Fractional part: 0.27 x 60 = 16.2 = 0x10

FCR.FRACTION = 0x10

#### 5.8.4.5 Time and Calendar counter

TLR and CLR are used to load the time and calendar. TAR and CAR are used to set the alarm. They are all represented by a BCD format, see register descriptions for digit assignments.

#### 5.8.4.6 12/24 hour Time Scale Selection

RTC can be selected to report time in either a 12 or 24hour time scale. If 12 hour mode is selected then AM/PM indication is provided by the hour digit being >=2, see register description [Table 5-76](#) for details. The 12/24 hour time scale selection depends on TSSR bit 0.

#### 5.8.4.7 Day of the week counter

The RTC unit provides day of week in Day of the Week Register (DWR). The value is defined from 0 to 6 to represent Sunday to Saturday respectively.

#### 5.8.4.8 Periodic Time Tick Interrupt

The periodic interrupt has 8 period option 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second which are selected by TTR.TTR[2:0]. When periodic time tick interrupt is enabled by setting RIER.TIER to 1, the Periodic Time Tick Interrupt is requested as selected by TTR register.

#### 5.8.4.9 Alarm Time Interrupt

When RTC counter in TLR and CLR is equal to alarm setting in TAR and CAR the alarm interrupt flag (RIIR.AIF) is set. If alarm interrupt is enabled (RIER.AIERN=1) the alarm interrupt is also requested.

#### 5.8.4.10 Additional Notes

1. TAR, CAR, TLR and CLR registers are all BCD counter.
2. Programmer has to make sure that values loaded are reasonable. For example, some invalid CLR values would be 201a (year), 13 (month), 00 (day).
3. Reset state :

| Register | Reset State                       |
|----------|-----------------------------------|
| AER      | 0                                 |
| CLR      | 05/1/1 (year/month/day)           |
| TLR      | 00:00:00 (hour : minute : second) |
| CAR      | 00/00/00 (year/month/day)         |
| TAR      | 00:00:00 (hour : minute : second) |
| TSSR     | 1 (24 hr mode)                    |
| DWR      | 6 (Saturday)                      |
| RIER     | 0                                 |
| RIIR     | 0                                 |
| LIR      | 0                                 |
| TTR      | 0                                 |
| PWRTOUT  | 5555                              |

4. In TLR and TAR, only 2 BCD digits are used to express "year". It is assumed that 2 BCD digits of xY denote 20xY, but not 19xY or 21xY.

### 5.8.5 Register Map

R: read only, W: write only, R/W: both read and write, C: Only value 0 can be written

| Register                    | Offset       | R/W | Description                         | Reset Value | Reference                  |
|-----------------------------|--------------|-----|-------------------------------------|-------------|----------------------------|
| <b>RTC_BA = 0x4000_8000</b> |              |     |                                     |             |                            |
| INIR                        | RTC_BA+0x000 | R/W | RTC Initialization Register         | 0x0000_0000 | <a href="#">Table 5-70</a> |
| AER                         | RTC_BA+0x004 | R/W | RTC Access Enable Register          | 0x0000_0000 | <a href="#">Table 5-71</a> |
| FCR                         | RTC_BA+0x008 | R/W | RTC Frequency Compensation Register | 0x0000_0700 | <a href="#">Table 5-73</a> |
| TLR                         | RTC_BA+0x00C | R/W | Time Load Register                  | 0x0000_0000 | <a href="#">Table 5-74</a> |
| CLR                         | RTC_BA+0x010 | R/W | Calendar Load Register              | 0x0005_0101 | <a href="#">Table 5-75</a> |
| TSSR                        | RTC_BA+0x014 | R/W | Time Scale Selection Register       | 0x0000_0001 | <a href="#">Table 5-76</a> |
| DWR                         | RTC_BA+0x018 | R/W | Day of the Week Register            | 0x0000_0006 | <a href="#">Table 5-77</a> |
| TAR                         | RTC_BA+0x01C | R/W | Time Alarm Register                 | 0x0000_0000 | <a href="#">Table 5-78</a> |
| CAR                         | RTC_BA+0x020 | R/W | Calendar Alarm Register             | 0x0000_0000 | <a href="#">Table 5-79</a> |
| LIR                         | RTC_BA+0x024 | R   | Leap year Indicator Register        | 0x0000_0000 | <a href="#">Table 5-80</a> |
| RIER                        | RTC_BA+0x028 | R/W | RTC Interrupt Enable Register       | 0x0000_0000 | <a href="#">Table 5-81</a> |
| RIIR                        | RTC_BA+0x02C | R/C | RTC Interrupt Indicator Register    | 0x0000_0000 | <a href="#">Table 5-82</a> |
| TTR                         | RTC_BA+0x030 | R/W | RTC Time Tick Register              | 0x0000_0000 | <a href="#">Table 5-83</a> |

### 5.8.6 Register Description

#### RTC Initiation Register (INIR)

| Register | Offset       | R/W | Description             |  |  |  | Reset Value |
|----------|--------------|-----|-------------------------|--|--|--|-------------|
| INIR     | RTC_BA+0x000 | R/W | RTC Initiation Register |  |  |  | 0x0000_0000 |

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

Table 5-70 RTC Initialization Register (INIR, address 0x4000\_8000).

| Bits   | Descriptions  |                                                                                                                                                                                                |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>INIR</b>   | <b>RTC Initialization</b><br>After a power-on reset (POR) RTC block should be initialized by writing 0xA5EB1357 to INIR. This will force a hardware reset then release all logic and counters. |
| [0]    | <b>Active</b> | <b>RTC Active Status</b> (Read only),<br>0: RTC is in reset state<br>1: RTC is in normal active state.                                                                                         |

RTC Access Enable Register (AER)

| Register | Offset       | R/W | Description                | Reset Value |
|----------|--------------|-----|----------------------------|-------------|
| AER      | RTC_BA+0x004 | R/W | RTC Access Enable Register | 0x0000_0000 |

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

Table 5-71 RTC Access Enable Register (AER, address 0x4000\_8004).

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                | Table 5-72 AER.ENF Register Access Effect. |            |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|------------|
| [16]   | ENF          | <p>RTC Register Access Enable Flag (Read only)</p> <p>1 = RTC register read/write enable.<br/>0 = RTC register read/write disable</p> <p>This bit will be set after AER[15:0] register is set to 0xA965, it will clear automatically in 512 RTC clock cycles or AER[15:0] != 0xA965. The effect of AER.ENF on access to each register is given Table 5-72.</p> | AER.ENF                                    | 1      0   |
| [15:0] | AER          | <p>RTC Register Access Enable Password (Write only)</p> <p>0xA965 = Enable RTC access<br/>Others = Disable RTC access</p>                                                                                                                                                                                                                                      | INIR                                       | R/W    R/W |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | FCR                                        | R/W    -   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | TLR                                        | R/W    R   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | CLR                                        | R/W    R   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | TSSR                                       | R/W    R/W |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | DWR                                        | R/W    R   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | TAR                                        | R/W    -   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | CAR                                        | R/W    -   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | LIR                                        | R      R   |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | RIER                                       | R/W    R/W |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | RIIR                                       | R/C    R/C |
|        |              |                                                                                                                                                                                                                                                                                                                                                                | TTR                                        | R/W    -   |

RTC Frequency Compensation Register (FCR)

| Register | Offset | R/W | Description | Reset Value |
|----------|--------|-----|-------------|-------------|
|          |        |     |             |             |

|     |              |     |                                 |             |
|-----|--------------|-----|---------------------------------|-------------|
| FCR | RTC_BA+0x008 | R/W | Frequency Compensation Register | 0x0000_0700 |
|-----|--------------|-----|---------------------------------|-------------|

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

Table 5-73 RTC Frequency Compensation Register (FCR, address 0x4000\_8008).

| Bits                           | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                |           |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-----------|--|--------------------------------|-----------|--------------------------------|-----------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|-------|------|
| [11:8]                         | <b>Integer Part.</b><br>Register should contain the value $(\text{INT}(F_{\text{actual}}) - 32761)$ <table border="1" style="margin-left: 20px;"> <tr> <td>Integer part of detected value</td> <td>FCR[11:8]</td> <td>Integer part of detected value</td> <td>FCR[11:8]</td> </tr> <tr> <td>32776</td> <td>1111</td> <td>32768</td> <td>0111</td> </tr> <tr> <td>32775</td> <td>1110</td> <td>32767</td> <td>0110</td> </tr> <tr> <td>32774</td> <td>1101</td> <td>32766</td> <td>0101</td> </tr> <tr> <td>32773</td> <td>1100</td> <td>32765</td> <td>0100</td> </tr> <tr> <td>32772</td> <td>1011</td> <td>32764</td> <td>0011</td> </tr> <tr> <td>32771</td> <td>1010</td> <td>32763</td> <td>0010</td> </tr> <tr> <td>32770</td> <td>1001</td> <td>32762</td> <td>0001</td> </tr> <tr> <td>32769</td> <td>1000</td> <td>32761</td> <td>0000</td> </tr> </table> |                                |           |  | Integer part of detected value | FCR[11:8] | Integer part of detected value | FCR[11:8] | 32776 | 1111 | 32768 | 0111 | 32775 | 1110 | 32767 | 0110 | 32774 | 1101 | 32766 | 0101 | 32773 | 1100 | 32765 | 0100 | 32772 | 1011 | 32764 | 0011 | 32771 | 1010 | 32763 | 0010 | 32770 | 1001 | 32762 | 0001 | 32769 | 1000 | 32761 | 0000 |
| Integer part of detected value | FCR[11:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Integer part of detected value | FCR[11:8] |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32776                          | 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32768                          | 0111      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32775                          | 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32767                          | 0110      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32774                          | 1101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32766                          | 0101      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32773                          | 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32765                          | 0100      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32772                          | 1011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32764                          | 0011      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32771                          | 1010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32763                          | 0010      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32770                          | 1001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32762                          | 0001      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| 32769                          | 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32761                          | 0000      |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |
| [5:0]                          | <b>Fractional Part</b><br>$\text{Formula} = (\text{fraction part of detected value}) \times 60$<br>Refer to 5.8.4.4 for the examples.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |           |  |                                |           |                                |           |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |       |      |

Note: This register can be read back after the RTC enable is active.

**RTC Time Load Register (TLR)**

This register is Read Only until access enable password is written to **AER** register. The register returns the current time.

| Register | Offset       | R/W | Description        |  |  |  |  | Reset Value |
|----------|--------------|-----|--------------------|--|--|--|--|-------------|
| TLR      | RTC_BA+0x00C | R/W | Time Load Register |  |  |  |  | 0x0000_0000 |

|          |       |      |    |      |     |    |    |
|----------|-------|------|----|------|-----|----|----|
| 23       | 22    | 21   | 20 | 19   | 18  | 17 | 16 |
| Reserved |       | 10HR |    |      | 1HR |    |    |
| 15       | 14    | 13   | 12 | 11   | 10  | 9  | 8  |
| Reserved | 10MIN |      |    | 1MIN |     |    |    |
| 7        | 6     | 5    | 4  | 3    | 2   | 1  | 0  |
| Reserved | 10SEC |      |    | 1SEC |     |    |    |

Table 5-74 RTC Time Load Register (TLR, address 0x4000\_800C).

| Bits    | Descriptions |                                       |
|---------|--------------|---------------------------------------|
| [21:20] | <b>10HR</b>  | 10 Hour Time Digit (0~3) <sup>2</sup> |
| [19:16] | <b>1HR</b>   | 1 Hour Time Digit (0~9)               |
| [14:12] | <b>10MIN</b> | 10 Min Time Digit (0~5)               |
| [11:8]  | <b>1MIN</b>  | 1 Min Time Digit (0~9)                |
| [6:4]   | <b>10SEC</b> | 10 Sec Time Digit (0~5)               |
| [3:0]   | <b>1SEC</b>  | 1 Sec Time Digit (0~9)                |

Note:

1. TLR is a BCD counter and RTC will not check loaded data for validity.
2. Valid range is listed in the parenthesis.

**RTC Calendar Load Register (CLR)**

This register is Read Only until access enable password is written to **AER** register. The register returns the current date.

| Register | Offset       | R/W | Description            |  |  |  |  | Reset Value |
|----------|--------------|-----|------------------------|--|--|--|--|-------------|
| CLR      | RTC_BA+0x010 | R/W | Calendar Load Register |  |  |  |  | 0x0005_0101 |

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

Table 5-75 RTC Calendar Load Register (CLR, address 0x4000\_80010).

| Bits    | Descriptions  |                                           |
|---------|---------------|-------------------------------------------|
| [23:20] | <b>10YEAR</b> | 10-Year Calendar Digit (0~9) <sup>1</sup> |
| [19:16] | <b>1YEAR</b>  | 1-Year Calendar Digit (0~9)               |
| [12]    | <b>10MON</b>  | 10-Month Calendar Digit (0~1)             |
| [11:8]  | <b>1MON</b>   | 1-Month Calendar Digit (0~9)              |
| [5:4]   | <b>10DAY</b>  | 10-Day Calendar Digit (0~3)               |
| [3:0]   | <b>1DAY</b>   | 1-Day Calendar Digit (0~9)                |

<sup>1</sup> CLR is a BCD counter and RTC will not check loaded data for validity. Valid range is listed in parenthesis.

RTC Time Scale Selection Register (TSSR)

| Register | Offset       | R/W | Description                   | Reset Value |
|----------|--------------|-----|-------------------------------|-------------|
| TSSR     | RTC_BA+0x014 | R/W | Time Scale Selection Register | 0x0000_0001 |

Table 5-76 RTC Time Scale Selection Register (TSSR, address 0x4000\_8014).

| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|----------|---|---|---|---|---|---|------|
| Reserved |   |   |   |   |   |   | HR24 |

| Bits               | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                    |                                   |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------|--|--------------------|--------------------|--------------------|-----------------------------------|----|----------|----|----------|----|-----------|----|-----------|----|----------|----|----------|----|----------|----|----------|----|-----------|----|-----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|-----------|----|-----------|----|-----------|----|-----------|
| [0]                | <b>24-Hour / 12-Hour Mode Selection</b><br>Determines whether TLR and TAR are in 24-hour mode or 12-hour mode<br>1 = select 24-hour time scale<br>0 = select 12-hour time scale with AM and PM indication <table border="1" style="margin-left: 20px;"> <tr> <th>24-hour time scale</th> <th>12-hour time scale</th> <th>24-hour time scale</th> <th>12-hour time scale (PM time + 20)</th> </tr> <tr><td>00</td><td>12(AM12)</td><td>12</td><td>32(PM12)</td></tr> <tr><td>01</td><td>01 (AM01)</td><td>13</td><td>21 (PM01)</td></tr> <tr><td>02</td><td>02(AM02)</td><td>14</td><td>22(PM02)</td></tr> <tr><td>03</td><td>03(AM03)</td><td>15</td><td>23(PM03)</td></tr> <tr><td>04</td><td>04 (AM04)</td><td>16</td><td>24 (PM04)</td></tr> <tr><td>05</td><td>05(AM05)</td><td>17</td><td>25(PM05)</td></tr> <tr><td>06</td><td>06(AM06)</td><td>18</td><td>26(PM06)</td></tr> <tr><td>07</td><td>07(AM07)</td><td>19</td><td>27(PM07)</td></tr> <tr><td>08</td><td>08(AM08)</td><td>20</td><td>28(PM08)</td></tr> <tr><td>09</td><td>09(AM09)</td><td>21</td><td>29(PM09)</td></tr> <tr><td>10</td><td>10 (AM10)</td><td>22</td><td>30 (PM10)</td></tr> <tr><td>11</td><td>11 (AM11)</td><td>23</td><td>31 (PM11)</td></tr> </table> |                    |                                   |  | 24-hour time scale | 12-hour time scale | 24-hour time scale | 12-hour time scale (PM time + 20) | 00 | 12(AM12) | 12 | 32(PM12) | 01 | 01 (AM01) | 13 | 21 (PM01) | 02 | 02(AM02) | 14 | 22(PM02) | 03 | 03(AM03) | 15 | 23(PM03) | 04 | 04 (AM04) | 16 | 24 (PM04) | 05 | 05(AM05) | 17 | 25(PM05) | 06 | 06(AM06) | 18 | 26(PM06) | 07 | 07(AM07) | 19 | 27(PM07) | 08 | 08(AM08) | 20 | 28(PM08) | 09 | 09(AM09) | 21 | 29(PM09) | 10 | 10 (AM10) | 22 | 30 (PM10) | 11 | 11 (AM11) | 23 | 31 (PM11) |
| 24-hour time scale | 12-hour time scale                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 24-hour time scale | 12-hour time scale (PM time + 20) |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 00                 | 12(AM12)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 12                 | 32(PM12)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 01                 | 01 (AM01)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 13                 | 21 (PM01)                         |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 02                 | 02(AM02)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 14                 | 22(PM02)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 03                 | 03(AM03)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 15                 | 23(PM03)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 04                 | 04 (AM04)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 16                 | 24 (PM04)                         |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 05                 | 05(AM05)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 17                 | 25(PM05)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 06                 | 06(AM06)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 18                 | 26(PM06)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 07                 | 07(AM07)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 19                 | 27(PM07)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 08                 | 08(AM08)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 20                 | 28(PM08)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 09                 | 09(AM09)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 21                 | 29(PM09)                          |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 10                 | 10 (AM10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 22                 | 30 (PM10)                         |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |
| 11                 | 11 (AM11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 23                 | 31 (PM11)                         |  |                    |                    |                    |                                   |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |           |    |           |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |          |    |           |    |           |    |           |    |           |

RTC Day of the Week Register (DWR)

| Register | Offset       | R/W | Description              | Reset Value |
|----------|--------------|-----|--------------------------|-------------|
| DWR      | RTC_BA+0x018 | R/W | Day of the Week Register | 0x0000_0006 |

|          |   |   |   |   |     |   |   |
|----------|---|---|---|---|-----|---|---|
| 7        | 6 | 5 | 4 | 3 | 2   | 1 | 0 |
| Reserved |   |   |   |   | DWR |   |   |

Table 5-77 RTC Day of Week Register (DWR, address 0x4000\_8018).

| Bits  | Descriptions    | Day of the Week Register                                                                                                                                                                                                                                                                                                                                      |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------|---|--------|---|--------|---|---------|---|-----------|---|----------|---|--------|---|----------|
| [2:0] | DWR             | <table border="1"><thead><tr><th>Value</th><th>Day of the Week</th></tr></thead><tbody><tr><td>0</td><td>Sunday</td></tr><tr><td>1</td><td>Monday</td></tr><tr><td>2</td><td>Tuesday</td></tr><tr><td>3</td><td>Wednesday</td></tr><tr><td>4</td><td>Thursday</td></tr><tr><td>5</td><td>Friday</td></tr><tr><td>6</td><td>Saturday</td></tr></tbody></table> | Value | Day of the Week | 0 | Sunday | 1 | Monday | 2 | Tuesday | 3 | Wednesday | 4 | Thursday | 5 | Friday | 6 | Saturday |
| Value | Day of the Week |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 0     | Sunday          |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 1     | Monday          |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 2     | Tuesday         |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 3     | Wednesday       |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 4     | Thursday        |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 5     | Friday          |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |
| 6     | Saturday        |                                                                                                                                                                                                                                                                                                                                                               |       |                 |   |        |   |        |   |         |   |           |   |          |   |        |   |          |

RTC Time Alarm Register (TAR)

| Register | Offset       | R/W | Description         | Reset Value |
|----------|--------------|-----|---------------------|-------------|
| TAR      | RTC_BA+0x01C | R/W | Time Alarm Register | 0x0000_0000 |

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

Table 5-78 RTC Time Alarm Register (TAR, address 0x4000\_801C).

| Bits    | Descriptions |                                                        |
|---------|--------------|--------------------------------------------------------|
| [21:20] | <b>10HR</b>  | 10 Hour Time Digit of Alarm Setting (0~3) <sup>2</sup> |
| [19:16] | <b>1HR</b>   | 1 Hour Time Digit of Alarm Setting (0~9)               |
| [14:12] | <b>10MIN</b> | 10 Min Time Digit of Alarm Setting (0~5)               |
| [11:8]  | <b>1MIN</b>  | 1 Min Time Digit of Alarm Setting (0~9)                |
| [6:4]   | <b>10SEC</b> | 10 Sec Time Digit of Alarm Setting (0~5)               |
| [3:0]   | <b>1SEC</b>  | 1 Sec Time Digit of Alarm Setting (0~9)                |

Note:

1. TAR is a BCD digit counter and RTC will not check validity of loaded data. Valid range is listed in the parenthesis.
2. This register can be read back after the RTC unit is active.

RTC Calendar Alarm Register (CAR)

| Register | Offset       | R/W | Description             |  |  |  | Reset Value |
|----------|--------------|-----|-------------------------|--|--|--|-------------|
| CAR      | RTC_BA+0x020 | R/W | Calendar Alarm Register |  |  |  | 0x0000_0000 |

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

Table 5-79 RTC Calendar Alarm Register (CAR, address 0x4000\_8020).

| Bits    | Descriptions  |                                                |
|---------|---------------|------------------------------------------------|
| [23:20] | <b>10YEAR</b> | 10-Year Calendar Digit of Alarm Setting (0~9)  |
| [19:16] | <b>1YEAR</b>  | 1-Year Calendar Digit of Alarm Setting (0~9)   |
| [12]    | <b>10MON</b>  | 10-Month Calendar Digit of Alarm Setting (0~1) |
| [11:8]  | <b>1MON</b>   | 1-Month Calendar Digit of Alarm Setting (0~9)  |
| [5:4]   | <b>10DAY</b>  | 10-Day Calendar Digit of Alarm Setting (0~3)   |
| [3:0]   | <b>1DAY</b>   | 1-Day Calendar Digit of Alarm Setting (0~9)    |

Note:

1. TLR is a BCD digit counter and RTC will not check validity loaded data, valid range is listed in the parenthesis.
2. This register can be read back after the RTC unit is active.

RTC Leap year Indication Register (LIR)

| Register | Offset       | R/W | Description                       | Reset Value |
|----------|--------------|-----|-----------------------------------|-------------|
| LIR      | RTC_BA+0x024 | R   | RTC Leap year Indication Register | 0x0000_0000 |

|          |   |   |   |   |   |   |     |
|----------|---|---|---|---|---|---|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Reserved |   |   |   |   |   |   | LIR |

Table 5-80 RTC Leap Year Indicator Register (LIR, address 0x4000\_8024).

| Bits | Descriptions |                                                                                                                           |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------|
| [0]  | LIR          | <b>Leap Year Indication Register</b> (read only).<br>1 = Current year is leap year<br>0 = Current year is not a leap year |

RTC Interrupt Enable Register (RIER)

| Register | Offset       | R/W | Description                   | Reset Value |
|----------|--------------|-----|-------------------------------|-------------|
| RIER     | RTC_BA+0x028 | R/W | RTC Interrupt Enable Register | 0x0000_0000 |

|          |   |   |   |   |   |      |      |
|----------|---|---|---|---|---|------|------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
| Reserved |   |   |   |   |   | TIER | AIER |

Table 5-81 RTC Interrupt Enable Register (RIER, address 0x4000\_8028).

| Bits | Descriptions |                                                                                                                                            |
|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| [1]  | <b>TIER</b>  | <b>Time-Tick Interrupt and Wakeup-by-Tick Enable</b><br>1 = RTC Time-Tick Interrupt is enabled<br>0 = RTC Time-Tick Interrupt is disabled. |
| [0]  | <b>AIER</b>  | <b>Alarm Interrupt Enable</b><br>1 = RTC Alarm Interrupt is enabled<br>0 = RTC Alarm Interrupt is disabled                                 |

RTC Interrupt Indication Register (RIIR)

| Register | Offset       | R/W | Description                       | Reset Value |
|----------|--------------|-----|-----------------------------------|-------------|
| RIIR     | RTC_BA+0x02C | R/C | RTC Interrupt Indication Register | 0x0000_0000 |

|          |   |   |   |   |   |     |     |
|----------|---|---|---|---|---|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
| Reserved |   |   |   |   |   | TIF | AIF |

Table 5-82 RTC Interrupt Indication Register (RIIR, address 0x4000\_802C).

| Bits | Descriptions                                                                                                                                                                                                                                                                                                                                                                    |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]  | <b>TI</b><br><b>RTC Time-Tick Interrupt Flag</b><br>When RTC Time-Tick Interrupt is enabled (RIER.TIER=1), RTC unit will set TIF high at the rate selected by TTR[2:0]. This bit cleared/acknowledged by writing 1 to it.<br>1= Indicates RTC Time-Tick Interrupt generated.<br>0= Indicates no Time-Tick Interrupt condition                                                   |
| [0]  | <b>AI</b><br><b>RTC Alarm Interrupt Flag</b><br>When RTC Alarm Interrupt is enabled (RIER.AIER=1), RTC unit will set AIF to high once the RTC real time counters TLR and CLR reach the alarm setting time registers TAR and CAR. This bit cleared/acknowledged by writing 1 to it.<br>1= Indicates RTC Alarm Interrupt generated.<br>0= Indicates no Alarm Interrupt condition. |

RTC Time-Tick Register (TTR)

| Register | Offset       | R/W | Description            | Reset Value |
|----------|--------------|-----|------------------------|-------------|
| TTR      | RTC_BA+0x030 | R/C | RTC Time-Tick Register | 0x0000_0000 |

|          |   |   |   |      |          |   |   |
|----------|---|---|---|------|----------|---|---|
| 7        | 6 | 5 | 4 | 3    | 2        | 1 | 0 |
| Reserved |   |   |   | TWKE | TTR[2:0] |   |   |

Table 5-83 RTC Time-Tick Register (TTR, address 0x4000\_8030).

| Bits     | Descriptions       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
|----------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|---|---|---|-----|---|-----|---|-----|---|------|---|------|---|------|---|-------|
| [3]      | TWKE               | <p><b>RTC Timer Wakeup CPU Function Enable Bit</b></p> <p>If TWKE is set before CPU is in power-down mode, when a RTC Time-Tick or Alarm Match occurs, CPU will wake up.</p> <p>1= Enable the Wakeup function.<br/>0= Disable Wakeup CPU function.</p>                                                                                                                                                                                                                                                                                                                                            |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| [2:0]    | TTR                | <p><b>Time Tick Register</b></p> <p>The RTC time tick period for Periodic Time-Tick Interrupt request.</p> <table border="1"> <thead> <tr> <th>TTR[2:0]</th> <th>Time tick (second)</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>1</td> </tr> <tr> <td>1</td> <td>1/2</td> </tr> <tr> <td>2</td> <td>1/4</td> </tr> <tr> <td>3</td> <td>1/8</td> </tr> <tr> <td>4</td> <td>1/16</td> </tr> <tr> <td>5</td> <td>1/32</td> </tr> <tr> <td>6</td> <td>1/64</td> </tr> <tr> <td>7</td> <td>1/128</td> </tr> </tbody> </table> <p>Note: This register can be read back after the RTC is active.</p> | TTR[2:0] | Time tick (second) | 0 | 1 | 1 | 1/2 | 2 | 1/4 | 3 | 1/8 | 4 | 1/16 | 5 | 1/32 | 6 | 1/64 | 7 | 1/128 |
| TTR[2:0] | Time tick (second) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 0        | 1                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 1        | 1/2                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 2        | 1/4                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 3        | 1/8                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 4        | 1/16               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 5        | 1/32               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 6        | 1/64               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |
| 7        | 1/128              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                    |   |   |   |     |   |     |   |     |   |      |   |      |   |      |   |       |

## 5.9 Serial Peripheral Interface (SPI) Controller

### 5.9.1 Overview

The Serial Peripheral Interface (SPI) is a synchronous serial data communication protocol which operates in full duplex mode. Devices communicate in master/slave mode with 4-wire bi-directional interface. The ISD9160 contains an SPI controller performing a serial-to-parallel conversion of data received from an external device, and a parallel-to-serial conversion of data transmitted to an external device. The SPI controller can be set as a master with up to 2 slave select (SSB) address lines to access two slave devices; it also can be set as a slave controlled by an off-chip master device.

### 5.9.2 Features

- Supports master or slave mode operation.
- Supports one or two channels of serial data.
- Configurable word length of up to 32 bits. Up to two words can be transmitted per a transaction, giving a maximum of 64 bits for each data transaction.
- Provide burst mode operation.
- MSB or LSB first transfer.
- 2 device/slave select lines in master mode, single device/slave select line in slave mode.
- Byte or word Sleep Suspend Mode .
- Support dual FIFO mode.
- PDMA access support.

### 5.9.3 SPI Block Diagram



Figure 5-34 SPI Block Diagram

#### 5.9.4 SPI Function Descriptions

##### Master/Slave Mode

This SPI controller can be configured as in master or slave mode by setting the SLAVE bit (SPI->CNTRL.SLAVE). In master mode the ISD9160 generates SCLK and SSB signals to access one or more slave devices. In slave mode the ISD9160 monitors SCLK and SSB signals to respond to data transactions from an off-chip master. The signal directions are summarized in the application block diagrams of Figure 5-35 and Figure 5-36.



Figure 5-35 SPI Master Mode Application Block Diagram



Figure 5-36 SPI Slave Mode Application Block Diagram

Preliminary

### Slave Select

In master mode, the SPI controller can address up to two off-chip slave devices through the slave select output pins SPI\_SSB0 and SPI\_SSB1. Only one slave can be addressed at any one time. If more slave address lines are required, GPIO pins can be manually configured to provide additional SSB lines. In slave mode, the off-chip master device drives the slave select signal SPI\_SSB0 to address the SPI controller. The slave select signal can be programmed to be active low or active high via the SPI->SSR.SS\_LVL bit. In addition the SPI->SSR.SS\_LTRIG bit defines whether the slave select signals are level triggered or edge triggered. The selection of trigger condition depends on what type of peripheral slave/master device is connected.

### Automatic Slave Select

In master mode, if the bit SPI->SSR.ASS is set, the slave select signals will be generated automatically and output to SPI\_SSB0 and SPI\_SSB1 pins according to registers SPI->SSR.SSR[0] and SPI->SSR.SSR[1]. In this mode, SPI controller will assert SSB when transaction is triggered and de-assert when data transfer is finished. If the SPI->SSR.ASS bit is cleared, the slave select output signals are asserted and de-asserted by manual setting and clearing the related bits in the SPI->SSR.SSR[1:0] register. The active level of the slave select output signals is specified by the SPI->SSR.SS\_LVL bit.

### Serial Clock

In master mode, writing a divisor into the SPI->DIVIDER.DIVIDER register will program the output frequency of serial clock to the SPI\_SCLK output port. In slave mode, the off-chip master device drives the serial clock through the SPI\_SCLK.

### Clock Polarity

The SPI->CNTRL.CLKP bit defines the serial clock idle state in master mode. If CLKP = 1, the output SPI\_SCLK is high in idle state. If CLKP=0,it is low in idle state.

### Transmit/Receive Bit Length

The bit length of a transfer word is defined in SPI->CNTRL.TX\_BIT\_LEN bit field. It is set to define the length of a transfer word and can be up to 32 bits in length. TX\_BIT\_LEN=0x0 enables 32bit word length.

### Burst Mode

The SPI controller has a burst mode controlled by the SPI->CNTRL.TX\_NUM field. If set to 0x01, SPI controller will burst two transactions from the TX[0] and TX[1] registers as shown in the waveform below:



Figure 5-37 Two Transactions in One Transfer (Burst Mode)

### LSB First

The SPI->CNTRL.LSB bit defines the **bit** order of data transmission. If LSB=0 then MSB of transfer word is sent first in time. If LSB=1 then LSB of transfer word is sent first in time.

### Transmit Edge

The SPI->CNTRL.TX\_NEG bit determines whether transmit data is changed on the positive or negative edge of the SPI\_SCLK serial clock. If TX\_NEG=0 then transmitted data will change state on the rising edge of SPI\_SCLK. If TX\_NEG=1 then transmitted data will change state on the falling edge of SPI\_SCLK.

### Receive Edge

The SPI->CNTRL.RX\_NEG bit determines whether data is received at either the negative edge or positive edge of serial clock SPI\_SCLK. If RX\_NEG=1 then data is clocked in on the falling edge of SPI\_SCLK. If RX\_NEG=0 data is clocked in on the rising edge of SPI\_SCLK. Note that RX\_NEG should be the inverse of TX\_NEG for standard SPI operation.

### Word Sleep Suspend

The bit field SPI->CNTRL.SLEEP provides a configurable suspend interval of SLEEP+2 serial clock periods between successive word transfers in master mode. The suspend interval is from the last falling clock edge of the preceding transfer word to the first rising clock edge of the following transfer word if CLKP = 0. If CLKP = 1, the interval is from the rising clock edge of the preceding transfer word to the falling clock edge of the following transfer word. The default value of SLEEP is 0x0 (2 serial clock cycles). Word Sleep only occurs when TX\_NUM=1. For TX\_NUM=0, this parameter will determine a Byte Sleep condition if the BYTE\_SLEEP bit is set.



Figure 5-38 Word Sleep Suspend Mode

### Byte Endian

APB access to the SPI controller is via the 32bit wide TX and RX registers. When the transfer is set as MSB first (SPI->CNTRL.LSB = 0) and the SPI->CNTRL.BYTE\_ENDIAN bit is set, the data stored in the TX buffer and RX buffer will be rearranged such that the least significant **physical byte** is processed first. For TX\_BIT\_LEN =0 (32 bits transfer), the sequence of transmitted/received data will be BYTE0, BYTE1, BYTE2, and then BYTE3. If TX\_BIT\_LEN is set to 24-bits, the sequence will be BYTE0, BYTE1, and BYTE2. The rule of 16-bits mode is the same as above, see Figure 5-39.



Figure 5-39 Byte Re-Ordering Transfer

Byte ordering can be a confusing issue when converting from arrays of data processed by the CPU for transmission out the SPI port. The CortexM0 stores data in a little endian format; that is the LSB of a multi-byte word or half-word are stored first in memory. Consider how the CortexM0 stores the following arrays in memory:

1. unsigned char ucSPI\_DATA[]={0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08};
2. unsigned int uiSPI\_DATA[]={0x01020304, 0x05060708};



Figure 5-40 Byte Order in Memory

It can be seen from Figure 5-40 that byte order for an array of bytes is different than that of an array of words. Now consider if this data were to be sent to the SPI port; the user could:

1. Set TX\_BIT\_LEN=8 and send data byte-by-byte SPI->TX[0] = ucSPI\_DATA[i++]
2. Set TX\_BIT\_LEN=32 and send word-by-word SPI->TX[0] = uiSPI\_DATA[i++]

Both of these would result in the byte stream {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08} being sent.

It would be common that a byte array of data is constructed but user, for efficiency, wishes to transfer

data to SPI via word transfers. Consider the situation of Figure 5-41 where a int pointer points to the byte data array.

|                | RAM Address    | RAM Contents                 |
|----------------|----------------|------------------------------|
|                | 0x20000014     | Byte0 Byte1 Byte2 Byte3      |
|                | 0x20000010     | Byte0 Byte1 Byte2 Byte3      |
|                | 0x2000000c     | 0x08 0x07 0x06 0x05          |
|                | 0x20000008     | 0x04 0x03 0x02 0x01          |
|                | 0x20000004     | 0x05 0x06 0x07 0x08          |
|                | 0x20000000     | 0x01 0x02 0x03 0x04          |
| uiSPI_DATA[] → | ucSPI_DATA[] → | 0x20000000                   |
|                | APB Data Bus   | [7:0] [15:8] [23:16] [31:24] |

Figure 5-41 Byte Order in Memory

Now if we set TX\_BIT\_LEN=32 and sent word-by-word SPI->TX[0] = uiSPI\_DATA[i++], the order transmitted would be {0x04, 0x03, 0x02, 0x01, 0x08, 0x07, 0x06, 0x05}. However if we set BYTE\_ENDIAN=1, we would reverse this order to the desired stream: {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08}.

### Byte Sleep Suspend

In master mode, if SPI->CNTRL.BYTE\_SLEEP is set to 1, the hardware will insert a suspend interval of SPI->CNTRL.SLEEP+2 serial clock periods between two successive bytes in a transfer word. Note that the byte suspend function is only valid for 32bit word transfers, that is TX\_BIT\_LEN=0x00.



Figure 5-42 Byte Suspend Mode

### Interrupt

The SPI controller can generate a CPU interrupt when data transfer is finished. When a transfer request triggered by GO\_BUSY is finished, the interrupt flag (SPI->CNTRL.IF) will be set by hardware.

If the SPI interrupt is enabled (SPI->CNTRL.IE) this will also generate a CPU interrupt. To clear the interrupt event flag, software must write a '1' to it.

### FIFO Mode

The SPI controller supports a dual buffer mode when SPI->CNTRL.FIFO is set as 1. In normal mode, software can only update the transmitted data when the current transmission is done. In FIFO mode, the next transmitted data can be written into the SPI\_TX buffer at any time when in master mode or the GO\_BUSY bit is set in slave mode. This data will load into the transmit buffer when the current transmission done.

After the FIFO bit is set, transmission is repeated automatically when the transmitted data is updated in time and it will continue until this bit is cleared. When cleared, the transmission will finish when the current transmission done. The user can also read the received data at any time before the next transmission is complete, wherein the receive buffer will be updated with new received data. If transmit data isn't updated before the current transmission is done, the transaction will stop. The transmission will resume automatically when transmit data is written into this buffer again.

Before the FIFO bit is set, the user can write first data into SPI\_TX buffer. Setting FIFO active will load the first data into the current transmission buffer. A subsequent write to SPI\_TX will load the TX FIFO which will be loaded into the transmission buffer after the 1st transmission is done.

This function is also supported in slave mode. The GO\_BUSY must be set as 1 before the external serial clock input and it will keep going until the FIFO is cleared.

The delay period between two transmissions is programmable. It is the same as the suspend interval on SLEEP parameter.

### Two Channel Mode

The SPI controller supports a two channel mode where data can be sent and received on alternate MOSI1 and MISO1 lines concurrently with data on MOSI0 and MISO0. The data for this second channel is the SPI->RX[1] and SPI\_TX[1] buffers. Mode is enabled by setting the SPI->CNTRL.TWOB bit. This mode is only available when TX\_NUM=0.



Figure 5-43 Two Bits Transfer Mode

### Variable Serial Clock Frequency

In master mode 16 bit transfers, the output of serial clock can be programmed as variable frequency

pattern if the Variable Clock Enable bit SPI->CNTRL.VARCLK\_EN is enabled. The frequency pattern format is defined in SPI->VARCLK register. If the bit content of VARCLK is '0' the output period for that bit is determined by setting of SPI->DIVIDER.DIVIDER, if the bit content of VARCLK is '1', the output period for that bit is determined by the SPI->DIVIDER.DIVIDER2 register. The following figure shows the timing relationships of serial clock (SCLK), to the VARCLK, the DIVIDER and the DIVIDER2 registers. A two-bit combination in the VARCLK defines one clock cycle. The bit field VARCLK[31:30] defines the first clock cycle of SCLK. The bit field VARCLK[29:28] defines the second clock cycle of SCLK and so on. The clock source selections are defined in VARCLK and must be set 1 cycle before the next clock option. For example, if there are 5 CLK1 cycle in SPICLK, the VARCLK shall set 9 '0' in the MSB of VARCLK. The 10th shall be set as '1' in order to switch the next clock source is CLK2. Note that when VARCLK\_EN bit is set, the setting of TX\_BIT\_LEN must be programmed as 0x10 (16 bits mode only).



Figure 5-44 Variable Serial Clock Frequency

### 5.9.5 SPI Timing Diagram

In master/slave mode, the device address/slave select (SPI\_SSBO/1) signal can be configured as active low or active high by the SPI->SSR.SS\_LVL bit. In slave mode, the SPI-SSR.SS\_LTRIG will determine whether the slave select signal is treated as a level triggered or edge triggered signal.

The serial clock phase and polarity is controlled by CLKP, RX\_NEG and TX\_NEG bits. The bit length of a transfer word is configured by the TX\_BIT\_LEN parameter. Whether data transmission is MSB first or LSB first is controlled by the SPI->CNTRL.LSB bit. Four examples of SPI timing diagrams for master/slave operations and the related settings are shown as below.



Figure 5-45 SPI Timing in Master Mode



Figure 5-46 SPI Timing in Master Mode (Alternate Phase of SPICLK)



Figure 5-47 SPI Timing in Slave Mode



Figure 5-48 SPI Timing in Slave Mode (Alternate Phase of SPICLK)

### 5.9.6 SPI Configuration Examples

- Example 1, SPI controller is set as a master to access an off-chip slave device with following specifications:

- Data bit latched on positive edge of serial clock
- Data bit driven on negative edge of serial clock
- Data be transferred from MSB first
- SCLK low in idle state
- Only one byte data be transmitted/received in a transfer
- Slave select signal is active low
- SCLK frequency is 10MHz

To configure the SPI interface to the above specifications perform the following steps:

- 1) Write a divisor into the SPI->DIVIDER register to determine the output frequency of serial clock. Driver function DrvSPI\_SetClock(0,10000000,0) can be used to achieve this.
- 2) Configure the SPI->SSR register to address device. For example to manually address, set SPI-SSR.ASS=0, SPI->SSR.SSR\_LVL=0 for active low SS. When software wishes to address device it will set SPI->SSR.SSR=1 to output an active SS on SPI\_SSBO pin.
- 3) Configure the SPI->CNTRL register. Set SPI->CNTRL.SLAVE=0 for master mode, set SPI->CNTRL.CLKP=0 for SCLK polarity normally low, set SPI->CNTRL.TX\_NEG=1 so that data changes on falling edge of SCLK, set SPI->CNTRL.RX\_NEG=0 so that data is latched into device on positive edge of SCLK, set SPI->CNTRL.TX\_BIT\_LEN=8 and SPI->CNTRL.TX\_NUM=0 for a single byte transfer and finally set SPI->CNTRL.LSB=0 for MSB first transfer.
- 4) If manually selecting slave device set SPI->SSR.SSR=1.
- 5) To transmit one byte of data, write data to SPI->TX[0] register. If only doing a receive, write a dummy byte to SPI->TX[0] register.
- 6) Enable the SPI->CNTRL.GO\_BUSY bit to start the data transfer over the SPI interface.

-- Wait for SPI transfer to finish. Can be interrupt driven (if the interrupt enable SPI->CNTRL.IE bit is set) or by polling the GO\_BUSY bit which will be cleared to 0 by hardware automatically at end of transmission. --

- 7) Read out the received one byte data from SPI->RX[0]
- 8) Go to 5) to continue another data transfer or set SPI->SSR.SSR=0 to deactivate the off-chip slave devices.

- Example 2, SPI controller is set as a slave device that controlled by an off-chip master device with the following characteristics:

- Data bit latched on positive edge of serial clock
- Data bit driven on negative edge of serial clock
- Data be transferred from LSB first
- SCLK high in idle state

- Only one byte data be transmitted/received in a transfer
- Slave select signal is active high level trigger

To configure the SPI interface to the above specifications perform the following steps:

- 1) Configure the SPI->SSR register. SPI->SSR.SS\_LVL=1 for active high slave select, SPI->SSR.SS\_LTRIG=1 for level sensitive trigger.
- 2) Configure the SPI->CNTRL register. Set SPI->CNTRL.SLAVE=1 for slave mode, set SPI->CNTRL.CLKP=1 for SCLK polarity idle high, set SPI->CNTRL.TX\_NEG=1 so that data changes on falling edge of SCLK, set SPI->CNTRL.RX\_NEG=0 so that data is latched into device on positive edge of SCLK, set SPI->CNTRL.TX\_BIT\_LEN=8 and SPI->CNTRL.TX\_NUM=0 for a single byte transfer and finally set SPI->CNTRL.LSB=1 for LSB first transfer.
- 3) If SPI slave is to transmit one byte of data to the off-chip master device, write first byte to TX[0] register. If no data to be transmitted write a dummy byte.
- 4) Enable the GO\_BUSY bit to wait for the slave select trigger input and serial clock input from the off-chip master device to start the data transfer at the SPI interface.

-- -- Wait for SPI transfer to finish. Can be interrupt driven (if the interrupt enable SPI->CNTRL.IE bit is set) or by polling the GO\_BUSY bit which will be cleared to 0 by hardware automatically at end of transmission. --

- 5) Read out the received data from RX[0] register.
- 6) Go to 3) to continue another data transfer or disable the GO\_BUSY bit to stop data transfer.

### 5.9.7 SPI Serial Interface Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                     | Offset         | R/W | Description                     | Reset Value | Reference                  |
|------------------------------|----------------|-----|---------------------------------|-------------|----------------------------|
| <b>SPI0_BA = 0x4003_0000</b> |                |     |                                 |             |                            |
| CNTRL                        | SPI0_BA + 0x00 | R/W | Control and Status Register     | 0x0000_0004 | <a href="#">Table 5-84</a> |
| DIVIDER                      | SPI0_BA + 0x04 | R/W | Clock Divider Register          | 0x0000_0000 | <a href="#">Table 5-85</a> |
| SSR                          | SPI0_BA + 0x08 | R/W | Slave Select Register           | 0x0000_0000 | <a href="#">Table 5-86</a> |
| RX[0]                        | SPI0_BA + 0x10 | R   | Data Receive Register 0         | 0x0000_0000 | <a href="#">Table 5-87</a> |
| RX[1]                        | SPI0_BA + 0x14 | R   | Data Receive Register 1         | 0x0000_0000 | <a href="#">Table 5-87</a> |
| TX[0]                        | SPI0_BA + 0x20 | W   | Data Transmit Register 0        | 0x0000_0000 | <a href="#">Table 5-88</a> |
| TX[1]                        | SPI0_BA + 0x24 | W   | Data Transmit Register 1        | 0x0000_0000 | <a href="#">Table 5-88</a> |
| VARCLK                       | SPI0_BA + 0x34 | R/W | Variable Clock Pattern Register | 0x007f_ff87 | <a href="#">Table 5-89</a> |
| DMA                          | SPI0_BA + 0x38 | R/W | SPI DMA Control Register        | 0x0000_0000 | <a href="#">Table 5-90</a> |

NOTE 1: When software programs CNTRL, the GO\_BUSY bit should be written last.

### 5.9.8 SPI Control Register Description

#### SPI Control and Status Register (CNTRL)

| Register | Offset         | R/W | Description                 |  |  |  | Reset Value |
|----------|----------------|-----|-----------------------------|--|--|--|-------------|
| CNTRL    | SPI0_BA + 0x00 | R/W | Control and Status Register |  |  |  | 0x0000_0004 |

|            |      |      |         |    |          |         |          |
|------------|------|------|---------|----|----------|---------|----------|
| 31         | 30   | 29   | 28      | 27 | 26       | 25      | 24       |
| Reserved   |      |      | TX_FULL |    | TX_EMPTY | RX_FULL | RX_EMPTY |
| 23         | 22   | 21   | 20      | 19 | 18       | 17      | 16       |
| VARCLK_EN  | TWOB | FIFO | REORDER |    | SLAVE    | IE      | IF       |
| 15         | 14   | 13   | 12      | 11 | 10       | 9       | 8        |
| SLEEP      |      |      | CLKP    |    | LSB      | TX_NUM  |          |
| 7          | 6    | 5    | 4       | 3  | 2        | 1       | 0        |
| TX_BIT_LEN |      |      | TX_NEG  |    | RX_NEG   | GO_BUSY |          |

Table 5-84 SPI Control and Status Register (CNTRL, address 0x4003\_0000)

| Bits    | Descriptions  |                                                                                                                                                    |
|---------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved      | Reserved                                                                                                                                           |
| [28]    | DMA_ASS_BURST | <b>Enable DMA Automatic SS function.</b><br>When enabled, interface will automatically generate a SS signal for an entire PDMA access transaction. |
| [27]    | TX_FULL       | <b>Transmit FIFO FULL STATUS</b><br>1 = The transmit data FIFO is full.<br>0 = The transmit data FIFO is not full.                                 |
| [26]    | TX_EMPTY      | <b>Transmit FIFO EMPTY STATUS</b><br>1 = The transmit data FIFO is empty.<br>0 = The transmit data FIFO is not empty.                              |
| [25]    | RX_FULL       | <b>Receive FIFO FULL STATUS</b><br>1 = The receive data FIFO is full.<br>0 = The receive data FIFO is not full.                                    |
| [24]    | RX_EMPTY      | <b>Receive FIFO EMPTY STATUS</b><br>1 = The receive data FIFO is empty.<br>0 = The receive data FIFO is not empty.                                 |

|         |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23]    | <b>VARCLK_EN</b>   | <b>Variable Clock Enable (Master Only)</b><br>1 = SCLK output frequency is variable. The output frequency is determined by the value of VARCLK, DIVIDER, and DIVIDER2.<br>0 = The serial clock output frequency is fixed and determined only by the value of DIVIDER.<br>Note that when enabled, the setting of TX_BIT_LEN must be programmed as 0x10 (16 bits mode)                                                                                                                                                                                                                                                                                                            |
| [22]    | <b>TWOB</b>        | <b>Two Bits Transfer Mode</b><br>1 = Enable two-bit transfer mode.<br>0 = Disable two-bit transfer mode.<br>Note that when enabled in master mode, MOSI0 data comes from TX[0] and MOSI1 data from TX[1]. Likewise RX[0] receives bit stream from MISO0 and RX[1] from MISO1. Note that when enabled, the setting of TX_NUM must be programmed as 0x00                                                                                                                                                                                                                                                                                                                          |
| [21]    | <b>FIFO</b>        | <b>FIFO Mode</b><br>0 = No FIFO present on transmit and receive buffer.<br>1 = Enable FIFO on transmit and receive buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [20]    | <b>BYTE_ENDIAN</b> | <b>Byte Endian Reorder Function</b><br>This function changes the order of bytes sent/received to be least significant physical byte first.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [19]    | <b>BYTE_SLEEP</b>  | <b>Insert Sleep interval between Bytes</b><br>This function is only valid for 32bit transfers (TX_BIT_LEN=0). If set then a pause of (SLEEP+2) SCLK cycles is inserted between each byte transmitted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [18]    | <b>SLAVE</b>       | <b>Master Slave Mode Control</b><br>0 = Master mode.<br>1 = Slave mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [17]    | <b>IE</b>          | <b>Interrupt Enable</b><br>0 = Disable SPI Interrupt.<br>1 = Enable SPI Interrupt to CPU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [16]    | <b>IF</b>          | <b>Interrupt Flag</b><br>0 = Indicates the transfer is not finished yet.<br>1 = Indicates that the transfer is complete. Interrupt is generated to CPU if enabled.<br><b>NOTE:</b> This bit is cleared by writing 1 to itself.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [15:12] | <b>SLEEP</b>       | <b>Suspend Interval (Master Only)</b><br>These four bits provide configurable suspend interval between two successive transmit/receive transactions in a transfer. The suspend interval is from the last falling clock edge of the current transaction to the first rising clock edge of the successive transaction if CLKP = 0. If CLKP = 1, the interval is from the rising clock edge to the falling clock edge. The default value is 0x0. When TX_NUM = 00b, setting this field has no effect on transfer except as determined by REORDER[0] setting. The suspend interval is determined according to the following equation:<br>$(SLEEP[3:0] + 2) * \text{period of SCLK}$ |

|       |                   |                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11]  | <b>CLKP</b>       | <b>Clock Polarity</b><br>0 = SCLK idle low.<br>1 = SCLK idle high.                                                                                                                                                                                                                                                                                                                                           |
| [10]  | <b>LSB</b>        | <b>LSB First</b><br>0 = The MSB is transmitted/received first (which bit in SPI_TX[0]/[1] and SPI_RX[0]/[1] register that depends on the TX_BIT_LEN field).<br>1 = The LSB is sent first on the line (bit 0 of SPI_TX[0]/[1]), and the first bit received from the line will be put in the LSB position in the Rx register (bit 0 of SPI_RX[0]/[1]).                                                         |
| [9:8] | <b>TX_NUM</b>     | <b>Transmit/Receive Word Numbers</b><br>This field specifies how many transmit/receive word numbers should be executed in one transfer.<br>00 = Only one transmit/receive word will be executed in one transfer.<br>01 = Two successive transmit/receive word will be executed in one transfer.<br>10 = Reserved.<br>11 = Reserved.                                                                          |
| [7:3] | <b>TX_BIT_LEN</b> | <b>Transmit Bit Length</b><br>This field specifies how many bits are transmitted in one transmit/receive. Up to 32 bits can be transmitted.<br>TX_BIT_LEN = 0x01 ... 1 bit<br>TX_BIT_LEN = 0x02 ... 2 bits<br>.....<br>TX_BIT_LEN = 0x1f ... 31 bits<br>TX_BIT_LEN = 0x00 ... 32 bits                                                                                                                        |
| [2]   | <b>TX_NEG</b>     | <b>Transmit At Negative Edge</b><br>0 = The transmitted data output signal is changed at the rising edge of SCLK.<br>1 = The transmitted data output signal is changed at the falling edge of SCLK.                                                                                                                                                                                                          |
| [1]   | <b>RX_NEG</b>     | <b>Receive At Negative Edge</b><br>0 = The received data input signal is latched at the rising edge of SCLK.<br>1 = The received data input signal is latched at the falling edge of SCLK.                                                                                                                                                                                                                   |
| [0]   | <b>GO_BUSY</b>    | <b>Go and Busy Status</b><br>0 = Writing 0 to this bit has no effect.<br>1 = Writing 1 to this bit starts the transfer. This bit remains set during the transfer and is automatically cleared after transfer finished.<br><b>NOTE:</b> All registers should be set before writing 1 to this GO_BUSY bit. When a transfer is in progress, writing to any register of the SPI master/slave core has no effect. |

**SPI Divider Register (DIVIDER)**

| Register | Offset         | R/W | Description                          | Reset Value |
|----------|----------------|-----|--------------------------------------|-------------|
| DIVIDER  | SPI0_BA + 0x04 | R/W | Clock Divider Register (Master Only) | 0x0000_0000 |

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

Table 5-85 SPI Clock Divider Register (DIVIDER, address 0x4003\_0004)

| Bits    | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>DIVIDER2</b><br><b>Clock Divider 2 Register</b> (master only)<br>The value in this field is the 2 <sup>nd</sup> frequency divider of the system clock, PCLK, to generate the serial clock on the output SCLK. The desired frequency is obtained according to the following equation:<br>$f_{sclk} = \frac{f_{pclk}}{(DIVIDER2 + 1) * 2}$                                                                                                                                                                                                |
| [15:0]  | <b>DIVIDER</b><br><b>Clock Divider Register</b> (master only)<br>The value in this field is the frequency division of the system clock, PCLK, to generate the serial clock on the output SCLK. The desired frequency is obtained according to the following equation:<br>$f_{sclk} = \frac{f_{pclk}}{(DIVIDER + 1) * 2}$<br>In slave mode, the period of SPI clock driven by a master shall satisfy<br>$f_{sclk} \leq \frac{f_{pclk}}{5}$<br>In other words, the maximum frequency of SCLK clock is one fifth of the SPI peripheral clock. |

SPI Slave Select Register (SSR)

| Register | Offset         | R/W | Description           | Reset Value |
|----------|----------------|-----|-----------------------|-------------|
| SSR      | SPI0_BA + 0x08 | R/W | Slave Select Register | 0x0000_0000 |

|          |   |            |          |     |        |          |   |
|----------|---|------------|----------|-----|--------|----------|---|
| 7        | 6 | 5          | 4        | 3   | 2      | 1        | 0 |
| Reserved |   | LTRIG_FLAG | SS_LTRIG | ASS | SS_LVL | SSR[1:0] |   |

Table 5-86 SPI Slave Select Register (SSR, address 0x4003\_0008)

| Bits   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [5]    | <p><b>Level Trigger Flag</b><br/> When the SS_LTRIG bit is set in slave mode, this bit can be read to indicate the received bit number is met the requirement or not.</p> <p>1: The received number and received bits met the requirement which defines in Tx_NUM and Tx_BIT_LEN among one transfer.</p> <p>0: One of the received number and the received bit length doesn't meet the requirement in one transfer.</p> <p>Note: This bit is READ only</p>                                                                                                                                                                                                |
| [4]    | <p><b>Slave Select Level Trigger (Slave only)</b><br/> 0: The input slave select signal is edge-trigger. This is the default value.<br/> 1: The slave select signal will be level-trigger. It depends on SS_LVL to decide the signal is active low or active high.</p>                                                                                                                                                                                                                                                                                                                                                                                    |
| [3]    | <p><b>Automatic Slave Select (Master only)</b><br/> 0 = If this bit is cleared, slave select signals are asserted and de-asserted by setting and clearing related bits in SSR[1:0] register.<br/> 1 = If this bit is set, SPISSx0/1 signals are generated automatically. It means that device/slave select signal, which is set in SSR[1:0] register is asserted by the SPI controller when transmit/receive is started by setting GO_BUSY, and is de-asserted after each transmit/receive is finished.</p>                                                                                                                                               |
| [2]    | <p><b>Slave Select Active Level</b><br/> It defines the active level of device/slave select signal (SPISSx0/1).<br/> 0 = The slave select signal SPISSx0/1 is active at low-level/falling-edge.<br/> 1 = The slave select signal SPISSx0/1 is active at high-level/rising-edge.</p>                                                                                                                                                                                                                                                                                                                                                                       |
| [1:0]  | <p><b>Slave Select Register (Master only)</b><br/> If ASS bit is cleared, writing 1 to any bit location of this field sets the proper SPISSx0/1 line to an active state and writing 0 sets the line back to inactive state.</p> <p>If ASS bit is set, writing 1 to any bit location of this field will select appropriate SPISSx0/1 line to be automatically driven to active state for the duration of the transmit/receive, and will be driven to inactive state for the rest of the time. (The active level of SPISSx0/1 is specified in SS_LVL).</p> <p><b>Note:</b> SPISSx0 is always defined as device/slave select input signal in slave mode.</p> |

**SPI Data Receive Register (RX)**

| Register | Offset         | R/W | Description             | Reset Value |
|----------|----------------|-----|-------------------------|-------------|
| RX[0]    | SPI0_BA + 0x10 | R   | Data Receive Register 0 | 0x0000_0000 |
| RX[1]    | SPI0_BA + 0x14 | R   | Data Receive Register 1 | 0x0000_0000 |

Table 5-87 SPI Data Receive Register (RX[0]/RX[1], address 0x4003\_0010/0x4003\_0014)

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:0] | RX           | <p><b>Data Receive Register</b></p> <p>The Data Receive Registers hold the value of received data of the last executed transfer. Valid bits depend on the transmit bit length field in the SPI_CNTRL register. For example, if Tx_BIT_LEN is set to 0x08 and Tx_NUM is set to 0x0, bit Rx0[7:0] holds the received data.</p> <p><b>NOTE:</b> The Data Receive Registers are read only registers.</p> |  |  |

**SPI Data Transmit Register (TX)**

| Register | Offset         | R/W | Description              | Reset Value |
|----------|----------------|-----|--------------------------|-------------|
| TX[0]    | SPI0_BA + 0x20 | W   | Data Transmit Register 0 | 0x0000_0000 |
| TX[1]    | SPI0_BA + 0x24 | W   | Data Transmit Register 1 | 0x0000_0000 |

Table 5-88 SPI Data Transmit Register (TX[0]/TX[1], address 0x4003\_0020/0x4003\_0024)

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:0] | Tx           | <p><b>Data Transmit Register</b></p> <p>The Data Transmit Registers hold the data to be transmitted in the next transfer. Valid bits depend on the transmit bit length field in the CNTRL register. For example, if Tx_BIT_LEN is set to 0x08 and the Tx_NUM is set to 0x0, the bit Tx0[7:0] will be transmitted in next transfer. If Tx_BIT_LEN is set to 0x00 and Tx_NUM is set to 0x1, the core will perform two 32-bit transmit/receive successive using the same setting (the order is Tx0[31:0], Tx1[31:0]).</p> |  |  |

**SPI Variable Clock Pattern Flag Register (VARCLK)**

| Register | Offset       | R/W | Description                     | Reset Value |
|----------|--------------|-----|---------------------------------|-------------|
| VARCLK   | SPIx_BA+0x34 | R/W | Variable Clock Pattern Register | 0x007F_FF87 |

Table 5-89 SPI Variable Clock Pattern Register (VARCLK, address 0x4003\_0034)

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | VARCLK       | <p><b>Variable Clock Pattern</b></p> <p>The value in this field is the frequency pattern of the SPI clock. If the bit field of VARCLK is '0', the output frequency of SCLK is given by the value of DIVIDER. If the bit field of VARCLK is '1', the output frequency of SCLK is given by the value of DIVIDER2. Refer to register DIVIDER.</p> <p>Refer to <a href="#">Variable Serial Clock Frequency</a> paragraph for detailed description.</p> <p>Note: Used for CLKP = 0 only, 16 bit transmission.</p> |

**DMA Control Register (DMA)**

| Register | Offset         | R/W | Description                   | Reset Value |
|----------|----------------|-----|-------------------------------|-------------|
| DMA      | SPI0_BA + 0x38 | R/W | SPI DMA Mode Control Register | 0x0000_0000 |

|          |   |   |   |   |   |           |           |
|----------|---|---|---|---|---|-----------|-----------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1         | 0         |
| Reserved |   |   |   |   |   | Rx_DMA_GO | Tx_DMA_GO |

Table 5-90 SPI DMA Control Register (DMA, address 0x4003\_0038)

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                                                |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]  | Rx_DMA_GO    | <p><b>Receive DMA Start</b></p> <p>Set this bit to 1 will start the receive DMA process. SPI module will issue request to DMA module automatically.</p>                                                                                                                                                                                        |
| [0]  | Tx_DMA_GO    | <p><b>Transmit DMA Start</b></p> <p>Set this bit to 1 will start the transmit DMA process. SPI module will issue request to DMA module automatically.</p> <p>If using DMA mode to transfer data, remember not to set GO_BUSY bit of SPI_CNTRL register. The DMA controller inside SPI module will set it automatically whenever necessary.</p> |

## 5.10 Timer Controller

### 5.10.1 General Timer Controller

The ISD9160 provides two general 24bit timer modules, TIMER0 and TIMER1. They allow the user to implement event counting or provide timing control for applications. The timer can perform functions such as frequency measurement, event counting, interval measurement, clock generation and delay timing. The timer can generates an interrupt signal upon timeout and provide the current value of count during operation.

### 5.10.2 Features

- Independent clock source for each channel (TMR0\_CLK, TMR1\_CLK).
- Time out period = (Period of timer clock input) \* (8-bit prescale + 1) \* (24-bit TCMP)
- Maximum count cycle time =  $(1 / \text{TMR\_CLK}) * (2^8) * (2^{24})$ .
- Internal 24-bit up counter is readable through TDR (Timer Data Register).

### 5.10.3 Timer Controller Block Diagram

Each channel is equipped with an 8-bit pre-scale counter, a 24-bit up-counter, a 24-bit compare register and an interrupt request signal. Refer to Figure 5-49 for the timer controller block diagram. There are five options of clock source for each channel, Figure 5-50 illustrate the clock source control function.



Figure 5-49 Timer Controller Block Diagram



Figure 5-50 Clock Source of Timer Controller

#### 5.10.4 Timer Controller Register Map

R: read only, W: write only, R/W: both read and write

| Register                     | Offset     | R/W | Description                        | Reset Value | Reference                  |
|------------------------------|------------|-----|------------------------------------|-------------|----------------------------|
| <b>TMR0_BA = 0x4001_0000</b> |            |     |                                    |             |                            |
| <b>TMR1_BA = 0x4001_0020</b> |            |     |                                    |             |                            |
| TCSR                         | TMRx_BA+00 | R/W | Timer0 Control and Status Register | 0x0000_0005 | <a href="#">Table 5-91</a> |
| TCMPR                        | TMRx_BA+04 | R/W | Timer0 Compare Register            | 0x0000_0000 | <a href="#">Table 5-92</a> |
| TISR                         | TMRx_BA+08 | R/W | Timer0 Interrupt Status Register   | 0x0000_0000 | <a href="#">Table 5-93</a> |
| TDR                          | TMRx_BA+0C | R   | Timer0 Data Register               | 0x0000_0000 | <a href="#">Table 5-94</a> |

Timer Control Register (TCSR)

| Register | Offset      | R/W | Description                       |  |  |  | Reset Value |
|----------|-------------|-----|-----------------------------------|--|--|--|-------------|
| TCSR     | TMRx_BA+000 | R/W | Timer Control and Status Register |  |  |  | 0x0000_0005 |

|               |     |    |           |    |      |      |          |
|---------------|-----|----|-----------|----|------|------|----------|
| 31            | 30  | 29 | 28        | 27 | 26   | 25   | 24       |
| Reserved      | CEN | IE | MODE[1:0] |    | CRST | CACT | Reserved |
| 23            | 22  | 21 | 20        | 19 | 18   | 17   | 16       |
| Reserved      |     |    |           |    |      |      | TDR_EN   |
| 15            | 14  | 13 | 12        | 11 | 10   | 9    | 8        |
| Reserved      |     |    |           |    |      |      |          |
| 7             | 6   | 5  | 4         | 3  | 2    | 1    | 0        |
| PRESCALE[7:0] |     |    |           |    |      |      |          |

Table 5-91 Timer Control and Status Register (TCSR, address 0x4001\_0000 + x \*0x20).

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                             |
| [30] | CEN          | <p><b>Counter Enable Bit</b><br/>           0 = Stops/Suspends counting<br/>           1 = Starts counting</p> <p><b>Note1:</b> Setting CEN=1 enables 24-bit counter. It continues count from last value.</p> <p><b>Note2:</b> This bit is auto-cleared by hardware in one-shot mode (MODE =00b) when the timer interrupt is generated (IE =1b).</p> |
| [29] | IE           | <p><b>Interrupt Enable Bit</b><br/>           0 = Disable TIMER Interrupt.<br/>           1 = Enable TIMER Interrupt.</p> <p>If timer interrupt is enabled, the timer asserts its interrupt signal when the count is equal to TCMR.</p>                                                                                                              |

| [28:27]     | <b>MODE</b>                                                                                                                                                                                            | <b>Timer Operating Mode</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------------------------------------------|----|-----------|
|             |                                                                                                                                                                                                        | <table border="1"> <thead> <tr> <th><b>MODE</b></th><th><b>Timer Operating Mode</b></th></tr> </thead> <tbody> <tr> <td>00</td><td>The timer is operating in the one-shot mode. The associated interrupt signal is generated once (if IE is enabled) and CEN is automatically cleared by hardware.</td></tr> <tr> <td>01</td><td>The timer is operating in the periodic mode. The associated interrupt signal is generated periodically (if IE is enabled).</td></tr> <tr> <td>10</td><td>Reserved.</td></tr> <tr> <td>11</td><td>The timer is operating in continuous counting mode. The associated interrupt signal is generated when TDR = TCMR (if IE is enabled); however, the 24-bit up-counter counts continuously without reset.</td></tr> </tbody> </table> | <b>MODE</b> | <b>Timer Operating Mode</b> | 00 | The timer is operating in the one-shot mode. The associated interrupt signal is generated once (if IE is enabled) and CEN is automatically cleared by hardware. | 01 | The timer is operating in the periodic mode. The associated interrupt signal is generated periodically (if IE is enabled). | 10 | Reserved. |
| <b>MODE</b> | <b>Timer Operating Mode</b>                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| 00          | The timer is operating in the one-shot mode. The associated interrupt signal is generated once (if IE is enabled) and CEN is automatically cleared by hardware.                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| 01          | The timer is operating in the periodic mode. The associated interrupt signal is generated periodically (if IE is enabled).                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| 10          | Reserved.                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| 11          | The timer is operating in continuous counting mode. The associated interrupt signal is generated when TDR = TCMR (if IE is enabled); however, the 24-bit up-counter counts continuously without reset. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
|             |                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
|             |                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| [26]        | <b>CRST</b>                                                                                                                                                                                            | <p><b>Counter Reset Bit</b><br/> Set this bit will reset the timer counter, prescale and also force CEN to 0.<br/> 0 = No effect.<br/> 1 = Reset Timer's prescale counter, internal 24-bit up-counter and CEN bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| [25]        | <b>CACT</b>                                                                                                                                                                                            | <p><b>Timer Active Status Bit (Read only)</b><br/> This bit indicates the counter status of timer.<br/> 0 = Timer is <b>not</b> active.<br/> 1 = Timer is active.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| [24:17]     | Reserved                                                                                                                                                                                               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| [16]        | <b>TDR_EN</b>                                                                                                                                                                                          | <p><b>Data Latch Enable</b><br/> When TDR_EN is set, TDR (Timer Data Register) will be updated continuously with the 24-bit up-counter value as the timer is counting.<br/> 1 = <b>Timer Data Register</b> update enable.<br/> 0 = <b>Timer Data Register</b> update disable.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| [15:8]      | Reserved                                                                                                                                                                                               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |
| [7:0]       | <b>PRESCALE</b>                                                                                                                                                                                        | <p><b>Pre-scale Counter</b><br/> Clock input is divided by PRESCALE+1 before it is fed to the counter. If PRESCALE =0, then there is no scaling.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                             |    |                                                                                                                                                                 |    |                                                                                                                            |    |           |

Timer Compare Register (TCMPR)

| Register | Offset      | R/W | Description            |  |  |  | Reset Value |
|----------|-------------|-----|------------------------|--|--|--|-------------|
| TCMPR    | TMRx_BA+004 | R/W | Timer Compare Register |  |  |  | 0x0000_0000 |

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

Table 5-92 Timer Compare Register (TCMPR, address 0x4001\_0004 + x \* 0x20)

| Bits   | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [24:0] | <p><b>TCMP</b></p> <p><b>Timer Comparison Value</b></p> <p>TCMP is a 24-bit comparison register. When the 24-bit up-counter is enabled and its value is equal to TCMP value, a Timer Interrupt is requested if the timer interrupt is enabled with TCSR.IE=1. The TCMP value defines the timer cycle time.</p> <p>Time out period = (Period of timer clock input) * (8-bit PRESCALE + 1) * (24-bit TCMP)</p> <p><b>NOTE1:</b> Never set TCMP to 0x000 or 0x001. Timer will not function correctly.</p> <p><b>NOTE2:</b> Regardless of CEN state, whenever a new value is written to this register, TIMER will restart counting using this new value and abort previous count.</p> |

Timer Interrupt Status Register (TISR)

| Register | Offset     | R/W | Description                     | Reset Value |
|----------|------------|-----|---------------------------------|-------------|
| TISR     | TMRx_BA+08 | R/W | Timer Interrupt Status Register | 0x0000_0000 |

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

Table 5-93 Timer Interrupt Status Register (TISR, address 0x4001\_0008 + x \* 0x20)

| Bits   | Descriptions |                                                                                                                                                                                                               |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved     | Reserved                                                                                                                                                                                                      |
| [0]    | <b>TIF</b>   | <b>Timer Interrupt Flag</b><br>This bit indicates the interrupt status of Timer.<br>TIF bit is set by hardware when the 24-bit counter matches the timer comparison value (TCMP). It is cleared by writing 1. |

Timer Data Register (TDR)

| Register | Offset     | R/W | Description         |  |  |  | Reset Value |
|----------|------------|-----|---------------------|--|--|--|-------------|
| TDR      | TMRx_BA+0C | R/W | Timer Data Register |  |  |  | 0x0000_0000 |

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

Table 5-94 Timer Data Register (TDR, address 0x4001\_000C + x \*0x20).

| Bits    | Descriptions |                                                                                                                                                                                        |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved     | Reserved                                                                                                                                                                               |
| [23:0]  | TDR          | <b>Timer Data Register</b><br>When TCSR.TDR_EN is set to 1, the internal 24-bit timer up-counter value will be latched into TDR. User can read this register for the up-counter value. |

## 5.11 Watchdog Timer

The purpose of Watchdog Timer is to perform a system reset if software is not responding as designed. This prevents system from hanging for an infinite period of time. The watchdog timer includes a 18-bit free running counter with programmable time-out intervals.

Setting WTE enables the watchdog timer and the WDT counter starts counting up. When the counter reaches the selected time-out interval, Watchdog timer interrupt flag WTIF will be set immediately to request a WDT interrupt if the watchdog timer interrupt enable bit WTIE is set, in the meantime, a specified delay time follows the time-out event. User must set WTR (Watchdog timer reset) high to reset the 18-bit WDT counter to prevent Watchdog timer reset before the delay time expires. WTR bit is auto cleared by hardware after WDT counter is reset. There are eight time-out intervals with specific delay time which are selected by Watchdog timer interval select bits WTIS. If the WDT counter has not been cleared after the specific delay time expires, the watchdog timer will set Watchdog Timer Reset Flag (WTRF) high and reset CPU. This reset will last 64 WDT clocks then CPU restarts executing program from reset vector (0x0000 0000). WTRF will not be cleared by Watchdog reset. User may poll WTRF by software to recognize the reset source.

Table 5-95 Watchdog Timeout Interval Selection

| WTIS | Interrupt Timeout | Watchdog Reset Timeout    | WTR Timeout Interval (WDT_CLK=49.152 MHz) | WTR Timeout Interval (WDT_CLK=32kHz) |
|------|-------------------|---------------------------|-------------------------------------------|--------------------------------------|
| 000  | $2^4$ WDT_CLK     | $(2^4 + 1024)$ WDT_CLK    | 21.2 us                                   | 31.7 ms                              |
| 001  | $2^6$ WDT_CLK     | $(2^6 + 1024)$ WDT_CLK    | 22.1 us                                   | 33.2 ms                              |
| 010  | $2^8$ WDT_CLK     | $(2^8 + 1024)$ WDT_CLK    | 26.0 us                                   | 39 ms                                |
| 011  | $2^{10}$ WDT_CLK  | $(2^{10} + 1024)$ WDT_CLK | 41.7 us                                   | 64 ms                                |
| 100  | $2^{12}$ WDT_CLK  | $(2^{12} + 1024)$ WDT_CLK | 104.2 us                                  | 160 ms                               |
| 101  | $2^{14}$ WDT_CLK  | $(2^{14} + 1024)$ WDT_CLK | 354.2 us                                  | 544 ms                               |
| 110  | $2^{16}$ WDT_CLK  | $(2^{16} + 1024)$ WDT_CLK | 1.4 ms                                    | 2080 ms                              |
| 111  | $2^{18}$ WDT_CLK  | $(2^{18} + 1024)$ WDT_CLK | 5.4 ms                                    | 8224 ms                              |



Figure 5-51 Watchdog Timer Clock Control



Figure 5-52 Watchdog Timer Block Diagram

### 5.11.1 Watchdog Timer Control Registers Map

R: read only, W: write only, R/W: both read and write

| Register                    | Offset    | R/W | Description                     | Reset Value |
|-----------------------------|-----------|-----|---------------------------------|-------------|
| <b>WDT_BA = 0x4000_4000</b> |           |     |                                 |             |
| WTCR                        | WDT_BA+00 | R/W | Watchdog Timer Control Register | 0x0000_0700 |

#### Watchdog Timer Control Register (WTCR)

This is a protected register, to write to register, first issue the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#)). Only flag bits, WTIF and WTRF are unprotected and can be write-cleared at any time.

| Register | Offset     | R/W | Description                     | Reset Value |
|----------|------------|-----|---------------------------------|-------------|
| WTCR     | WDT_BA+000 | R/W | Watchdog Timer Control Register | 0x0000_0700 |

|          |      |          |    |      |      |      |     |
|----------|------|----------|----|------|------|------|-----|
| 31       | 30   | 29       | 28 | 27   | 26   | 25   | 24  |
| Reserved |      |          |    |      |      |      |     |
| 23       | 22   | 21       | 20 | 19   | 18   | 17   | 16  |
| Reserved |      |          |    |      |      |      |     |
| 15       | 14   | 13       | 12 | 11   | 10   | 9    | 8   |
| Reserved |      |          |    |      | WTIS |      |     |
| 7        | 6    | 5        | 4  | 3    | 2    | 1    | 0   |
| WTE      | WTIE | Reserved |    | WTIF | WTRF | WTRE | WTR |

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [10:8]  | WTIS         | <p><b>Watchdog Timer Interval Select</b></p> <p>These three bits select the timeout interval for the Watchdog timer, a watchdog reset will occur 1024 clock cycles later if WDG not reset. The timeout is given by:</p> $\text{Interrupt Timeout} = 2^{(2 \times \text{WTIS} + 4)} \times \text{WDT\_CLK}$ $\text{Reset Timeout} = (2^{(2 \times \text{WTIS} + 4)} + 1024) \times \text{WDT\_CLK}$ <p>Where WDT_CLK is the period of the Watchdog Timer clock source.</p> |
| [7]     | WTE          | <p><b>Watchdog Timer Enable</b></p> <p>0 : Disable the Watchdog timer (This action will reset the internal counter)<br/>1: Enable the Watchdog timer</p>                                                                                                                                                                                                                                                                                                                  |

|     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>WTIE</b> | <b>Watchdog Timer Interrupt Enable</b><br>0 : Disable the Watchdog timer interrupt<br>1 : Enable the Watchdog timer interrupt                                                                                                                                                                                                                                                                                                                                                 |
| [3] | <b>WTIF</b> | <b>Watchdog Timer Interrupt Flag</b><br>If the Watchdog timer interrupt is enabled, then the hardware will set this bit to indicate that the Watchdog timer interrupt has occurred. If the Watchdog timer interrupt is not enabled, then this bit indicates that a timeout period has elapsed.<br>0 : Watchdog timer interrupt does not occur<br>1 : Watchdog timer interrupt occurs<br><b>NOTE:</b> This bit is cleared by writing 1 to this bit.                            |
| [2] | <b>WTRF</b> | <b>Watchdog Timer Reset Flag</b><br>When the Watchdog timer initiates a reset, the hardware will set this bit. This flag can be read by software to determine the source of reset. Software is responsible to clear it manually by writing 1 to it. If <b>WTRE</b> is disabled, then the Watchdog timer has no effect on this bit.<br>0 : Watchdog timer reset does not occur<br>1: Watchdog timer reset occurs<br><b>NOTE:</b> This bit is cleared by writing 1 to this bit. |
| [1] | <b>WTRE</b> | <b>Watchdog Timer Reset Enable</b><br>Setting this bit will enable the Watchdog timer reset function.<br>0 : Disable Watchdog timer reset function<br>1: Enable Watchdog timer reset function                                                                                                                                                                                                                                                                                 |
| [0] | <b>WTR</b>  | <b>Clear Watchdog Timer</b><br>Set this bit will clear the Watchdog timer.<br>0 : Writing 0 to this bit has no effect<br>1 : Reset the contents of the Watchdog timer<br><b>NOTE:</b> This bit will auto clear after few clock cycle                                                                                                                                                                                                                                          |

## 5.12 UART Interface Controller

The ISD9160 includes a Universal Asynchronous Receiver/Transmitter (UART). The UART supports high speed operation and flow control functions as well as protocols for Serial Infrared (IrDA) and Local interconnect Network (LIN).

### 5.12.1 Overview

The Universal Asynchronous Receiver/Transmitter (UART) performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the CPU. The UART controller also supports LIN (Local Interconnect Network) master mode function and IrDA SIR (Serial Infrared) function. The UART channel supports seven types of interrupts including transmitter FIFO empty interrupt (THRE\_INT), receiver threshold level interrupt (RDA\_INT), line status interrupt (overrun error or parity error or framing error or break interrupt) (RLS\_INT), time out interrupt (TOUT\_INT), MODEM status interrupt (MODEM\_INT), Buffer error interrupt (BUF\_ERR\_INT) and LIN receiver break field detected interrupt.

The UART has a 8-byte transmit FIFO (TX\_FIFO) and a 8-byte receive FIFO (RX\_FIFO) that reduces the number of interrupts presented to the CPU. The CPU can read the status of the UART at any time during the operation. The reported status information includes the type and condition of the transfer operations being performed by the UART, as well as 4 error conditions (parity error, overrun error, framing error and break interrupt) that can occur while receiving data. The UART includes a programmable baud rate generator that is capable of dividing master clock input by divisors to produce the baud rate clock. The baud rate equation is  $\text{Baud Rate} = \text{UART\_CLK} / M * [\text{BRD} + 2]$ , where M and BRD are defined in Baud Rate Divider Register (UART0->BAUD). [Table 5-96](#) lists the equations under various conditions.

The UART controller supports auto-flow control function that uses two active-low signals, /CTS (clear-to-send) and /RTS (request-to-send), to control the flow of data transfer between the UART and external devices (e.g. Modem). When auto-flow is enabled, the UART will not receive data until the UART asserts /RTS to external device. When the number of bytes in the Rx FIFO equals the value of  $\text{UART0->FCR.RTS\_TRIG\_LEVEL}$ , the /RTS is de-asserted. The UART sends data out when UART controller detects /CTS is asserted from external device. If /CTS is not detected the UART controller will not send data out.

The UART controller also provides Serial IrDA (SIR, Serial Infrared) function (UART0->FUNSEL. IrDA\_EN =1 to enable IrDA function). The SIR specification defines a short-range infrared asynchronous serial transmission mode with one start bit, 8 data bits, and 1 stop bit. The maximum data rate is 115.2 Kbps (half duplex). The IrDA SIR block contains an IrDA SIR Protocol encoder/decoder. The IrDA SIR protocol is half-duplex only. So it cannot transmit and receive data at the same time. The IrDA SIR physical layer specifies a minimum 10ms transfer delay between transmission and reception. This delay must be implemented by software.

The alternate function of UART controller is LIN (Local Interconnect Network) function. The LIN mode is selected by setting the  $\text{UART0->FUNSEL.LIN\_EN}$  bit. In LIN mode, one start bit, 8-bit data format with 1-bit stop bit are generated in accordance with the LIN standard.

Table 5-96 UART Baud Rate Equation

| Mode | DIVX_EN | DIVX_ONE | DIVX[3:0]  | BRD[15:0] | Baud rate equation                |
|------|---------|----------|------------|-----------|-----------------------------------|
| 0    | 0       | 0        | B          | A         | UART_CLK / [16 * (A+2)]           |
| 1    | 1       | 0        | B          | A         | UART_CLK / [(B+1) * (A+2)], B ≥ 8 |
| 2    | 1       | 1        | Don't care | A         | UART_CLK / (A+2), A ≥ 3           |

Table 5-97 UART Baud Rate Setting Table

| System clock = 49.152MHz |       |      |                          |            |         |      |
|--------------------------|-------|------|--------------------------|------------|---------|------|
| Baud rate                | Mode0 | %err | Mode1                    | %err       | Mode2   | %err |
| 921600                   | x     |      | A=4,B=8                  | 1.2        | A=51    | -0.6 |
| 460800                   | x     |      | A=10,B=8                 | 1.2        | A=104   | 0.3  |
| 230400                   | x     |      | A=22,B=8<br>A=7,B=11     | 1.2<br>1.2 | A=211   | -0.2 |
| 115200                   | A=25  | 1.2  | A=37,B=10<br>A=31,B=12   | 0.5<br>0.5 | A=425   | 0.1  |
| 57600                    | A=51  | -0.6 | A=59,B=13<br>A=93,B=8    | 0.1<br>0.2 | A=851   | 0.0  |
| 38400                    | A=78  | 0.0  | A=126,B=9<br>A=78,B=15   | 0.0<br>0.0 | A=1278  | 0.0  |
| 19200                    | A=158 | 0.0  | A=254,B=9<br>A=158,B=15  | 0.0<br>0.0 | A=2558  | 0.0  |
| 9600                     | A=318 | 0.0  | A=510,B=9<br>A=318,B=15  | 0.0<br>0.0 | A=5118  | 0.0  |
| 4800                     | A=638 | 0.0  | A=1022,B=9<br>A=638,B=15 | 0.0<br>0.0 | A=10238 | 0.0  |

### 5.12.2 Features of UART controller

- UART supports 8 byte FIFO for receive and transmit data payloads.
- PDMA access support.
- Auto flow control function (/CTS, /RTS) supported.
- Programmable baud-rate generator.
- Fully programmable serial-interface characteristics:
  - 5-, 6-, 7-, or 8-bit character.
  - Even, odd, or no-parity bit generation and detection.
  - 1-, 1&1/2, or 2-stop bit generation.
  - Baud rate generation.
  - False start bit detection.
- IrDA SIR Function.
- LIN master mode.

### 5.12.3 Block Diagram

The UART clock control and block diagram are shown as following.



Figure 5-53 UART Clock Control Diagram



Figure 5-54 UART Block Diagram

**TX\_FIFO**

The transmitter is buffered with an 8 byte FIFO to reduce the number of interrupts presented to the CPU.

**RX\_FIFO**

The receiver is buffered with an 8 byte FIFO (plus three error bits per byte) to reduce the number of interrupts presented to the CPU.

**TX shift Register**

Shifts the transmit data out serially

**RX shift Register**

Shifts the receive data in serially

**Modem Control Register**

This register controls the interface to the MODEM or data set (or a peripheral device emulating a MODEM).

**Baud Rate Generator**

Divides the UART0\_CLK clock by the divisor to get the desired baud rate clock. Refer to [Table 5-96](#) for the baud rate equation.

**Control and Status Register**

This is a register set, including the FIFO control registers (FCR), FIFO status registers (FSR), and line control register (LCR) for transmitter and receiver. The time out control register (TOR) identifies the condition of time out interrupt. This register set also includes the interrupt enable register (IER) and interrupt status register (ISR) to enable or disable the responding interrupt and to identify the occurrence of the responding interrupt. There are six types of interrupts, transmitter FIFO empty interrupt(THRE\_INT), receiver threshold level reaching interrupt (RDA\_INT), line status interrupt (overrun error or parity error or framing error or break interrupt) (RLS\_INT) , time out interrupt (TOUT\_INT), MODEM status interrupt (MODEM\_INT) and Buffer error interrupt (BUF\_ERR\_INT).

Figure 5-55 demonstrates the auto-flow control block diagram.



Figure 5-55 Auto Flow Control Block Diagram

#### 5.12.4 IrDA Mode

The UART supports IrDA SIR (Serial Infrared) Transmit Encoder and Receive Decoder. IrDA mode is selected by setting the UART0->FUNSEL.IrDA\_EN bit.

When in IrDA mode, the UART0->BAUD.DIVX\_EN register must be zero and baud rate is given by:

Baud Rate =  $\text{UART\_CLK} / (16 * \text{BRD})$ , where BRD is Baud Rate Divider in the UART0->BAUD.BRD register.



Figure 5-56 IrDA Block Diagram

##### 5.12.4.1 IrDA SIR Transmit Encoder

The IrDA SIR Transmit Encoder modulates Non-Return-to Zero (NRZ) transmission bit stream from UART serial output. The IrDA SIR physical layer specifies use of Return-to-Zero, Inverted (RZI) modulation scheme which represents logic 0 as an infrared light pulse. The modulated output pulse stream is transmitted to an external output driver and infrared LED (Light Emitting Diode). In normal mode, the transmitted pulse width is specified as 3/16 the period of the baud rate.

##### 5.12.4.2 IrDA SIR Receive Decoder

The IrDA SIR Receive Decoder demodulates the return-to-zero bit stream from the input detector and outputs the NRZ serial bit stream to the UART received data input. The IR\_SIN decoder input is normally high in the idle state. Because of this, IRCR.RX\_INV\_EN should be set 1 by default). A start bit is detected when the IR\_SIN decoder input is LOW.

##### 5.12.4.3 IrDA SIR Operation

The IrDA SIR Encoder/decoder provides functionality which converts between UART data stream and half duplex serial SIR interface. Figure 5-57 shows the IrDA encoder/decoder waveform:



Figure 5-57 IrDA Tx/Rx Timing Diagram

### 5.12.5 LIN (Local Interconnection Network) mode

The UART supports a Local Interconnection Network (LIN) function. LIN mode is selected by setting the UART0->FUNSEL.LIN\_EN bit. In LIN mode, each byte field is initiated by a start bit with value zero (dominant), followed by 8 data bits (LSB is first) and ended by 1 stop bit with value one (recessive) in accordance with the LIN standard (<http://www.lin-subbus.org/> ).



Figure 5-58 Structure of LIN Frame

The program flow of LIN Bus Transmit transfer (Tx) is shown as following

1. Set the UART0->FUNSEL.LIN\_EN bit to enable LIN Bus mode.
2. Set UART0->LINCON.LINBCNT to choose break field length. The break field length is LINBCNT+2.
3. Fill 0x55 to UART0->DATA to request synch field transmission.
4. Request Identifier Field transmission by writing the protected identifier value to UART0->DATA
5. Set the UART0->LINCON.LINTX\_EN bit to start transmission (When break filed operation is finished, LINTX\_EN will be cleared automatically).
6. When the STOP bit of the last byte UART0->DATA has been sent to bus, hardware will set flag UART0->FSR.TE to 1.
7. Fill N bytes data and Checksum to UART0->DATA then repeat step 5 and 6 to transmit the data.

The program flow of LIN Bus Receiver transfer (Rx) is show as following

1. Set the UART0->FUNSEL.LIN\_EN bit to enable LIN Bus mode.
2. Set the UART0->LINCON.LINRX\_EN bit register to enable LIN Rx mode.
3. Wait for the flag UART0->ISR.LIN\_Rx\_Break\_IF to indicate Rx received Break field or not.
4. Wait for the flag UART0->ISR.RDA\_IF read back the UART0->DATA register.

### 5.12.6 UART Interface Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                      | Offset          | R/W | Description                      | Reset Value | Reference                   |
|-------------------------------|-----------------|-----|----------------------------------|-------------|-----------------------------|
| <b>UART0_BA = 0x4005_0000</b> |                 |     |                                  |             |                             |
| DATA                          | UART0_BA + 0x00 | R   | UART0 Receive FIFO Register.     | Undefined   | <a href="#">Table 5-98</a>  |
| DATA                          | UART0_BA + 0x00 | W   | UART0 Transmit FIFO Register.    | Undefined   | <a href="#">Table 5-99</a>  |
| IER                           | UART0_BA + 0x04 | R/W | UART0 Interrupt Enable Register. | 0x0000_0000 | <a href="#">Table 5-100</a> |
| FCR                           | UART0_BA + 0x08 | R/W | UART0 FIFO Control Register.     | 0x0000_0000 | <a href="#">Table 5-101</a> |
| LCR                           | UART0_BA + 0x0C | R/W | UART0 Line Control Register.     | 0x0000_0000 | <a href="#">Table 5-102</a> |
| MCR                           | UART0_BA + 0x10 | R/W | UART0 Modem Control Register.    | 0x0000_0000 | <a href="#">Table 5-103</a> |
| MSR                           | UART0_BA + 0x14 | R/W | UART0 Modem Status Register.     | 0x0000_0000 | <a href="#">Table 5-104</a> |
| FSR                           | UART0_BA + 0x18 | R/W | UART0 FIFO Status Register.      | 0x1040_4000 | <a href="#">Table 5-105</a> |
| ISR                           | UART0_BA + 0x1C | R/W | UART0 Interrupt Status Register. | 0x0000_0002 | <a href="#">Table 5-106</a> |
| TOR                           | UART0_BA + 0x20 | R/W | UART0 Time Out Register          | 0x0000_0000 | <a href="#">Table 5-109</a> |
| BAUD                          | UART0_BA + 0x24 | R/W | UART0 Baud Rate Divisor Register | 0x0F00_0000 | <a href="#">Table 5-110</a> |
| IRCR                          | UART0_BA + 0x28 | R/W | UART0 IrDA Control Register.     | 0x0000_0040 | <a href="#">Table 5-112</a> |
| LINCON                        | UART0_BA + 0x2C | R/W | UART0 LIN Control Register.      | 0x0000_0000 | <a href="#">Table 5-113</a> |
| FUNSEL                        | UART0_BA + 0x30 | R/W | UART0 Function Select Register.  | 0x0000_0000 | <a href="#">Table 5-114</a> |

### 5.12.7 UART Interface Control Register Description

#### Receive FIFO Data Register (DATA)

| Register | Offset          | R/W | Description                  |  |  |  | Reset Value |
|----------|-----------------|-----|------------------------------|--|--|--|-------------|
| DATA     | UART0_BA + 0x00 | R   | UART0 Receive FIFO Register. |  |  |  | Undefined   |

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

Table 5-98 UART Receive FIFO Data Register (DATA, address 0x4005\_0000)

| Bits  | Descriptions        |                                                                                                                                                                                                    |
|-------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | 8-bit Received Data | <b>Receive FIFO Register</b><br>Reading this register will return data from the receive data FIFO. By reading this register, the UART will return the 8-bit data received from Rx pin (LSB first). |

Transmit FIFO Data Register (DATA)

| Register | Offset          | R/W | Description                        | Reset Value |
|----------|-----------------|-----|------------------------------------|-------------|
| DATA     | UART0_BA + 0x00 | W   | UART0 Transmit FIFO Data Register. | Undefined   |

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

Table 5-99 UART Transmit FIFO Data Register (DATA, address 0x4005\_0000)

| Bits  | Descriptions        |                                                                                                                                                                                                         |
|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | 8-bit Transmit Data | <p><b>Transmit FIFO Data Register</b></p> <p>By writing to this register, transmit data will be pushed onto the transmit FIFO. The UART will send out an 8-bit data through the Tx pin (LSB first).</p> |

Interrupt Enable Register (IER)

| Register | Offset          | R/W | Description                      |  |  |  | Reset Value |
|----------|-----------------|-----|----------------------------------|--|--|--|-------------|
| IER      | UART0_BA + 0x04 | R/W | UART0 Interrupt Enable Register. |  |  |  | 0x0000_0000 |

|           |           |             |             |        |          |          |                |
|-----------|-----------|-------------|-------------|--------|----------|----------|----------------|
| 31        | 30        | 29          | 28          | 27     | 26       | 25       | 24             |
| Reserved  |           |             |             |        |          |          |                |
| 23        | 22        | 21          | 20          | 19     | 18       | 17       | 16             |
| Reserved  |           |             |             |        |          |          |                |
| 15        | 14        | 13          | 12          | 11     | 10       | 9        | 8              |
| DMA_RX_EN | DMA_TX_EN | AUTO_CTS_EN | AUTO_RTS_EN | TOC_EN | Reserved |          | LIN_RX_BRK_IEN |
| 7         | 6         | 5           | 4           | 3      | 2        | 1        | 0              |
| Reserved  |           | BUF_ERR_IEN | RTO_IEN     | MS_IEN | RLS_IEN  | THRE_IEN | RDA_IEN        |

Table 5-100 UART Interrupt Enable Register (IER, address 0x4005\_0004)

| Bits    | Descriptions   |                                                                                                                                                                                                                                                          |
|---------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved       | Reserved                                                                                                                                                                                                                                                 |
| [15]    | DMA_RX_EN      | <b>Receive DMA Enable</b><br>If enabled, the UART will request DMA service when data is available in receive FIFO.                                                                                                                                       |
| [14]    | DMA_TX_EN      | <b>Transmit DMA Enable</b><br>If enabled, the UART will request DMA service when space is available in transmit FIFO.                                                                                                                                    |
| [13]    | AUTO_CTS_EN    | <b>CTS Auto Flow Control Enable</b><br>1 = Enable, 0 = Disable CTS auto flow control.<br>When CTS auto-flow is enabled, the UART will send data to external device when CTS input is asserted (UART will not send data to device until CTS is asserted). |
| [12]    | AUTO_RTS_EN    | <b>RTS Auto Flow Control Enable</b><br>1 = Enable, 0 = Disable RTS auto flow control.<br>When RTS auto-flow is enabled, if the number of bytes in the Rx FIFO equals FCR.RTS_TRIG_LEVEL, the UART will de-assert the RTS signal.                         |
| [11]    | TOC_EN         | <b>Time-Out Counter Enable</b><br>1 = Enable, 0 = Disable Time-out counter.                                                                                                                                                                              |
| [10:9]  | Reserved       | Reserved                                                                                                                                                                                                                                                 |
| [8]     | LIN_RX_BRK_IEN | <b>LIN RX Break Field Detected Interrupt Enable</b><br>0 = Mask off Lin bus Rx break field interrupt.<br>1 = Enable Lin bus Rx break field interrupt.                                                                                                    |

|       |                    |                                                                                                      |
|-------|--------------------|------------------------------------------------------------------------------------------------------|
| [7:6] | Reserved           | Reserved                                                                                             |
| [5]   | <b>BUF_ERR_IEN</b> | <b>Buffer Error Interrupt Enable</b><br>0 = Mask off BUF_ERR_INT<br>1 = Enable IBUF_ERR_INT          |
| [4]   | <b>RTO_IEN</b>     | <b>Receive Time out Interrupt Enable</b><br>0 = Mask off TOUT_INT<br>1 = Enable TOUT_INT             |
| [3]   | <b>MS_IEN</b>      | <b>Modem Status Interrupt Enable</b><br>0 = Mask off MODEM_INT<br>1 = Enable MODEM_INT               |
| [2]   | <b>RLS_IEN</b>     | <b>Receive Line Status Interrupt Enable</b><br>0 = Mask off RLS_INT<br>1 = Enable RLS_INT            |
| [1]   | <b>THRE_IEN</b>    | <b>Transmit FIFO Register Empty Interrupt Enable</b><br>0 = Mask off THRE_INT<br>1 = Enable THRE_INT |
| [0]   | <b>RDA_IEN</b>     | <b>Receive Data Available Interrupt Enable.</b><br>0 = Mask off RDA_INT<br>1 = Enable RDA_INT        |

FIFO Control Register (FCR)

| Register | Offset          | R/W | Description                  | Reset Value |
|----------|-----------------|-----|------------------------------|-------------|
| FCR      | UART0_BA + 0x08 | R/W | UART0 FIFO Control Register. | 0x0000_0000 |

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

Table 5-101 UART FIFO Control Register (FCR, address 0x4005\_0008)

| Bits        | Descriptions                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
|-------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------------|------|---|------|---|------|---|
| [31:20]     | Reserved                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |                                |      |   |      |   |      |   |
| [19:16]     | RTS_TRIGGER_LEVEL              | <p><b>RTS Trigger Level for Auto-flow Control</b><br/>Sets the FIFO trigger level when auto-flow control will de-assert RTS (request-to-send).</p> <table border="1"> <thead> <tr> <th>RTS_Tri_Lev</th> <th>Trigger Level (Bytes)</th> </tr> </thead> <tbody> <tr> <td>0000</td> <td>1</td> </tr> <tr> <td>0001</td> <td>4</td> </tr> <tr> <td>0010</td> <td>8</td> </tr> </tbody> </table>                                                                  | RTS_Tri_Lev | Trigger Level (Bytes)          | 0000 | 1 | 0001 | 4 | 0010 | 8 |
| RTS_Tri_Lev | Trigger Level (Bytes)          |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| 0000        | 1                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| 0001        | 4                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| 0010        | 8                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| [7:4]       | RFITL                          | <p><b>Receive FIFO Interrupt (RDA_INT) Trigger Level</b><br/>When the number of bytes in the receive FIFO equals the RFITL then the RDA_IF will be set and, if enabled, an RDA_INT interrupt will generated.</p> <table border="1"> <thead> <tr> <th>RFITL</th> <th>INTR_RDA Trigger Level (Bytes)</th> </tr> </thead> <tbody> <tr> <td>0000</td> <td>1</td> </tr> <tr> <td>0001</td> <td>4</td> </tr> <tr> <td>0010</td> <td>8</td> </tr> </tbody> </table> | RFITL       | INTR_RDA Trigger Level (Bytes) | 0000 | 1 | 0001 | 4 | 0010 | 8 |
| RFITL       | INTR_RDA Trigger Level (Bytes) |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| 0000        | 1                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| 0001        | 4                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| 0010        | 8                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                                |      |   |      |   |      |   |
| [3]         | Reserved                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |                                |      |   |      |   |      |   |

|     |          |                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | TFR      | <p><b>Transmit FIFO Reset</b></p> <p>When TFR is set, all the bytes in the transmit FIFO are cleared and transmit internal state machine is reset.</p> <p>0 = Writing 0 to this bit has no effect.</p> <p>1 = Writing 1 to this bit will reset the transmit internal state machine and pointers.</p> <p><b>Note:</b> This bit will auto-clear after 3 UART engine clock cycles.</p> |
| [1] | RFR      | <p><b>Receive FIFO Reset</b></p> <p>When RFR is set, all the bytes in the receive FIFO are cleared and receive internal state machine is reset.</p> <p>0 = Writing 0 to this bit has no effect.</p> <p>1 = Writing 1 to this bit will reset the receive internal state machine and pointers.</p> <p><b>Note:</b> This bit will auto-clear after 3 UART engine clock cycles.</p>     |
| [0] | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                            |

Line Control Register (LCR)

| Register | Offset          | R/W | Description                  |  |  |  | Reset Value |
|----------|-----------------|-----|------------------------------|--|--|--|-------------|
| LCR      | UART0_BA + 0x0C | R/W | UART0 Line Control Register. |  |  |  | 0x0000_0000 |

| 7        | 6   | 5   | 4   | 3   | 2   | 1   | 0 |
|----------|-----|-----|-----|-----|-----|-----|---|
| Reserved | BCB | SPE | EPE | PBE | NSB | WLS |   |

Table 5-102 UART Line Control Register (LCR, address 0x4005\_000C)

| Bits     | Descriptions     |                                                                                                                                                                                                                                                                                     |          |                  |    |        |    |        |    |        |    |        |
|----------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------|----|--------|----|--------|----|--------|----|--------|
| [31:7]   | Reserved         | Reserved                                                                                                                                                                                                                                                                            |          |                  |    |        |    |        |    |        |    |        |
| [6]      | <b>BCB</b>       | <b>Break Control Bit</b><br>When this bit is set to logic 1, the serial data output (Tx) is forced to the 'Space' state (logic 0). Normal condition is serial data output is 'Mark' state. This bit acts only on Tx and has no effect on the transmitter logic.                     |          |                  |    |        |    |        |    |        |    |        |
| [5]      | <b>SPE</b>       | <b>Stick Parity Enable</b><br>0 = Disable stick parity<br>1 = When bits PBE and SPE are set 'Stick Parity' is enabled. If EPE=0 the parity bit is transmitted and checked as always set, if EPE=1, the parity bit is transmitted and checked as always cleared.                     |          |                  |    |        |    |        |    |        |    |        |
| [4]      | <b>EPE</b>       | <b>Even Parity Enable</b><br>0 = Odd number of logic 1's are transmitted or checked in the data word and parity bits.<br>1 = Even number of logic 1's are transmitted or checked in the data word and parity bits.<br>This bit has effect only when PBE (parity bit enable) is set. |          |                  |    |        |    |        |    |        |    |        |
| [3]      | <b>PBE</b>       | <b>Parity Bit Enable</b><br>0 = Parity bit is not generated (transmit data) or checked (receive data) during transfer.<br>1 = Parity bit is generated or checked between the "last data word bit" and "stop bit" of the serial data.                                                |          |                  |    |        |    |        |    |        |    |        |
| [2]      | <b>NSB</b>       | <b>Number of STOP bits</b><br>0= One "STOP bit" is generated after the transmitted data<br>1= Two "STOP bits" are generated when 6-, 7- and 8-bit word length is selected; One and a half "STOP bits" are generated in the transmitted data when 5-bit word length is selected;     |          |                  |    |        |    |        |    |        |    |        |
| [1:0]    | <b>WLS</b>       | <b>Word Length Select</b> <table border="1"> <tr> <th>WLS[1:0]</th> <th>Character length</th> </tr> <tr> <td>00</td> <td>5 bits</td> </tr> <tr> <td>01</td> <td>6 bits</td> </tr> <tr> <td>10</td> <td>7 bits</td> </tr> <tr> <td>11</td> <td>8 bits</td> </tr> </table>            | WLS[1:0] | Character length | 00 | 5 bits | 01 | 6 bits | 10 | 7 bits | 11 | 8 bits |
| WLS[1:0] | Character length |                                                                                                                                                                                                                                                                                     |          |                  |    |        |    |        |    |        |    |        |
| 00       | 5 bits           |                                                                                                                                                                                                                                                                                     |          |                  |    |        |    |        |    |        |    |        |
| 01       | 6 bits           |                                                                                                                                                                                                                                                                                     |          |                  |    |        |    |        |    |        |    |        |
| 10       | 7 bits           |                                                                                                                                                                                                                                                                                     |          |                  |    |        |    |        |    |        |    |        |
| 11       | 8 bits           |                                                                                                                                                                                                                                                                                     |          |                  |    |        |    |        |    |        |    |        |

MODEM Control Register (MCR)

| Register | Offset          | R/W | Description                   | Reset Value |
|----------|-----------------|-----|-------------------------------|-------------|
| MCR      | UART0_BA + 0x10 | R/W | UART0 Modem Control Register. | 0x0000_0000 |

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

Table 5-103 UART Modem Control Register (MCR, address 0x4005\_0010)

| Bits    | Descriptions |                                                                                                                                                                                           |
|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved     | Reserved                                                                                                                                                                                  |
| [13]    | RTS_ST       | <b>RTS Pin State (read only)</b><br>This bit is the pin status of RTS.                                                                                                                    |
| [12:10] | Reserved     | Reserved                                                                                                                                                                                  |
| [9]     | RTS_ACT      | <b>Request-to-Send (RTS) Active Trigger Level</b><br>This bit can change the RTS trigger level.<br>0= RTS is active low level.<br>1= RTS is active high level                             |
| [8:5]   | Reserved     | Reserved                                                                                                                                                                                  |
| [4]     | LBME         | Loopback Mode Enable.                                                                                                                                                                     |
| [3:2]   | Reserved     | Reserved                                                                                                                                                                                  |
| [1]     | RTS_SET      | <b>RTS (Request-To-Send) Signal</b><br>If IER.AUTO_RTS_EN=0, this bit controls whether RTS pin is active or not.<br>0: Drive RTS inactive (=~RTS_ACT).<br>1: Drive RTS active (=RTS_ACT). |

Modem Status Register (MSR)

| Register | Offset          | R/W | Description                  |  |  |  | Reset Value |
|----------|-----------------|-----|------------------------------|--|--|--|-------------|
| MSR      | UART0_BA + 0x14 | R/W | UART0 Modem Status Register. |  |  |  | 0x0000_0000 |

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

Table 5-104 UART Modem Status Register (MSR, address 0x4005\_0014)

| Bits   | Descriptions   |                                                                                                                                                                                                                   |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved       | Reserved                                                                                                                                                                                                          |
| [8]    | <b>CTS_ACT</b> | <b>Clear-to-Send (CTS) Active Trigger Level</b><br>This bit can change the CTS trigger level.<br>0= CTS is active low level.<br>1= CTS is active high level                                                       |
| [7:5]  | Reserved       | Reserved                                                                                                                                                                                                          |
| [4]    | <b>CTS_ST</b>  | <b>CTS Pin Status (read only)</b><br>This bit is the pin status of CTS.                                                                                                                                           |
| [3:1]  | Reserved       | Reserved                                                                                                                                                                                                          |
| [0]    | <b>DCTSF</b>   | <b>Detect CTS State Change Flag</b><br>This bit is set whenever CTS input has state change. It will generate Modem interrupt to CPU when IER.MS_IEN=1<br><b>NOTE:</b> This bit is cleared by writing 1 to itself. |

**FIFO Status Register (FSR)**

| Register | Offset          | R/W | Description                 |  |  |  | Reset Value |
|----------|-----------------|-----|-----------------------------|--|--|--|-------------|
| FSR      | UART0_BA + 0x18 | R/W | UART0 FIFO Status Register. |  |  |  | 0x1040_4000 |

|          |          |            |     |          |    |    |           |
|----------|----------|------------|-----|----------|----|----|-----------|
| 31       | 30       | 29         | 28  | 27       | 26 | 25 | 24        |
| Reserved |          |            | TE  | Reserved |    |    | TX_OVF_IF |
| 23       | 22       | 21         | 20  | 19       | 18 | 17 | 16        |
| TX_FULL  | TX_EMPTY | TX_POINTER |     |          |    |    |           |
| 15       | 14       | 13         | 12  | 11       | 10 | 9  | 8         |
| RX_FULL  | RX_EMPTY | RX_POINTER |     |          |    |    |           |
| 7        | 6        | 5          | 4   | 3        | 2  | 1  | 0         |
| Reserved | BIF      | FEF        | PEF | Reserved |    |    | RX_OVF_IF |

Table 5-105 UART FIFO Status Register (FSR, address 0x4005\_0018)

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                |
|---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                       |
| [28]    | TE           | <p><b>Transmitter Empty (Read Only)</b></p> <p>Bit is set by hardware when Tx FIFO is empty and the STOP bit of the last byte has been transmitted.</p> <p>Bit is cleared automatically when Tx FIFO is not empty or the last byte transmission has not completed.</p> <p>NOTE: This bit is read only.</p>                     |
| [27:25] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                       |
| [24]    | TX_OVF_IF    | <p><b>Tx Overflow Error Interrupt Flag</b></p> <p>If the Tx FIFO (UART0-&gt;DATA) is full, an additional write to UART0-&gt;DATA will cause an overflow condition and set this bit to logic 1. It will also generate a BUF_ERR_IF event and interrupt if enabled.</p> <p>NOTE: This bit is cleared by writing 1 to itself.</p> |
| [23]    | TX_FULL      | <p><b>Transmit FIFO Full (Read Only)</b></p> <p>This bit indicates whether the Tx FIFO is full or not.</p> <p>This bit is set when Tx FIFO is full; otherwise it is cleared by hardware. TX_FULL=0 indicates there is room to write more data to Tx FIFO.</p>                                                                  |
| [22]    | TX_EMPTY     | <p><b>Transmit FIFO Empty (Read Only)</b></p> <p>This bit indicates whether the Tx FIFO is empty or not.</p> <p>When the last byte of Tx FIFO has been transferred to Transmitter Shift Register, hardware sets this bit high. It will be cleared after writing data to FIFO (Tx FIFO not empty).</p>                          |

|         |                   |                                                                                                                                                                                                                                                                                                                            |
|---------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [21:16] | <b>TX_POINTER</b> | <b>Tx FIFO Pointer (Read Only)</b><br>This field returns the Tx FIFO buffer pointer. When CPU writes a byte into the Tx FIFO, TX_POINTER is incremented. When a byte from Tx FIFO is transferred to the Transmit Shift Register, TX_POINTER is decremented.                                                                |
| [15]    | <b>RX_FULL</b>    | <b>Receive FIFO Full (Read Only)</b><br>This bit indicates whether the Rx FIFO is full or not.<br>This bit is set when Rx FIFO is full; otherwise it is cleared by hardware.                                                                                                                                               |
| [14]    | <b>RX_EMPTY</b>   | <b>Receive FIFO Empty (Read Only)</b><br>This bit indicates whether the Rx FIFO is empty or not.<br>When the last byte of Rx FIFO has been read by CPU, hardware sets this bit high. It will be cleared when UART receives any new data.                                                                                   |
| [13:8]  | <b>RX_POINTER</b> | <b>Rx FIFO pointer (Read Only)</b><br>This field returns the Rx FIFO buffer pointer. It is the number of bytes available for read in the Rx FIFO. When UART receives one byte from external device, RX_POINTER is incremented. When one byte of Rx FIFO is read by CPU, RX_POINTER is decremented.                         |
| [7]     | Reserved          | Reserved                                                                                                                                                                                                                                                                                                                   |
| [6]     | <b>BIF</b>        | <b>Break Interrupt Flag</b><br>This bit is set to a logic 1 whenever the receive data input (Rx) is held in the "space" state (logic 0) for longer than a full word transmission time (that is, the total time of start bit + data bits + parity + stop bits). It is reset whenever the CPU writes 1 to this bit.          |
| [5]     | <b>FEF</b>        | <b>Framing Error Flag</b><br>This bit is set to logic 1 whenever the received character does not have a valid "stop bit" (that is, the stop bit following the last data bit or parity bit is detected as a logic 0), and is reset whenever the CPU writes 1 to this bit.                                                   |
| [4]     | <b>PEF</b>        | <b>Parity Error Flag</b><br>This bit is set to logic 1 whenever the received character does not have a valid "parity bit", and is reset whenever the CPU writes 1 to this bit.                                                                                                                                             |
| [3:1]   | Reserved          | Reserved                                                                                                                                                                                                                                                                                                                   |
| [0]     | <b>RX_OVF_IF</b>  | <b>Rx Overflow Error Interrupt Flag</b><br>If the Rx FIFO (UART0->DATA) is full, and an additional byte is received by the UART, an overflow condition will occur and set this bit to logic 1. It will also generate a BUF_ERR_IF event and interrupt if enabled.<br><br>NOTE: This bit is cleared by writing 1 to itself. |

Interrupt Status Register (ISR)

| Register | Offset          | R/W | Description                      |  |  |  | Reset Value |
|----------|-----------------|-----|----------------------------------|--|--|--|-------------|
| ISR      | UART0_BA + 0x1C | R/W | UART0 Interrupt Status Register. |  |  |  | 0x0000_0002 |

| 31                   | 30       | 29               | 28            | 27             | 26          | 25       | 24      |
|----------------------|----------|------------------|---------------|----------------|-------------|----------|---------|
| DMA_LIN_Rx_Break_INT | Reserved | DMA_BUF_ER_R_INT | DMA_TOUT_I NT | DMA_MODEM _INT | DMA_RLS_INT | Reserved |         |
| 23                   | 22       | 21               | 20            | 19             | 18          | 17       | 16      |
| DMA_LIN_Rx_Break_IF  | Reserved | DMA_BUF_ERR_IF   | DMA_TOUT_IF   | DMA_MODEM _IF  | DMA_RLS_IF  | Reserved |         |
| 15                   | 14       | 13               | 12            | 11             | 10          | 9        | 8       |
| LIN_Rx_Break_INT     | Reserved | BUF_ERR_INT      | TOUT_INT      | MODEM_INT      | RLS_INT     | THRE_INT | RDA_INT |
| 7                    | 6        | 5                | 4             | 3              | 2           | 1        | 0       |
| LIN_Rx_Break_IF      | Reserved | BUF_ERR_IF       | TOUT_IF       | MODEM_IF       | RLS_IF      | THRE_IF  | RDA_IF  |

Table 5-106 UART Interrupt Status Register (ISR, address 0x4005\_001C)

| Bits    | Descriptions     |                                                                                                                                                                                                                                                       |
|---------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | DMA mode Bits    | DMA mode equivalent following interrupt indicators and flags. See Table 5-107 and normal mode descriptions below.<br>In DMA mode (either DMA transmit or receive requests are active) these bits are generated rather than the normal use bits below. |
| [15]    | LIN_Rx_Break_INT | <b>LIN Bus Rx Break Field Detected Interrupt Indicator to Interrupt Controller</b><br>Logical AND of IER.LIN_RX_BRK_IEN and LIN_Rx_Break_IF                                                                                                           |
| [14]    | Reserved         | Reserved                                                                                                                                                                                                                                              |
| [13]    | BUF_ERR_INT      | <b>Buffer Error Interrupt Indicator to Interrupt Controller</b><br>Logical AND of IER.BUF_ERR_IEN and BUF_ERR_IF                                                                                                                                      |
| [12]    | TOUT_INT         | <b>Time Out Interrupt Indicator to Interrupt Controller</b><br>Logical AND of IER.RTO_IEN and TOUT_IF                                                                                                                                                 |
| [11]    | MODEM_INT        | <b>MODEM Status Interrupt Indicator to Interrupt</b><br>Logical AND of IER.MS_IEN and MODEM_IF                                                                                                                                                        |
| [10]    | RLS_INT          | <b>Receive Line Status Interrupt Indicator to Interrupt Controller</b><br>Logical AND of IER.RLS_IEN and RLS_IF                                                                                                                                       |
| [9]     | THRE_INT         | <b>Transmit Holding Register Empty Interrupt Indicator to Interrupt Controller</b><br>Logical AND of IER.THRE_IEN and THRE_IF                                                                                                                         |

|     |                        |                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8] | <b>RDA_INT</b>         | <b>Receive Data Available Interrupt Indicator to Interrupt Controller</b><br>Logical AND of IER.RDA_IEN and RDA_IF                                                                                                                                                                                                                                                                   |
| [7] | <b>LIN_Rx_Break_IF</b> | <b>LIN Bus Rx Break Field Detected Flag</b><br>This bit is set when LIN controller detects a break field. This bit is cleared by writing a 1.                                                                                                                                                                                                                                        |
| [6] | Reserved               | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
| [5] | <b>BUF_ERR_IF</b>      | <b>Buffer Error Interrupt Flag (Read Only)</b><br>This bit is set when either the Tx or Rx FIFO overflows (FSR.TX_OVF_IF or FSR.RX_OVF_IF is set). When BUF_ERR_IF is set, the serial transfer may be corrupted. If IER.BUF_ERR_IEN is enabled a CPU interrupt request will be generated.<br><b>NOTE:</b> This bit is cleared when both FSR.TX_OVF_IF and FSR.RX_OVF_IF are cleared. |
| [4] | <b>TOUT_IF</b>         | <b>Time Out Interrupt Flag (Read Only)</b><br>This bit is set when the Rx FIFO is not empty and no activity occurs in the Rx FIFO and the time out counter equal to TOIC. If IER.TOUT_IEN is enabled a CPU interrupt request will be generated.<br><b>NOTE:</b> This bit is read only and user can read FIFO to clear it.                                                            |
| [3] | <b>MODEM_IF</b>        | <b>MODEM Interrupt Flag (Read Only)</b><br>This bit is set when the CTS pin has changed state (MSR.DCTS=1). If IER.MS_IEN is enabled, a CPU interrupt request will be generated.<br><b>NOTE:</b> This bit is read only and reset when bit MSR.DCTS is cleared by a write 1.                                                                                                          |
| [2] | <b>RLS_IF</b>          | <b>Receive Line Status Interrupt Flag (Read Only).</b><br>This bit is set when the Rx receive data has a parity, framing or break error (at least one of, FSR.BIF, FSR.FEF and FSR.PEF, is set). If IER.RLS_IEN is enabled, the RLS interrupt will be generated.<br><b>NOTE:</b> This bit is read only and reset to 0 when all bits of BIF, FEF and PEF are cleared.                 |
| [1] | <b>THRE_IF</b>         | <b>Transmit Holding Register Empty Interrupt Flag (Read Only).</b><br>This bit is set when the last data of Tx FIFO is transferred to Transmitter Shift Register. If IER.THRE_IEN is enabled, the THRE interrupt will be generated.<br><b>NOTE:</b> This bit is read only and it will be cleared when writing data into the Tx FIFO.                                                 |
| [0] | <b>RDA_IF</b>          | <b>Receive Data Available Interrupt Flag (Read Only).</b><br>When the number of bytes in the Rx FIFO equals FCR.RFITL then the RDA_IF will be set. If IER.RDA_IEN is enabled, the RDA interrupt will be generated.<br><b>NOTE:</b> This bit is read only and it will be cleared when the number of unread bytes of Rx FIFO drops below the threshold level (RFITL).                  |

When the DMA controller is used to transmit or receive data to the UART, an alternate set of flags and interrupt indicators are generated. These are equivalent to the normal mode set above and are summarized in Table 5-107.

Table 5-107 UART Interrupt Sources and Flags Table In DMA Mode

| UART Interrupt Source                                 | Interrupt Enable Bit | Interrupt Indicator to Interrupt Controller | Interrupt Flag                                   | Flag Cleared by                  |
|-------------------------------------------------------|----------------------|---------------------------------------------|--------------------------------------------------|----------------------------------|
| LIN RX Break Field Detected interrupt                 | LIN_RX_BRK_IEN       | DMA_LIN_Rx_Break_INT                        | <b>DMA_LIN_Rx_Break_IF</b>                       | Write '1' to LIN_Rx_Break_IF     |
| Buffer Error Interrupt<br>BUF_ERR_INT                 | BUF_ERR_IEN          | DMA_BUF_ERR_INT                             | <b>DMA_BUF_ERR_IF = (TX_OVF_IF or RX_OVF_IF)</b> | Write '1' to TX_OVF_IF/RX_OVF_IF |
| Rx Timeout Interrupt<br>TOUT_INT                      | RTO_IEN              | DMA_TOUT_INT                                | <b>DMA_TOUT_IF</b>                               | Read data FIFO                   |
| Modem Status Interrupt<br>MODEM_INT                   | MS_IEN               | DMA_MODEM_INT                               | <b>DMA_MODEM_IF = (DCTS/DSR)</b>                 | Write '1' to DCTS/DSR            |
| Receive Line Status Interrupt<br>RLS_INT              | RLS_IEN              | DMA_RLS_INT                                 | <b>DMA_RLS_IF = (BIF or FEF or PEF)</b>          | Write '1' to BIF/FEF/PEF         |
| Transmit Holding Register Empty Interrupt<br>THRE_INT | THRE_IEN             | DMA_THRE_INT                                | <b>DMA_THRE_IF</b>                               | Write data FIFO                  |
| Receive Data Available Interrupt<br>RDA_INT           | RDA_IEN              | DMA_RDA_INT                                 | <b>DMA_RDA_IF</b>                                | Read data FIFO                   |

Table 5-108 UART Interrupt Sources and Flags Table In Software Mode

| UART Interrupt Source                                 | Interrupt Enable Bit | Interrupt Indicator to Interrupt Controller | Interrupt Flag                               | Flag Cleared by                  |
|-------------------------------------------------------|----------------------|---------------------------------------------|----------------------------------------------|----------------------------------|
| LIN RX Break Field Detected interrupt                 | LIN_RX_BRK_IEN       | LIN_Rx_Break_INT                            | <b>LIN_Rx_Break_IF</b>                       | Write '1' to LIN_Rx_Break_IF     |
| Buffer Error Interrupt<br>BUF_ERR_INT                 | BUF_ERR_IEN          | BUF_ERR_INT                                 | <b>BUF_ERR_IF = (TX_OVF_IF or RX_OVF_IF)</b> | Write '1' to TX_OVF_IF/RX_OVF_IF |
| Rx Timeout Interrupt<br>TOUT_INT                      | RTO_IEN              | TOUT_INT                                    | <b>TOUT_IF</b>                               | Read data FIFO                   |
| Modem Status Interrupt<br>MODEM_INT                   | MS_IEN               | MODEM_INT                                   | <b>MODEM_IF = (DCTSIF)</b>                   | Write '1' to DCTSIF              |
| Receive Line Status Interrupt<br>RLS_INT              | RLS_IEN              | RLS_INT                                     | <b>RLS_IF = (BIF or FEF or PEF)</b>          | Write '1' to BIF/FEF/PEF         |
| Transmit Holding Register Empty Interrupt<br>THRE_INT | THRE_IEN             | THRE_INT                                    | <b>THRE_IF</b>                               | Write data FIFO                  |
| Receive Data Available Interrupt<br>RDA_INT           | RDA_IEN              | RDA_INT                                     | <b>RDA_IF</b>                                | Read data FIFO                   |

Time Out Register (TOR)

| Register | Offset          | R/W | Description             |  |  |  | Reset Value |
|----------|-----------------|-----|-------------------------|--|--|--|-------------|
| TOR      | UART0_BA + 0x20 | R/W | UART0 Time Out Register |  |  |  | 0x0000_0000 |

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

Table 5-109 UART Time Out Register (TOR, address 0x4005\_0020)

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [6:0]  | TOIC         | <p><b>Time Out Interrupt Comparator</b></p> <p>The time out counter resets and starts counting whenever the Rx FIFO receives a new data word. Once the content of time out counter (TOUT_CNT) is equal to that of time out interrupt comparator (TOIC), a receiver time out interrupt (TOUT_INT) is generated if IER.RTO_IEN is set. A new incoming data word or RX FIFO empty clears TOUT_IF. The period of the time out counter is the baud rate.</p> |

**Baud Rate Divider Register (BAUD)**

| Register | Offset          | R/W | Description                      | Reset Value |
|----------|-----------------|-----|----------------------------------|-------------|
| BAUD     | UART0_BA + 0x24 | R/W | UART0 Baud Rate Divisor Register | 0x0F00_0000 |

The baud rate generator takes the UART master clock UART\_CLK and divides it to produce the baud rate (bit rate) clock. The divider has two division stages controlled by BRD and DIVX fields. These are configured in three modes depending on the selections of DIVX\_EN and DIVX\_ONE. These modes and the baud rate equations for them are described in Table 5-111.

|           |    |         |          |      |    |    |    |
|-----------|----|---------|----------|------|----|----|----|
| 31        | 30 | 29      | 28       | 27   | 26 | 25 | 24 |
| Reserved  |    | DIVX_EN | DIVX_ONE | DIVX |    |    |    |
| 23        | 22 | 21      | 20       | 19   | 18 | 17 | 16 |
| Reserved  |    |         |          |      |    |    |    |
| 15        | 14 | 13      | 12       | 11   | 10 | 9  | 8  |
| BRD[15:0] |    |         |          |      |    |    |    |
| 7         | 6  | 5       | 4        | 3    | 2  | 1  | 0  |
| BRD[7:0]  |    |         |          |      |    |    |    |

Table 5-110 UART Baud Rate Divider Register (BAUD, address 0x4005\_0024)

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                             |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                    |
| [29]    | DIVX_EN      | <b>Divider X Enable</b><br>The baud rate equation is:<br><b>Baud Rate = UART_CLK / [ M * (BRD + 2) ]</b> ; The default value of M is 16.<br>0 = Disable divider X (M = 16)<br>1 = Enable divider X (M = DIVX+1, with DIVX ≥ 8).<br>Refer to Table 5-111 for more information.<br><b>NOTE:</b> When in IrDA mode, this bit must be disabled. |
| [28]    | DIVX_ONE     | <b>Divider X equal 1</b><br>0: M = DIVX+1, with restriction DIVX ≥ 8.<br>1: M = 1, with restriction BRD[15:0] ≥ 3.<br>Refer to Table 5-111 for more information.                                                                                                                                                                            |
| [27:24] | DIVX         | <b>Divider X</b><br>The baud rate divider M = DIVX+1.                                                                                                                                                                                                                                                                                       |
| [23:16] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                    |
| [15:0]  | BRD          | <b>Baud Rate Divider.</b> Refer to Table 5-111 for more information.                                                                                                                                                                                                                                                                        |

Table 5-111 Baud Rate Equations.

| Mode | DIVX_EN | DIVX_ONE | DIVX[3:0]  | BRD[15:0] | Baud rate equation                          |
|------|---------|----------|------------|-----------|---------------------------------------------|
| 0    | 0       | 0        | B          | A         | UART_CLK / [16 * (A+2)]                     |
| 1    | 1       | 0        | B          | A         | UART_CLK / [(B+1) * (A+2)] , requires B ≥ 8 |
| 2    | 1       | 1        | Don't care | A         | UART_CLK / (A+2), requires A ≥ 3            |

IrDA Control Register (IRCR)

| Register | Offset          | R/W | Description                  |  |  |  | Reset Value |
|----------|-----------------|-----|------------------------------|--|--|--|-------------|
| IRCR     | UART0_BA + 0x28 | R/W | UART0 IrDA Control Register. |  |  |  | 0x0000_0040 |

|          |           |           |          |          |          |           |          |
|----------|-----------|-----------|----------|----------|----------|-----------|----------|
| 7        | 6         | 5         | 4        | 3        | 2        | 1         | 0        |
| Reserved | RX_INV_EN | TX_INV_EN | Reserved | Reserved | LOOPBACK | TX_SELECT | Reserved |

Table 5-112 UART IrDA Control Register (IRCR, address 0x4005\_0028)

| Bits   | Descriptions |                                                                                            |
|--------|--------------|--------------------------------------------------------------------------------------------|
| [31:7] | Reserved     | Reserved                                                                                   |
| [6]    | RX_INV_EN    | <b>Receive Inversion Enable</b><br>1= Invert Rx input signal<br>0= No inversion            |
| [5]    | TX_INV_EN    | <b>Transmit inversion enable</b><br>1= Invert Tx output signal<br>0= No inversion          |
| [4:3]  | Reserved     | Reserved                                                                                   |
| [2]    | LOOPBACK     | IrDA Loopback test mode. Loopback Tx to Rx.                                                |
| [1]    | TX_SELECT    | <b>Transmit/Receive Selection</b><br>1: Enable IrDA transmitter<br>0: Enable IrDA receiver |
| [0]    | Reserved     | Reserved                                                                                   |

UART LIN Network Control Register (LINCON)

| Register | Offset          | R/W | Description                                | Reset Value |
|----------|-----------------|-----|--------------------------------------------|-------------|
| LINCON   | UART0_BA + 0x2C | R/W | UART0 LIN Network Control/Status Register. | 0x0000_0000 |

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

Table 5-113 UART LIN Network Control Register (LINCON, address 0x4005\_002C)

| Bits   | Descriptions |                                                                                                                                                                                                                                         |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved     | Reserved                                                                                                                                                                                                                                |
| [7]    | LIN_TX_EN    | <p><b>LIN TX Break Mode Enable</b><br/>           1 = Enable LIN Tx Break Mode.<br/>           0 = Disable LIN Tx Break Mode.</p> <p>NOTE: When Tx break field transfer operation finished, this bit will be cleared automatically.</p> |
| [6]    | LIN_RX_EN    | <p><b>LIN RX Enable</b><br/>           1 = Enable LIN Rx mode.<br/>           0 = Disable LIN Rx mode.</p>                                                                                                                              |
| [3:0]  | LINBCNT      | <p><b>UART LIN Break Field Length Count</b><br/>           This field indicates a 4-bit LIN Tx break field count.</p> <p>NOTE: This break field length is LINBCNT + 2</p>                                                               |

UART Function Select Register (FUNSEL)

| Register | Offset          | R/W | Description                     |  |  |  | Reset Value |
|----------|-----------------|-----|---------------------------------|--|--|--|-------------|
| FUNSEL   | UART0_BA + 0x30 | R/W | UART0 Function Select Register. |  |  |  | 0x0000_0000 |

|          |    |    |    |    |    |                |               |
|----------|----|----|----|----|----|----------------|---------------|
| 31       | 30 | 29 | 28 | 27 | 26 | 25             | 24            |
| Reserved |    |    |    |    |    |                |               |
| 23       | 22 | 21 | 20 | 19 | 18 | 17             | 16            |
| Reserved |    |    |    |    |    |                |               |
| 15       | 14 | 13 | 12 | 11 | 10 | 9              | 8             |
| Reserved |    |    |    |    |    |                |               |
| 7        | 6  | 5  | 4  | 3  | 2  | 1              | 0             |
| Reserved |    |    |    |    |    | <b>IrDA_EN</b> | <b>LIN_EN</b> |

Table 5-114 UART Function Select Register (FUNSEL, address 0x4005\_0030)

| Bits   | Descriptions   |                                                                                                                                                                                   |
|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved       | Reserved                                                                                                                                                                          |
| [1]    | <b>IrDA_EN</b> | <b>Enable IrDA Function.</b><br>0 = UART Function.<br>1 = Enable IrDA Function.                                                                                                   |
| [0]    | <b>LIN_EN</b>  | <b>Enable LIN Function.</b><br>0 = UART Function.<br>1 = Enable LIN Function.<br><br>Note that IrDA and LIN functions are mutually exclusive: both cannot be active at same time. |

## 5.13 I2S Audio PCM Controller

### 5.13.1 Overview

The I2S controller is a peripheral for serial transmission and reception of audio PCM (Pulse-Code Modulated) signals across a 4-wire bus. The bus consists of a bit clock (I2S\_BCLK) a frame synchronization clock (I2S\_FS) and serial data in (I2S\_SDI) and out (I2S\_SDO) lines. This peripheral allows communication with an external audio CODEC or DSP. The peripheral is capable of mono or stereo audio transmission with 8-32bit word sizes. Audio data is buffered in 8 word deep FIFO buffers and has DMA capability.

### 5.13.2 Features

- I2S can operate as either master or slave
- Master clock generation for slave device synchronization.
- Capable of handling 8, 16, 24 and 32 bit word sizes.
- Mono and stereo audio data supported.
- I2S and MSB justified data format supported.
- 8 word FIFO data buffers for transmit and receive.
- Generates interrupt requests when buffer levels crosses programmable boundary.
- Two DMA requests, one for transmit and one for receive.

### 5.13.3 I2S Block Diagram



Figure 5-59 I2S Clock Control Diagram



Figure 5-60 I2S Controller Block Diagram

#### 5.13.4 I2S Operation



Figure 5-61 I2S Bus Timing Diagram (Format =0)



Figure 5-62 MSB Justified Timing Diagram (Format=1)

### 5.13.5 FIFO operation

|                                           |
|-------------------------------------------|
| Mono 8-bit data mode                      |
| 7 N+3 0 7 N+2 0 7 N+1 0 7 N 0             |
| Stereo 8-bit data mode                    |
| 7 LEFT+1 0 7 RIGHT+1 0 7 LEFT 0 7 RIGHT 0 |
| Mono 16-bit data mode                     |
| 15 N+1 0 15 N 0                           |
| Stereo 16-bit data mode                   |
| 15 LEFT 0 15 RIGHT 0                      |
| Mono 24-bit data mode                     |
| 23 N 0                                    |
| Stereo 24-bit data mode                   |
| 23 LEFT 0 N                               |
| 23 RIGHT 0 N+1                            |
| Mono 32-bit data mode                     |
| 31 N 0                                    |
| Stereo 32-bit data mode                   |
| 31 LEFT 0 N                               |
| 31 RIGHT 0 N+1                            |

Figure 5-63 FIFO contents for various I2S modes

### 5.13.6 I2S Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                    | Offset      | R/W | Description                   | Reset Value | Reference                   |
|-----------------------------|-------------|-----|-------------------------------|-------------|-----------------------------|
| <b>I2S_BA = 0x400A_0000</b> |             |     |                               |             |                             |
| <b>ICON</b>                 | I2S_BA+0x00 | R/W | I2S Control Register          | 0x0000_0000 | <a href="#">Table 5-115</a> |
| <b>CLKDIV</b>               | I2S_BA+0x04 | R/W | I2S Clock Divider Register    | 0x0000_0000 | <a href="#">Table 5-116</a> |
| <b>IE</b>                   | I2S_BA+0x08 | R/W | I2S Interrupt Enable Register | 0x0000_0000 | <a href="#">Table 5-117</a> |
| <b>STATUS</b>               | I2S_BA+0x0C | R/W | I2S Status Register           | 0x0014_1000 | <a href="#">Table 5-118</a> |
| <b>TXFIFO</b>               | I2S_BA+0x10 | W   | I2S Transmit FIFO Register    | 0x0000_0000 | <a href="#">Table 5-119</a> |
| <b>RXFIFO</b>               | I2S_BA+0x14 | R   | I2S Receive FIFO Register     | 0x0000_0000 | <a href="#">Table 5-120</a> |

### 5.13.7 I2S Control Register Description

#### I2S Control Register (CON)

| Register | Offset        | R/W | Description          |  |  |  | Reset Value |
|----------|---------------|-----|----------------------|--|--|--|-------------|
| CON      | I2S_BA + 0x00 | R/W | I2S Control Register |  |  |  | 0x0000_0000 |

|          |           |                |       |            |            |         |         |
|----------|-----------|----------------|-------|------------|------------|---------|---------|
| 31       | 30        | 29             | 28    | 27         | 26         | 25      | 24      |
| Reserved |           |                |       |            |            |         |         |
| 23       | 22        | 21             | 20    | 19         | 18         | 17      | 16      |
| Reserved | Reserved  | RXDMA          | TXDMA | CLR_RXFIFO | CLR_TXFIFO | LCHZCEN | RCHZCEN |
| 15       | 14        | 13             | 12    | 11         | 10         | 9       | 8       |
| MCLKEN   | RXTH[2:0] |                |       | TXTH[2:0]  |            |         | SLAVE   |
| 7        | 6         | 5              | 4     | 3          | 2          | 1       | 0       |
| FORMAT   | MONO      | WORDWIDTH[1:0] |       | MUTE       | RXEN       | TXEN    | I2SEN   |

Table 5-115 I2S Control Register (CON, address 0x400A\_0000)

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                           |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                  |
| [21]    | RXDMA        | <b>Enable Receive DMA</b><br>When RX DMA is enabled, I2S requests DMA to transfer data from receive FIFO to SRAM if FIFO is not empty.<br>1 = Enable RX DMA<br>0 = Disable RX DMA                                                                                                                         |
| [20]    | TXDMA        | <b>Enable Transmit DMA</b><br>When TX DMA is enables, I2S request DMA to transfer data from SRAM to transmit FIFO if FIFO is not full.<br>1 = Enable TX DMA<br>0 = Disable TX DMA                                                                                                                         |
| [19]    | CLR_RXFIFO   | <b>Clear Receive FIFO</b><br>Write 1 to clear receive FIFO, internal pointer is reset to FIFO start point, and RXFIFO_LEVEL[3:0] returns to zero and receive FIFO becomes empty.<br>This bit is cleared by hardware automatically when clear operation complete.                                          |
| [18]    | CLR_TXFIFO   | <b>Clear Transmit FIFO</b><br>Write 1 to clear transmit FIFO, internal pointer is reset to FIFO start point, and TXFIFO_LEVEL[3:0] returns to zero and transmit FIFO becomes empty. Data in transmit FIFO is not changed.<br>This bit is cleared by hardware automatically when clear operation complete. |

|         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]    | <b>LCHZCEN</b>   | <p><b>Left channel zero cross detect enable</b></p> <p>If this bit is set to 1, when left channel data sign bit changes, or data bits are all zero, the LZCF flag in I2S_STATUS register will be set to 1.</p> <p>1 = Enable left channel zero cross detect<br/>0 = Disable left channel zero cross detect</p>                                                                                                                                                                                              |
| [16]    | <b>RCHZCEN</b>   | <p><b>Right channel zero cross detect enable</b></p> <p>If this bit is set to 1, when right channel data sign bit changes, or data bits are all zero, the RZCF flag in I2S_STATUS register will be set to 1.</p> <p>1 = Enable right channel zero cross detect<br/>0 = Disable right channel zero cross detect</p>                                                                                                                                                                                          |
| [15]    | <b>MCLKEN</b>    | <p><b>Master clock enable</b></p> <p>The ISD9160 can generate a master clock signal to an external audio CODEC to synchronize the audio devices. If audio devices are not synchronous, then data will be periodically corrupted. Software needs to implement a way to drop/repeat or interpolate samples in a jitter buffer if devices are not synchronized. The master clock frequency is determined by the CLKDIV.MCLK_DIV[2:0] register.</p> <p>1 = Enable master clock<br/>0 = Disable master clock</p> |
| [14:12] | <b>RXTH[2:0]</b> | <p><b>Receive FIFO threshold level</b></p> <p>When received data word(s) in buffer is equal or higher than threshold level then RXTHI flag is set.</p> <p>Threshold = RXTH+1 words of data in receive FIFO.</p>                                                                                                                                                                                                                                                                                             |
| [11:9]  | <b>TXTH[2:0]</b> | <p><b>Transmit FIFO threshold level</b></p> <p>If remaining data words in transmit FIFO less than or equal to the threshold level then TXTHI flag is set.</p> <p>Threshold = TXTH words remaining in transmit FIFO</p>                                                                                                                                                                                                                                                                                      |
| [8]     | <b>SLAVE</b>     | <p><b>Slave mode</b></p> <p>I2S can operate as a master or slave. For master mode, I2S_BCLK and I2S_FS pins are outputs and send bit clock and frame sync from ISD9160. In slave mode, I2S_BCLK and I2S_FS pins are inputs and bit clock and frame sync are received from external audio device.</p> <p>1 = Slave mode<br/>0 = Master mode</p>                                                                                                                                                              |
| [7]     | <b>FORMAT</b>    | <p><b>Data format</b></p> <p>1 = MSB justified data format<br/>0 = I2S data format</p> <p>See Figure 5-61 and Figure 5-62 for timing differences.</p>                                                                                                                                                                                                                                                                                                                                                       |
| [6]     | <b>MONO</b>      | <p><b>Monaural data</b></p> <p>This parameter sets whether mono or stereo data is processed. See Figure 5-63 for details of how data is formatted in transmit and receive FIFO.</p> <p>1 = Data is monaural format<br/>0 = Data is stereo format</p>                                                                                                                                                                                                                                                        |

|       |                       |                                                                                                                                                                                                                                                      |
|-------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:4] | <b>WORDWIDTH[1:0]</b> | <b>Word width</b><br>This parameter sets the word width of audio data. See Figure 5-63 for details of how data is formatted in transmit and receive FIFO.<br>00 = data is 8 bit<br>01 = data is 16 bit<br>10 = data is 24 bit<br>11 = data is 32 bit |
| [3]   | <b>MUTE</b>           | <b>Transmit mute enable</b><br>1= Transmit channel zero<br>0 = Transmit data is shifted from FIFO                                                                                                                                                    |
| [2]   | <b>RXEN</b>           | <b>Receive enable</b><br>1 = Enable data receive<br>0 = Disable data receive                                                                                                                                                                         |
| [1]   | <b>TXEN</b>           | <b>Transmit enable</b><br>1 = Enable data transmit<br>0 = Disable data transmit                                                                                                                                                                      |
| [0]   | <b>I2SEN</b>          | <b>Enable I2S controller</b><br>1 = Enable<br>0 = Disable                                                                                                                                                                                            |

I2S Clock Divider (CLKDIV)

| Register | Offset        | R/W | Description                        | Reset Value |
|----------|---------------|-----|------------------------------------|-------------|
| CLKDIV   | I2S_BA + 0x04 | R/W | I2S Clock Divider Control Register | 0x0000_0000 |

|                |    |    |    |    |    |               |   |
|----------------|----|----|----|----|----|---------------|---|
| 15             | 14 | 13 | 12 | 11 | 10 | 9             | 8 |
| BCLK_DIV [7:0] |    |    |    |    |    |               |   |
| 7              | 6  | 5  | 4  | 3  | 2  | 1             | 0 |
| Reserved       |    |    |    |    |    | MCLK_DIV[2:0] |   |

Table 5-116 I2S Clock Divider Register (CLKDIV, address 0x400A\_0004)

| Bits    | Descriptions   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [15:8]  | BCLK_DIV [7:0] | <p><b>Bit Clock Divider</b></p> <p>If I2S operates in master mode, bit clock is provided by ISD9160. Software can program these bits to generate bit clock frequency for the desired sample rate.</p> <p>For sample rate <math>F_s</math>, the desired bit clock frequency is:</p> $F_{BCLK} = F_s \times \text{Word\_width\_in\_bytes} \times 16$ <p>For example if <math>F_s=16\text{kHz}</math>, and word width is 2-bytes (16bit) then desired bit clock frequency is 512kHz.</p> <p>The bit clock frequency is given by:</p> $F_{BCLK} = \frac{F_{I2S\_CLK}}{2 \times (\text{BCLK\_DIV} + 1)}$ <p>Or,</p> $\text{BCLK\_DIV} = \frac{F_{I2S\_CLK}}{2 \times F_{BCLK}} - 1$ <p>So if <math>F_{I2S\_CLK} = HCLK = 49.152\text{MHz}</math>, desired <math>F_{BCLK} = 512\text{kHz}</math> then <math>\text{BCLK\_DIV} = 47</math></p> |
| [7:3]   | Reserved       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [2:0]   | MCLK_DIV[2:0]  | <p><b>Master Clock Divider</b></p> <p>ISD9160 can generate a master clock to synchronously drive an external audio device. If MCLK_DIV is set to 0, MCLK is the same as I2S_CLK clock input, otherwise MCLK frequency is given by:</p> $F_{MCLK} = \frac{F_{I2S\_CLK}}{2 \times \text{MCLK\_DIV}}$ <p>Or,</p> $\text{MCLK\_DIV} = \frac{F_{I2S\_CLK}}{2 \times F_{MCLK}}$ <p>If the desired MCLK frequency is <math>256F_s</math> and <math>F_s = 16\text{kHz}</math> then <math>\text{MCLK\_DIV} = 6</math></p>                                                                                                                                                                                                                                                                                                                       |

Preliminary

I2S Interrupt Enable Register (IE)

| Register | Offset        | R/W | Description                   |  |  |  | Reset Value |
|----------|---------------|-----|-------------------------------|--|--|--|-------------|
| IE       | I2S_BA + 0x08 | R/W | I2S Interrupt Enable Register |  |  |  | 0x0000_0000 |

| 15 | 14 | 13       | 12    | 11    | 10     | 9       | 8       |
|----|----|----------|-------|-------|--------|---------|---------|
|    |    | Reserved | LZCIE | RZCIE | TXTHIE | TXOVFIE | TXUDFIE |
| 7  | 6  | 5        | 4     | 3     | 2      | 1       | 0       |
|    |    | Reserved |       |       | RXTHIE | RXOVFIE | RXUDFIE |

Table 5-117 I2S Interrupt Enable Register (IE, address 0x400A\_0008)

| Bits | Descriptions |                                                                                                                                                                                                                |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [12] | LZCIE        | <b>Left channel zero cross interrupt enable</b><br>Interrupt will occur if this bit is set to 1 and left channel has zero cross event<br>1 = Enable interrupt, 0 = Disable interrupt                           |
| [11] | RZCIE        | <b>Right channel zero cross interrupt enable</b><br>Interrupt will occur if this bit is set to 1 and right channel has zero cross event<br>1 = Enable interrupt, 0 = Disable interrupt                         |
| [10] | TXTHIE       | <b>Transmit FIFO threshold level interrupt enable</b><br>Interrupt occurs if this bit is set to 1 and data words in transmit FIFO is less than TXTH[2:0].<br>1 = Enable interrupt, 0 = Disable interrupt       |
| [9]  | TXOVFIE      | <b>Transmit FIFO overflow interrupt enable</b><br>Interrupt occurs if this bit is set to 1 and transmit FIFO overflow flag is set to 1<br>1 = Enable interrupt, 0 = Disable interrupt                          |
| [8]  | TXUDFIE      | <b>Transmit FIFO underflow interrupt enable</b><br>Interrupt occur if this bit is set to 1 and transmit FIFO underflow flag is set to 1.<br>1 = Enable interrupt , 0 = Disable interrupt                       |
| [2]  | RXTHIE       | <b>Receive FIFO threshold level interrupt</b><br>Interrupt occurs if this bit is set to 1 and data words in receive FIFO is greater than or equal to RXTH[2:0].<br>1 = Enable interrupt, 0 = Disable interrupt |
| [1]  | RXOVFIE      | <b>Receive FIFO overflow interrupt enable</b><br>1 = Enable interrupt, 0 = Disable interrupt                                                                                                                   |
| [0]  | RXUDFIE      | <b>Receive FIFO underflow interrupt enable</b><br>If software read receive FIFO when it is empty then RXUDF flag in I2SSTATUS register is set to 1.<br>1 = Enable interrupt, 0 = Disable interrupt             |

I2S Status Register (STATUS)

| Register | Offset        | R/W | Description         | Reset Value |
|----------|---------------|-----|---------------------|-------------|
| STATUS   | I2S_BA + 0x0C | R/W | I2S Status Register | 0x0014_1000 |

|               |      |        |         |               |          |          |        |
|---------------|------|--------|---------|---------------|----------|----------|--------|
| 31            | 30   | 29     | 28      | 27            | 26       | 25       | 24     |
| TX_LEVEL[3:0] |      |        |         | RX_LEVEL[3:0] |          |          |        |
| 23            | 22   | 21     | 20      | 19            | 18       | 17       | 16     |
| LZCF          | RZCF | TXBUSY | TXEMPTY | TXFULL        | TXTHF    | TXOVF    | TXUDF  |
| 15            | 14   | 13     | 12      | 11            | 10       | 9        | 8      |
| Reserved      |      |        | RXEMPTY | RXFULL        | RXTHF    | RXOVF    | RXUDF  |
| 7             | 6    | 5      | 4       | 3             | 2        | 1        | 0      |
| Reserved      |      |        |         | RIGHT         | I2STXINT | I2SRXINT | I2SINT |

Table 5-118 I2S Status Register (STATUS, address 0x400A\_000C)

| Bits    | Descriptions                                                                                                                                                                                                                                                                    |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | <b>TX_LEVEL</b><br>Transmit FIFO level (Read Only)<br>TX_LEVEL = number of words in transmit FIFO.                                                                                                                                                                              |
| [27:24] | <b>RX_LEVEL</b><br>Receive FIFO level (Read Only)<br>RX_LEVEL = number of words in receive FIFO.                                                                                                                                                                                |
| [23]    | <b>LZCF</b><br>Left channel zero cross flag (write '1' to clear, or clear LCHZCEN)<br>1 = Left channel zero cross is detected<br>0 = No zero cross detected.                                                                                                                    |
| [22]    | <b>RZCF</b><br>Right channel zero cross flag (write '1' to clear, or clear RCHZCEN)<br>1 = Right channel zero cross is detected<br>0 = No zero cross                                                                                                                            |
| [21]    | <b>TXBUSY</b><br>Transmit Busy (Read Only)<br>This bit is cleared when all data in transmit FIFO and Tx shift register is shifted out. It is set when first data is loaded to Tx shift register.<br>1 = Transmit shift register is busy<br>0 = Transmit shift register is empty |
| [20]    | <b>TXEMPTY</b><br>Transmit FIFO Empty (Read Only)<br>This is set when transmit FIFO is empty.<br>1 = Empty<br>0 = Not empty                                                                                                                                                     |

|         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19]    | <b>TXFULL</b>  | <b>Transmit FIFO Full (Read Only)</b><br>This bit is set when transmit FIFO is full.<br>1 = Full.<br>0 = Not full.                                                                                                                                                                                                                                                                                                                                   |
| [18]    | <b>TXTHF</b>   | <b>Transmit FIFO Threshold Flag (Read Only)</b><br>When data word(s) in transmit FIFO is less than or equal to the threshold value set in TXTH[2:0] the TXTHF bit becomes to 1. It remains set until transmit FIFO level is greater than TXTH[2:0]. Cleared by writing to TXFIFO register until threshold exceeded.<br>1 = Data word(s) in FIFO is less than or equal to threshold level<br>0 = Data word(s) in FIFO is greater than threshold level |
| [17]    | <b>TXOVF</b>   | <b>Transmit FIFO Overflow Flag (Write '1' to clear)</b><br>This flag is set if data is written to transmit FIFO when it is full.<br>1 = Overflow<br>0 = No overflow                                                                                                                                                                                                                                                                                  |
| [16]    | <b>TXUDF</b>   | <b>Transmit FIFO underflow flag (Write '1' to clear)</b><br>This flag is set if I2S controller requests data when transmit FIFO is empty.<br>1 = Underflow<br>0 = No underflow                                                                                                                                                                                                                                                                       |
| [15:13] | Reserved       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [12]    | <b>RXEMPTY</b> | <b>Receive FIFO empty (Read Only)</b><br>This is set when receive FIFO is empty.<br>1 = Empty<br>0 = Not empty                                                                                                                                                                                                                                                                                                                                       |
| [11]    | <b>RXFULL</b>  | <b>Receive FIFO full (Read Only)</b><br>This bit is set when receive FIFO is full.<br>1 = Full.<br>0 = Not full.                                                                                                                                                                                                                                                                                                                                     |
| [10]    | <b>RXTHF</b>   | <b>Receive FIFO Threshold Flag (Read Only)</b><br>When data word(s) in receive FIFO is greater than or equal to threshold value set in RXTH[2:0] the RXTHF bit becomes to 1. It remains set until receive FIFO level is less than RXTH[2:0]. It is cleared by reading RXFIFO until threshold satisfied.<br>1 = Data word(s) in FIFO is greater than or equal to threshold level<br>0 = Data word(s) in FIFO is less than threshold level             |
| [9]     | <b>RXOVF</b>   | <b>Receive FIFO Overflow Flag (Write '1' to clear)</b><br>This flag is set if I2S controller writes to receive FIFO when it is full. Audio data is lost.<br>1 = Overflow<br>0 = No overflow                                                                                                                                                                                                                                                          |

|       |                 |                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8]   | <b>RXUDF</b>    | <b>Receive FIFO Underflow Flag (Write '1' to clear)</b><br>This flag is set if attempt is made to read receive FIFO while it is empty.<br>1 = Underflow<br>0 = No underflow                                                                                                                                                                        |
| [7:4] | Reserved        | Reserved                                                                                                                                                                                                                                                                                                                                           |
| [3]   | <b>RIGHT</b>    | <b>Right Channel Active (Read Only)</b><br>This bit indicates current data being transmitted/received belongs to right channel<br>1 = Right channel<br>0 = Left channel                                                                                                                                                                            |
| [2]   | <b>I2STXINT</b> | <b>I2S Transmit Interrupt (Read Only)</b><br>This indicates that there is an active transmit interrupt source. This could be TXOVF, TXUDF, TXTHF, LZCF or RZCF if corresponding interrupt enable bits are active. To clear interrupt the corresponding source(s) must be cleared.<br>1 = Transmit interrupt occurred.<br>0 = No transmit interrupt |
| [1]   | <b>I2SRXINT</b> | <b>I2S Receive Interrupt (Read Only)</b><br>This indicates that there is an active receive interrupt source. This could be RXOVF, RXUDF or RXTHF if corresponding interrupt enable bits are active. To clear interrupt the corresponding source(s) must be cleared.<br>1 = Receive interrupt occurred<br>0 = No receive interrupt                  |
| [0]   | <b>I2SINT</b>   | <b>I2S Interrupt (Read Only)</b><br>This bit is set if any enabled I2S interrupt is active.<br>1 = I2S interrupt active<br>0 = No I2S interrupt                                                                                                                                                                                                    |

I2S Transmit FIFO (TXFIFO)

| Register | Offset        | R/W | Description       | Reset Value |
|----------|---------------|-----|-------------------|-------------|
| TXFIFO   | I2S_BA + 0x10 | W   | I2S Transmit FIFO | 0x0000_0000 |

Table 5-119 I2S Transmit FIFO Register (TXFIFO, address 0x400A\_0010)

| Bits   | Descriptions |                                                                                                                                                                                                                                                |  |  |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:0] | TXFIFO       | <b>Transmit FIFO Register (Write Only)</b><br>A write to this register pushes data onto the transmit FIFO. The transmit FIFO is eight words deep. The number of words currently in the FIFO can be determined by reading I2S->STATUS.TX_LEVEL. |  |  |

I2S Receive FIFO (I2S\_RXFIFO)

| Register   | Offset        | R/W | Description      | Reset Value |
|------------|---------------|-----|------------------|-------------|
| I2S_RXFIFO | I2S_BA + 0x14 | R   | I2S Receive FIFO | 0x0000_0000 |

Table 5-120 I2S Receive FIFO Register (RXFIFO, address 0x400A\_0014)

| Bits   | Descriptions |                                                                                                                                                                                                                                             |  |  |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:0] | RXFIFO       | <b>Receive FIFO Register (Read Only)</b><br>A read of this register will pop data from the receive FIFO. The receive FIFO is eight words deep. The number of words currently in the FIFO can be determined by reading I2S->STATUS.RX_LEVEL. |  |  |

## 5.14 Cyclic Redundancy Check (CRC) Controller

### 5.14.1 Overview and Features

The ISD9160 contains a hardware CRC Generator for checking validity of data streams. The CRC function supported is CRC-16-CCITT ( $x^{16} + x^{12} + x^5 + 1$ ). The hardware CRC allows very fast CRC calculation without utilizing any CPU cycles.

The CRC Controller takes input of even sized packets (2, 4, 8 etc.) of up to 512 bytes long and produces a 16bit CRC output. Input to the CRC Controller is via word access of 4 bytes (32 bits) at a time. This word is configurable to either MSB first or LSB first format

### 5.14.2 Operation

The procedure to use the CRC Generator is as follows:

- Write to CRC->CRC\_EN.LSB register to determine data format. A write to this register initializes the packet counter.
- Write to CRC->CRC\_EN.LEN register to set the packet length (up to 512 bytes, even sizes only, e.g. 2,4,8). A write to this register resets the CRC value to 0xFFFF.
- A read of CRC\_OUT will return 0xFFFF
- Send data to CRC Generator (CRC\_IN) one (32bit) word at a time. CRC Generator extracts bytes from the word in the order specified by the CRC\_EN.LSB control bit.
- Current CRC result is available from CRC\_OUT register four clock cycles after input word written, including intermediate results. The CRC Generator will stop processing data after CRC\_EN.LEN+1 bytes are sent.

### 5.14.3 Example

The following is an example of using CRC Generation and Checking with a packet length of 4 bytes.

If the following code was executed:

```
CRC->CRC_EN.LEN = 3; // Initialize the CRC Generator for a 4 byte packet.
```

```
CRC->CRC_IN = 0x2dcf4633; // Note data is sent MSB first in this mode.
```

Internally the CRC generator would perform the following CRC calculations:

| Data In | CRC    |
|---------|--------|
| initial | 0xffff |
| 0x2D    | 0x143f |
| 0xCF    | 0x4516 |
| 0x46    | 0x2663 |
| 0x33    | 0x2194 |

The CRC result is 0x2194 after the byte sequence 0x2D, 0xCF, 0x46, 0x33 is processed by the generator.

The 2 byte result can be appended to the original data for checking as shown in the following table.

```
CRC->CRC_EN.LEN = 5; // Initialize the CRC Generator for a 6 byte packet.
```

```
CRC->CRC_IN = 0x2dcf4633; // Note data is sent MSB first in this mode.
```

```
CRC->CRC_IN = 0x21940000; // Note data is sent MSB first in this mode.
```

| <b>Data In</b> | <b>CRC</b> |
|----------------|------------|
| <b>initial</b> | 0xffff     |
| <b>0x2D</b>    | 0x143f     |
| <b>0xCF</b>    | 0x4516     |
| <b>0x46</b>    | 0x2663     |
| <b>0x33</b>    | 0x2194     |
| <b>0x21</b>    | 0x9400     |
| <b>0x94</b>    | 0x0000     |

After parsing the 4 bytes data + 2 bytes of CRC result through the CRC Generator, the final result should be 0 which indicates correct data has been transferred.

#### 5.14.4 CRC Controller Register Map

R: read only, W: write only, R/W: both read and write

| Register                    | Offset       | R/W | Description        | Reset Value | Reference                   |
|-----------------------------|--------------|-----|--------------------|-------------|-----------------------------|
| <b>CRC_BA = 0x4009_0000</b> |              |     |                    |             |                             |
| <b>CRC_EN</b>               | CRC_BA+0x000 | R/W | CRC Enable Control | 0x0000_0000 | <a href="#">Table 5-42</a>  |
| <b>CRC_IN</b>               | CRC_BA+0x004 | R/W | CRC Input          | 0x0000_0000 | <a href="#">Table 5-122</a> |
| <b>CRC_OUT</b>              | CRC_BA+0x008 | R   | CRC Output         | 0x0000_FFFF | <a href="#">Table 5-123</a> |

**CRC Control Register Description****CRC Enable Control**

| Register | Offset       | R/W | Description        | Reset Value |
|----------|--------------|-----|--------------------|-------------|
| CRC_EN   | CRC_BA+0x000 | R/W | CRC Enable Control | 0x0000_0000 |

Table 5-121 CRC Enable Control Register

|                 |    |    |    |    |    |    |    |
|-----------------|----|----|----|----|----|----|----|
| 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| <b>Reserved</b> |    |    |    |    |    |    |    |
| 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Reserved</b> |    |    |    |    |    |    |    |
| 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
| <b>Reserved</b> |    |    |    |    |    |    |    |
| 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>LEN[7:0]</b> |    |    |    |    |    |    |    |

| Bits  | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | <p><b>LSB</b></p> <p><b>CRC LSB mode</b></p> <p>Determines whether CRC Generator processes input words (32bit/4Bytes) LSB (least significant byte) first or MSB (most significant byte) first.</p> <p>0 = CRC input is MSB first (default).</p> <p>1 = CRC input is LSB first.</p> <p>For example if LSB=1, and 0x01020304 is written to CRC_IN, bytes will be processed in order 0x04, 0x03, 0x02, 0x01. If LSB=0, then order would be 0x01, 0x02, 0x3, 0x04.</p> <p>Writing any value to this register will flush all previous calculations and restart a new CRC calculation.</p> |
| [8:0] | <p><b>LEN</b></p> <p><b>CRC Packet Length</b></p> <p>Indicates number of bytes of CRC input to process. CRC calculation will stop once input number of bytes = LEN+1. Maximum packet size is 512 bytes, for LEN=511.</p> <p>Writing any value to this register will flush all previous calculations and restart a new CRC calculation.</p>                                                                                                                                                                                                                                           |

CRC Input

| Register | Offset       | R/W | Description         | Reset Value |
|----------|--------------|-----|---------------------|-------------|
| CRC_IN   | CRC_BA+0x004 | R/W | CRC Generator Input | 0x0000_0000 |

Table 5-122 CRC Input Register

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

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CRC_IN       | <p><b>CRC Input</b></p> <p>The string of bytes to perform CRC calculation on.</p> <p>When LSB = 0, CRC performs calculation byte by byte in the order CRC_IN[31:24], CRC_IN[23:16], CRC_IN[15:8], CRC_IN[7:0].</p> <p>When LSB = 1, CRC performs calculation byte by byte in the order CRC_IN[7:0], CRC_IN[15:8], CRC_IN[23:16], CRC_IN[31:24].</p> <p>If number of input bytes exceeds CRC Packet Length (CRC_EN[8:0]+1), any additional input bytes will be ignored.</p> <p>The CRC generator takes four clock cycles to process the CRC input. Software must ensure that at least four clock cycles occur between writes of CRC_IN. Compiled assembly language can be examined to ensure this requirement is met.</p> |

CRC Output

| Register | Offset       | R/W | Description | Reset Value |
|----------|--------------|-----|-------------|-------------|
| CRC_OUT  | CRC_BA+0x008 | R   | CRC Output  | 0x0000_FFFF |

Table 5-123 CRC Output Register

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

| Bits   | Descriptions |                                                                                                                                                                |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | CRC_OUT      | <p><b>CRC Output</b></p> <p>The result of CRC computation. The result is valid four clock cycles after last CRC_IN input data is written to CRC generator.</p> |

Preliminary

## 5.15 PDMA Controller

### 5.15.1 Overview

The ISD9160 incorporates a Peripheral Direct Memory Access (PDMA) controller that transfers data between SRAM and APB devices. The PDMA has four channels of DMA (PDMA CH0~CH3). PDMA transfers are unidirectional and can be Peripheral-to-SRAM, SRAM-to-Peripheral or SRAM-to-SRAM.

The peripherals available for PDMA transfer are SPI, UART, I2S, ADC and DPWM.

PDMA operation is controlled for each channel by configuring a source and destination address and specifying a number of bytes to transfer. Source and destination addresses can be fixed, automatically increment or wrap around a circular buffer. When PDMA operation is complete, controller can be configured to provide CPU with an interrupt.

### 5.15.2 Features

- Provides access to SPI, UART, I2S, ADC and DPWM peripherals.
- AMBA AHB master/slave interface, transfers can occur concurrently with CPU access to flash memory.
- PDMA source and destination addressing modes allow fixed, incrementing, and wrap-around addressing.

### 5.15.3 Block Diagram



Figure 5-64 PDMA Controller Block Diagram

#### 5.15.4 Function Description

The PDMA controller has four channels of DMA, each channel can be configured to one of the following transfer types: Peripheral-to-SRAM SRAM-to-Peripheral or SRAM-to-SRAM. The SRAM and the AHB-APB bus bridge each have an AHB bus arbiter that allows AHB bus access to occur either from the CPU or the PDMA controller. The PDMA controller requests bus transfers over the AHB bus from one address into a single word buffer within the PDMA controller then writes this buffer to another address over the AHB bus. Peripherals with PDMA capability generate control signals to the PDMA block requesting service when they need data (Rx request) or have data to transfer (Tx request). The PDMA control registers reside in address space on the AHB bus.

Transfer completion can be determined by polling of status registers or by generation of PDMA interrupt to CPU. A transfer is set up as a specified number of bytes from a source address to a destination address. Both source and destination address can be configured as a fixed address, an incrementing address or a wrap-around buffer address.

The general procedure to operate a DMA channel is as follows:

- Enable PDMA channel  $n$  clock by setting PDMA->HCLK $n$ \_EN
- Enable PDMA channel  $n$  by setting PDMA->channel[ $n$ ].CSR.PDMACEN
- Set source address in PDMA->channel[ $n$ ].SAR
- Set destination address in PDMA->channel[ $n$ ].DAR
- Set the transfer count in PDMA->channel[ $n$ ].BCR
- Set transfer mode and address increment mode in PDMA->channel[ $n$ ].CSR
- Route peripheral PDMA request signal to channel  $n$  in service selection register.
- Trigger transfer PDMA->channel[ $n$ ].CSR.TRIG\_EN

If the source or destination address is not in wraparound mode, the PDMA will continue the transfer until PDMA->channel[ $n$ ].CBCR decrements to zero (CBCR is initialized to BCR, in wraparound mode, CBCR will reload and continue until PDMACEN is disabled). If an error occurs during the PDMA operation, the channel stops until software clears the error condition and sets the PDMA->channel[ $n$ ].CSR.SW\_RST bit to reset the PDMA channel. After reset the PDMACEN and TRIG\_EN bits would need to be set to start a new operation.

### 5.15.5 PDMA Controller Register Map

R: read only, W: write only, R/W: both read and write, C: Only value 0 can be written

| Register                         | Offset             | R/W | Description                               | Reset Value | Reference                        |
|----------------------------------|--------------------|-----|-------------------------------------------|-------------|----------------------------------|
| <b>PDMA_BA = 0x5000_8000</b>     |                    |     |                                           |             |                                  |
| <b>PDMA_BA_ch0</b>               | = 0x5000_8000      |     | <b>PDMA_BA_ch1</b> = 0x5000_8100          |             | <b>PDMA_BA_ch2</b> = 0x5000_8200 |
| <b>PDMA_BA_ch3</b>               | = 0x5000_8300      |     |                                           |             |                                  |
| <b>CSR</b>                       | PDMA_BA_chx + 0x00 | R/W | PDMA Control Register                     | 0x0000_0000 | <a href="#">Table 5-124</a>      |
| <b>SAR</b>                       | PDMA_BA_chx + 0x04 | R/W | PDMA Source Address Register              | 0x0000_0000 | <a href="#">Table 5-125</a>      |
| <b>DAR</b>                       | PDMA_BA_chx + 0x08 | R/W | PDMA Destination Address Register         | 0x0000_0000 | <a href="#">Table 5-126</a>      |
| <b>BCR</b>                       | PDMA_BA_chx + 0x0C | R/W | PDMA Transfer Byte Count Register         | 0x0000_0000 | <a href="#">Table 5-127</a>      |
| <b>POINT</b>                     | PDMA_BA_chx + 0x10 | R   | PDMA Internal buffer pointer              | 0xFFFF_0000 | <a href="#">Table 5-128</a>      |
| <b>CSAR</b>                      | PDMA_BA_chx + 0x14 | R   | PDMA Current Source Address Register      | 0x0000_0000 | <a href="#">Table 5-129</a>      |
| <b>CDAR</b>                      | PDMA_BA_chx + 0x18 | R   | PDMA Current Destination Address Register | 0x0000_0000 | <a href="#">Table 5-130</a>      |
| <b>CBCR</b>                      | PDMA_BA_chx + 0x1C | R   | PDMA Current Transfer Byte Count Register | 0x0000_0000 | <a href="#">Table 5-131</a>      |
| <b>IER</b>                       | PDMA_BA_chx + 0x20 | R/W | PDMA Interrupt Enable Register            | 0x0000_0001 | <a href="#">Table 5-132</a>      |
| <b>ISR</b>                       | PDMA_BA_chx + 0x24 | R/W | PDMA Interrupt Status Register            | 0x0000_0000 | <a href="#">Table 5-133</a>      |
| <b>PDMA_GCR_BA = 0x5000_8F00</b> |                    |     |                                           |             |                                  |
| <b>GCR</b>                       | PDMA_GCR_BA + 0x00 | R/W | PDMA Global Control Register              | 0x0000_0000 | <a href="#">Table 5-134</a>      |
| <b>PDSSR0</b>                    | PDMA_GCR_BA + 0x04 | R/W | PDMA Service Selection Control Register   | 0xFFFF_FFFF | <a href="#">Table 5-135</a>      |
| <b>GCRISR</b>                    | PDMA_GCR_BA + 0x0C | R/W | PDMA Global Interrupt Register            | 0x0000_0000 | <a href="#">Table 5-136</a>      |

### 5.15.6 PDMA Control Register Description

#### PDMA Control and Status Register (CSR)

| Register | Offset                               | R/W | Description                                  |  |  |  | Reset Value |
|----------|--------------------------------------|-----|----------------------------------------------|--|--|--|-------------|
| CSR      | PDMA_BA+<br>$n \times 0x100 + 0x000$ | R/W | PDMA Control and Status Register Channel $n$ |  |  |  | 0x0000_0000 |

|             |          |    |          |          |          |         |    |
|-------------|----------|----|----------|----------|----------|---------|----|
| 31          | 30       | 29 | 28       | 27       | 26       | 25      | 24 |
| Reserved    |          |    |          |          |          |         |    |
| 23          | 22       | 21 | 20       | 19       | 18       | 17      | 16 |
| TRIG_EN     | Reserved |    | APB_TWS  |          | Reserved |         |    |
| 15          | 14       | 13 | 12       | 11       | 10       | 9       | 8  |
| WRA_INT_SEL |          |    |          | Reserved |          |         |    |
| 7           | 6        | 5  | 4        | 3        | 2        | 1       | 0  |
| DAD_SEL     | SAD_SEL  |    | MODE_SEL |          | SW_RST   | PDMACEN |    |

Table 5-124 PDMA Control and Status Register (CSR, address 0x5000\_8000 +  $n \times 0x100$ )

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23]    | TRIG_EN      | <b>Trigger Enable – Start a PDMA operation.</b><br>0 = Write: no effect. Read: Idle/Finished.<br>1 = Enable PDMA data read or write transfer.<br><b>Note:</b> When PDMA transfer completed, this bit will be cleared automatically.<br>If a bus error occurs, all PDMA transfer will be stopped. Software must reset PDMA channel, and then trigger again.                                                                                                                                                    |
| [20:19] | APB_TWS      | <b>Peripheral Transfer Width Select.</b><br>This parameter determines the data width to be transferred each PDMA transfer operation.<br>00 = One word (32 bits) is transferred for every PDMA operation.<br>01 = One byte (8 bits) is transferred for every PDMA operation.<br>10 = One half-word (16 bits) is transferred for every PDMA operation.<br>11 = Reserved.<br><b>Note:</b> This field is meaningful only when MODE_SEL is IP to Memory mode (APB-to-Memory) or Memory to IP mode (Memory-to-APB). |

|         |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:12] | <b>WRA_INT_SEL</b> | <b>Wrap Interrupt Select</b><br>x1xx: If this bit is set, and wraparound mode is in operation a Wrap Interrupt can be generated when half each PDMA transfer is complete. For example if BCR=32 then an interrupt could be generated when 16 bytes were sent.<br>xxx1: If this bit is set, and wraparound mode is in operation a Wrap Interrupt can be generated when each PDMA transfer is wrapped. For example if BCR=32 then an interrupt could be generated when 32 bytes were sent and PDMA wraps around.<br>x1x1: Both half and w interrupts generated.                                                                                                                                                                                                                                                                                                                                                                              |
| [7:6]   | <b>DAD_SEL</b>     | <b>Destination Address Select</b><br>This parameter determines the behavior of the current destination address register with each PDMA transfer. It can either be fixed, incremented or wrapped.<br>00 = Transfer Destination Address is incremented.<br>01 = Reserved.<br>10 = Transfer Destination Address is fixed (Used when data transferred from multiple addresses to a single destination such as peripheral FIFO input).<br>11 = Transfer Destination Address is wrapped. When CBCR (Current Byte Count) equals zero, the CDAR (Current Destination Address) and CBCR registers will be reloaded from the DAR (Destination Address) and BCR (Byte Count) registers automatically and PDMA will start another transfer. Cycle continues until software sets PDMA_EN=0. When PDMA_EN is disabled, the PDMA will complete the active transfer but the remaining data in the SBUF will not be transferred to the destination address. |
| [5:4]   | <b>SAD_SEL</b>     | <b>Source Address Select</b><br>This parameter determines the behavior of the current source address register with each PDMA transfer. It can either be fixed, incremented or wrapped.<br>00 = Transfer Source address is incremented.<br>01 = Reserved.<br>10 = Transfer Source address is fixed<br>11 = Transfer Source address is wrapped. When CBCR (Current Byte Count) equals zero, the CSAR (Current Source Address) and CBCR registers will be reloaded from the SAR (Source Address) and BCR (Byte Count) registers automatically and PDMA will start another transfer. Cycle continues until software sets PDMA_EN=0. When PDMA_EN is disabled, the PDMA will complete the active transfer but the remaining data in the SBUF will not be transferred to the destination address.                                                                                                                                                |
| [3:2]   | <b>MODE_SEL</b>    | <b>PDMA Mode Select</b><br>This parameter selects to transfer direction of the PDMA channel. Possible values are:<br>00 = Memory to Memory mode (SRAM-to-SRAM).<br>01 = IP to Memory mode (APB-to-SRAM).<br>10 = Memory to IP mode (SRAM-to-APB).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [1]     | <b>SW_RST</b>      | <b>Software Engine Reset</b><br>0 = Writing 0 to this bit has no effect.<br>1 = Writing 1 to this bit will reset the internal state machine and pointers. The contents of the control register will not be cleared. This bit will auto clear after a few clock cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|     |         |                                                                                                                                                                                                                           |
|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | PDMACEN | <b>PDMA Channel Enable</b><br>Setting this bit to 1 enables PDMA's operation. If this bit is cleared, PDMA will ignore all PDMA request and force Bus Master into IDLE state.<br><b>Note:</b> SW_RST will clear this bit. |
|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Preliminary

PDMA Transfer Source Address Register (SAR)

| Register | Offset                               | R/W | Description                                       | Reset Value |
|----------|--------------------------------------|-----|---------------------------------------------------|-------------|
| SAR      | PDMA_BA+<br>$n \times 0x100 + 0x004$ | R/W | PDMA Transfer Source Address Register Channel $n$ | 0x0000_0000 |

Table 5-125 PDMA Source Address Register (SAR, address 0x5000\_8004 +  $n \times 0x100$ )

| Bits   | Descriptions |                                                                                                                                                                           |  |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:0] | SAR          | <b>PDMA Transfer Source Address Register</b><br>This register holds the initial Source Address of PDMA transfer.<br><b>Note:</b> The source address must be word aligned. |  |

PDMA Transfer Destination Address Register (DAR)

| Register | Offset                               | R/W | Description                                            | Reset Value |
|----------|--------------------------------------|-----|--------------------------------------------------------|-------------|
| DAR      | PDMA_BA+<br>$n \times 0x100 + 0x008$ | R/W | PDMA Transfer Destination Address Register Channel $n$ | 0x0000_0000 |

Table 5-126 PDMA Destination Address Register (DAR, address 0x5000\_8008 +  $n \times 0x100$ )

| Bits   | Descriptions |                                                                                                                                                                                          |  |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:0] | DAR          | <b>PDMA Transfer Destination Address Register</b><br>This register holds the initial Destination Address of PDMA transfer.<br><b>Note:</b> The destination address must be word aligned. |  |

PDMA Transfer Byte Count Register (BCR)

| Register | Offset                               | R/W | Description                                   | Reset Value |
|----------|--------------------------------------|-----|-----------------------------------------------|-------------|
| BCR      | PDMA_BA+<br>$n \times 0x100 + 0x00C$ | R/W | PDMA Transfer Byte Count Register Channel $n$ | 0x0000_0000 |

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

Table 5-127 PDMA Transfer Byte Count Register (BCR, address 0x5000\_800C +  $n \times 0x100$ )

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                            |
|---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved     | Reserved                                                                                                                                                                                                                                                                                   |
| [15:0]  | BCR          | <p><b>PDMA Transfer Byte Count Register</b></p> <p>This register controls the transfer byte count of PDMA. Maximum value is 0xFFFF.</p> <p><b>Note:</b> When in memory-to-memory (CSR.MODE_SEL = 00b) mode, the transfer byte count must be word aligned, that is multiples of 4bytes.</p> |

PDMA Internal Buffer Pointer Register (POINT)

| Register | Offset                               | R/W | Description                                       | Reset Value |
|----------|--------------------------------------|-----|---------------------------------------------------|-------------|
| POINT    | PDMA_BA+<br>$n \times 0x100 + 0x010$ | R   | PDMA Internal Buffer Pointer Register Channel $n$ | 0xXXXX_XX00 |

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

Table 5-128 PDMA Internal Buffer Point Register (POINT, address 0x5000\_8010 +  $n \times 0x100$ )

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [3:0]  | POINT        | <b>PDMA Internal Buffer Pointer Register (Read Only)</b><br>A PDMA transaction consists of two stages, a read from the source address and a write to the destination address. Internally this data is buffered in a 32bit register. If transaction width between the read and write transactions are different, this register tracks which byte/half-word of the internal buffer is being processed by the current transaction. |

PDMA Current Source Address Register (CSAR)

| Register | Offset                               | R/W | Description                                      | Reset Value |
|----------|--------------------------------------|-----|--------------------------------------------------|-------------|
| CSAR     | PDMA_BA+<br>$n \times 0x100 + 0x014$ | R   | PDMA Current Source Address Register Channel $n$ | 0x0000_0000 |

Table 5-129 PDMA Current Source Address Register (CSAR, address  $0x5000_8014 + n \times 0x100$ )

| Bits   | Descriptions |                                                                                                                                                                                                                                     |  |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:0] | CSAR         | <b>PDMA Current Source Address Register (Read Only)</b><br>This register returns the source address from which the PDMA transfer is occurring. This register is loaded from SAR when PDMA is triggered or when a wraparound occurs. |  |

PDMA Current Destination Address Register (CDAR)

| Register | Offset                               | R/W | Description                                           | Reset Value |
|----------|--------------------------------------|-----|-------------------------------------------------------|-------------|
| CDAR     | PDMA_BA+<br>$n \times 0x100 + 0x018$ | R   | PDMA Current Destination Address Register Channel $n$ | 0x0000_0000 |

Table 5-130 PDMA Current Destination Address Register (CDAR, address  $0x5000_8018 + n \times 0x100$ )

| Bits   | Descriptions |                                                                                                                                                                                                                                             |  |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:0] | CDAR         | <b>PDMA Current Destination Address Register (Read Only)</b><br>This register returns the destination address to which the PDMA transfer is occurring. This register is loaded from DAR when PDMA is triggered or when a wraparound occurs. |  |

PDMA Current Byte Count Register (CBCR)

| Register | Offset                               | R/W | Description                                  | Reset Value |
|----------|--------------------------------------|-----|----------------------------------------------|-------------|
| CBCR     | PDMA_BA+<br>$n \times 0x100 + 0x01C$ | R   | PDMA Current Byte Count Register Channel $n$ | 0x0000_0000 |

Table 5-131 PDMA Current Byte Count Register (CBCR, address  $0x5000_801C + n \times 0x100$ )

| Bits    | Descriptions |                                                                                                                                                                                                                                  |  |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:16] | Reserved     | Reserved                                                                                                                                                                                                                         |  |
| [15:0]  | CBCR         | <b>PDMA Current Byte Count Register (Read Only)</b><br>This field indicates the current remaining byte count of PDMA transfer. This register is initialized with BCR register when PDMA is triggered or when a wraparound occurs |  |

PDMA Interrupt Enable Control Register (IER)

| Register | Offset                               | R/W | Description                                        |  |  |  | Reset Value |
|----------|--------------------------------------|-----|----------------------------------------------------|--|--|--|-------------|
| IER      | PDMA_BA+<br>$n \times 0x100 + 0x020$ | R/W | PDMA Interrupt Enable Control Register Channel $n$ |  |  |  | 0x0000_0001 |

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

Table 5-132 PDMA Interrupt Enable Control Register (IER, address 0x5000\_8020 +  $n \times 0x100$ )

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2]    | WAR_IE       | <p><b>Wraparound Interrupt Enable</b></p> <p>If enabled, and channel source or destination address is in wraparound mode, the PDMA controller will generate a WRAP interrupt to the CPU according to the setting of CSR.WRA_INT_SEL. This can be interrupts when the transaction has finished and has wrapped around and/or when the transaction is half way in progress. This allows the efficient implementation of circular buffers for DMA.</p> <p>0 = Disable Wraparound PDMA interrupt generation.<br/>1 = Enable Wraparound interrupt generation.</p> |
| [1]    | BLKD_IE      | <p><b>PDMA Transfer Done Interrupt Enable</b></p> <p>If enabled, the PDMA controller will generate and interrupt to the CPU when the requested PDMA transfer is complete.</p> <p>0 = Disable PDMA transfer done interrupt generation.<br/>1 = Enable PDMA transfer done interrupt generation.</p>                                                                                                                                                                                                                                                            |
| [0]    | TABORT_IE    | <p><b>PDMA Read/Write Target Abort Interrupt Enable</b></p> <p>If enabled, the PDMA controller will generate and interrupt to the CPU whenever a PDMA transaction is aborted due to an error. If a transfer is aborted, PDMA channel must be reset to resume DMA operation.</p> <p>0 = Disable PDMA transfer target abort interrupt generation.<br/>1 = Enable PDMA transfer target abort interrupt generation.</p>                                                                                                                                          |

PDMA Interrupt Status Register (ISR)

| Register | Offset                               | R/W | Description                                |  |  |  | Reset Value |
|----------|--------------------------------------|-----|--------------------------------------------|--|--|--|-------------|
| ISR      | PDMA_BA+<br>$n \times 0x100 + 0x024$ | R/W | PDMA Interrupt Status Register Channel $n$ |  |  |  | 0x0x0x_0000 |

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

Table 5-133 PDMA Interrupt Enable Status Register (ISR, address  $0x5000\_8024 + n \times 0x100$ )

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | INTR         | <b>Interrupt Pin Status (Read Only)</b><br>This bit is the Interrupt pin status of PDMA channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [30:12] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [11:8]  | WAR_IF       | <b>Wrap around transfer byte count interrupt flag.</b><br>These flags are set whenever the conditions for a wraparound interrupt (complete or half complete) are met. They are cleared by writing one to the bits.<br>0001 = Current transfer finished flag (CBCR==0).<br>0100 = Current transfer half complete flag (CBCR==BCR/2).                                                                                                                                                                                                                                                 |
| [1]     | BLKD_IF      | <b>Block Transfer Done Interrupt Flag</b><br>This bit indicates that PDMA block transfer complete interrupt has been generated. It is cleared by writing 1 to the bit.<br>0 = Transfer ongoing or Idle.<br>1 = Transfer Complete.                                                                                                                                                                                                                                                                                                                                                   |
| [0]     | TABORT_IF    | <b>PDMA Read/Write Target Abort Interrupt Flag</b><br>This flag indicates a Target Abort interrupt condition has occurred. This condition can happen if attempt is made to read/write from invalid or non-existent memory space. It occurs when PDMA controller receives a bus error from AHB master. Upon occurrence PDMA will stop transfer and go to idle state. To resume, software must reset PDMA channel and initiate transfer again.<br>0 = No bus ERROR response received.<br>1 = Bus ERROR response received.<br><b>NOTE:</b> This bit is cleared by writing 1 to itself. |

**PDMA Global Control Register (GCR)**

| Register | Offset              | R/W | Description                  |  |  |  | Reset Value |
|----------|---------------------|-----|------------------------------|--|--|--|-------------|
| GCR      | PDMA_BA_GCR + 0x000 | R/W | PDMA Global Control Register |  |  |  | 0x0000_0000 |

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

Table 5-134 PDMA Global Control Register (GCR, address 0x5000\_8F00)

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                    |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                           |
| [11:8]  | HCLK_EN[3:0] | <b>PDMA Controller Channel Clock Enable Control</b><br>To enable clock for channel $n$ HCLK_EN[ $n$ ] must be set.<br>HCLK_EN[ $n$ ]=1: Enable Channel $n$ clock<br>HCLK_EN[ $n$ ]=0: Disable Channel $n$ clock                                                                                                                    |
| [7:1]   | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                           |
| [0]     | PDMA_RST     | <b>PDMA Software Reset</b><br>0 = Writing 0 to this bit has no effect.<br>1 = Writing 1 to this bit will reset the internal state machine and pointers. The contents of control register will not be cleared. This bit will auto clear after several clock cycles.<br><b>Note:</b> This bit can reset all channels (global reset). |

PDMA Service Selection Control Register (PDSSR)

| Register | Offset            | R/W | Description                             | Reset Value |
|----------|-------------------|-----|-----------------------------------------|-------------|
| PDSSR    | PDMA_BA_GCR +0x04 | R/W | PDMA Service Selection Control Register | 0xFFFF_FFFF |

PDMA peripherals have transmit and/or receive request signals to control dataflow during PDMA transfers. These signals must be connected to the PDMA channel assigned by software for use with that peripheral. For instance if PDMA Channel 3 is to be used to transfer data from memory to DPWM peripheral, then DPWM\_TXSEL should be set to 3. This will route the DPWM transmit request signal to PDMA channel 3, whenever DPWM has space in FIFO it will request transmission of data from PDMA. When not used the selection should be set to 0xFF.

|             |    |    |    |             |    |    |    |
|-------------|----|----|----|-------------|----|----|----|
| 31          | 30 | 29 | 28 | 27          | 26 | 25 | 24 |
| I2S_TXSEL   |    |    |    | I2S_RXSEL   |    |    |    |
| 23          | 22 | 21 | 20 | 19          | 18 | 17 | 16 |
| UART0_TXSEL |    |    |    | UART0_RXSEL |    |    |    |
| 15          | 14 | 13 | 12 | 11          | 10 | 9  | 8  |
| DPWM_TXSEL  |    |    |    | ADC_RXSEL   |    |    |    |
| 7           | 6  | 5  | 4  | 3           | 2  | 1  | 0  |
| SPI0_TXSEL  |    |    |    | SPI0_RXSEL  |    |    |    |

Table 5-135 PDMA Service Selection Control Register (PDSSR, address 0x5000\_8F04)

| Bits    | Descriptions       |                                                                                                                                                     |
|---------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | <b>I2S_TXSEL</b>   | <b>PDMA I2S Transmit Selection</b><br>This field defines which PDMA channel is connected to I2S peripheral transmit (PDMA destination) request.     |
| [27:24] | <b>I2S_RXSEL</b>   | <b>PDMA I2S Receive Selection</b><br>This field defines which PDMA channel is connected to I2S peripheral receive (PDMA source) request.            |
| [23:20] | <b>UART0_TXSEL</b> | <b>PDMA UART0 Transmit Selection</b><br>This field defines which PDMA channel is connected to UART0 peripheral transmit (PDMA destination) request. |
| [19:16] | <b>UART0_RXSEL</b> | <b>PDMA UART0 Receive Selection</b><br>This field defines which PDMA channel is connected to UART0 peripheral receive (PDMA source) request.        |
| [15:12] | <b>DPWM_TXSEL</b>  | <b>PDMA DPWM Transmit Selection</b><br>This field defines which PDMA channel is connected to DPWM peripheral transmit (PDMA destination) request.   |

|        |                   |                                                                                                                                                   |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [11:8] | <b>ADC_RXSEL</b>  | <b>PDMA ADC Receive Selection</b><br>This field defines which PDMA channel is connected to ADC peripheral receive (PDMA source) request.          |
| [7:4]  | <b>SPI0_TXSEL</b> | <b>PDMA SPI0 Transmit Selection</b><br>This field defines which PDMA channel is connected to SPI0 peripheral transmit (PDMA destination) request. |
| [3:0]  | <b>SPI0_RXSEL</b> | <b>PDMA SPI0 Receive Selection</b><br>This field defines which PDMA channel is connected to SPI0 peripheral receive (PDMA source) request.        |

**PDMA Global Interrupt Status Register (GCRISR)**

| Register | Offset              | R/W | Description                           | Reset Value |
|----------|---------------------|-----|---------------------------------------|-------------|
| GCRISR   | PDMA_BA_GCR + 0x00C | R   | PDMA Global Interrupt Status Register | 0x0000_0000 |

Table 5-136 PDMA Global Interrupt Status Register (GCRISR, address 0x5000\_8F0C)

| Bits  | Descriptions  |                                                                                                                  |
|-------|---------------|------------------------------------------------------------------------------------------------------------------|
| [3:0] | <b>GCRISR</b> | <b>Interrupt Pin Status (Read Only)</b><br>GCRISR[ <i>n</i> ] is the interrupt status of PDMA channel <i>n</i> . |

## 6 FLASH MEMORY CONTROLLER (FMC)

### 6.1 Overview

The ISD9160 is available with 141K bytes of on-chip embedded Flash EEPROM for application program and data flash memory. The memory can be updated through procedures for In-Circuit Programming (ICP) through the ARM Serial-Wire Debug (SWD) port or via In-System Programming (ISP) functions under software control. In-System Programming (ISP) functions enable user to update program memory when chip is soldered onto PCB.

Main flash memory is divided into two partitions: Application Program ROM (APROM) and Data flash (DATAF). In addition there are two other partitions, a 4K Byte Boot Loader ROM (LDROM), and Configuration ROM (CONFIG).

Upon chip power-on, the Cortex-M0 CPU fetches code from APROM or LDROM determined by a boot select configuration in CONFIG.

The boundary between APROM and user DATA Flash can be configured to any sector address boundary. Erasable sector size is 1K Byte. This boundary is also specified in the CONFIG memory.

LDROM is a fixed 4K Byte in size, but if not required can be incorporated into the APROM address space of the 141K Byte device for a total device memory of 145K Byte.

### 6.2 Features

- AHB interface compatible
- Runs up to 50 MHz with zero wait-state for continuous address read access
- 141KB application program memory (APROM)
- 4KB in system programming (ISP) boot loader program memory (LDROM)
- Configurable data flash with 1k Bytes sector erase unit
- Programmable data flash start address.
- In System Program (ISP) capability to update on chip Flash EEPROM

### 6.3 Flash Memory Controller Block Diagram

The flash memory controller consist of AHB slave interface, ISP control logic, writer interface and flash macro interface timing control logic. The block diagram of flash memory controller is shown as following:



Figure 6-1 Flash Memory Control Block Diagram

## 6.4 Flash Memory Organization

The ISD9160 flash memory consists of Application Program (APROM) memory (141KB), data flash (DATAF), ISP boot loader (LDROM) program memory (4KB), user configuration (CONFIG). User configuration block provides 2 words that control system configuration, like flash security lock, boot select, brown out voltage level and data flash base address. An additional 504Bytes are available in CONFIG memory for the user to store custom configuration data. The first two CONFIG words are loaded from CONFIG memory at power-on into device control registers to initialize certain chip functions. The data flash start address (DFBADR) is defined in CONFIG memory and determines the relative size of the APROM and DATAF partitions.

Table 6-1 Memory Address Map

| Block Name | Size              | Start Address | End Address                                      |
|------------|-------------------|---------------|--------------------------------------------------|
| APROM      | 141 KB            | 0x0000_0000   | 0x0002_33FF (141KB)<br>OR<br>DFBADR-1 if DFEN!=0 |
| DATAF      | User Configurable | DFBADR        | 0x0002_33FF (141KB)                              |
| LDROM      | 4 KB              | 0x0010_0000   | 0x0010_0FFF                                      |
| CONFIG     | 512B              | 0x0030_0000   | 0x0030_01FF                                      |

The Flash memory organization is shown as below:



Figure 6-2 Flash Memory Organization

## 6.5 Boot Selection

The ISD9160 provides an in-system programming (ISP) feature to enable user to update the application program memory when the chip is mounted on a PCB. A dedicated 4KB boot loader program memory is used to store ISP firmware. The user customizes this firmware to implement a protocol specific to their system to download updated application code. This firmware could utilize device peripherals such as UART, SPI or I2C to fetch new application code. The memory area from which the ISD9160 boots is controlled by the CBS bit in Config0 register.

## 6.6 Data Flash (DATAF)

The ISD9160 provides a data flash partition for user to store non-volatile data such as audio recordings. It accessed through ISP procedures via the Flash Memory Controller (FMC). The size of each erasable sector is 1Kbyte and minimum write size is one word (4Bytes). An erase operation resets all memory in sector to value 0xFF. A write operation can only change a '1' bit to a '0' bit. If a subset of the sector needs to be changed, the entire 1KB sector must be copied to another page or into SRAM in advance as entire sector must be erased before modification. Data flash and application program memory share the same memory space. If DFENB bit in Config0 is enabled ('0'), the data flash base address is defined by DFBADR and application program memory size is  $(X-N)$ KB and data flash size is  $N$  KB, where  $X$  is the total device memory size (141KB) and  $N$  is number of Kbytes (sectors) reserved for data flash. In addition, for the 141KB device, the LDROM partition can be disabled and included in APROM/DATAF memory by setting the LDROM\_EN configuration bit low allowing a total of 145KB of memory available to APROM/DATAF.



Figure 6-3 Flash Memory Structure

## 6.7 User Configuration (CONFIG)

Config0 (ISP Address = 0x0030\_0000)

| 31            | 30 | 29 | 28 | 27 | 26              | 25          | 24          |
|---------------|----|----|----|----|-----------------|-------------|-------------|
| -             | -  | -  | -  | -  | -               | -           | -           |
| 23            | 22 | 21 | 20 | 19 | 18              | 17          | 16          |
| <b>CBODEN</b> | -  | -  | -  | -  | -               | -           | -           |
| 15            | 14 | 13 | 12 | 11 | 10              | 9           | 8           |
| -             | -  | -  | -  | -  | -               | -           | -           |
| 7             | 6  | 5  | 4  | 3  | 2               | 1           | 0           |
| <b>CBS</b>    | -  | -  | -  | -  | <b>LDROM_EN</b> | <b>LOCK</b> | <b>DFEN</b> |

Table 6-2 User Configuration Register 0 (Config0, address 0x0030\_0000 accessible through ISP only)

| Bits    | Descriptions  |                                                                                                                                                                                                                                                                                                                                             |
|---------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:23] | Reserved      | Reserved for future use                                                                                                                                                                                                                                                                                                                     |
| [23]    | <b>CBODEN</b> | <b>Brown Out Detector Enable</b><br>If set to '0' the Brown Out Detector (BOD) will be enabled after power up. It will be configured at lowest voltage (2.1V) and if brown out condition detected will trigger the NMI interrupt to processor.<br>0= Enable, 1=Disable brown out detect after power on                                      |
| [22:8]  | Reserved      | Reserved for future use                                                                                                                                                                                                                                                                                                                     |
| [7]     | <b>CBS</b>    | <b>Configuration Boot Selection</b><br>0 = Chip will boot from LDROM, 1 = Chip will boot from APROM                                                                                                                                                                                                                                         |
| [6:2]   | Reserved      | Reserved for future use                                                                                                                                                                                                                                                                                                                     |
| [1]     | <b>LOCK</b>   | <b>Security Lock</b><br>0 = Flash data is locked, 1 = Flash data is not locked.<br>When flash data is locked, only device ID, Config0 and Config1 can be read by ICP through serial debug interface. Other data is locked as 0xFFFFFFFF. Once locked no SWD debugging is possible. ISP can read data anywhere regardless of LOCK bit value. |
| [0]     | <b>DFENB</b>  | <b>Data Flash Enable Bar</b><br>When data flash is enabled, flash memory is partitioned between APROM and DATAF memory depending on the setting of data flash base address in Config1 register. If set to '0' then no DATAF partition exists.<br>0 = Enable data flash<br>1 = Disable data flash                                            |

Config1 (Address = 0x0030\_0004)

Table 6-3 User Configuration Register 1 (Config1, address 0x0030\_0004 accessible through ISP only)

| Bits    | Descriptions |                                                                                                                                                                            |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved     | Reserved<br>It is mandatory to program 0x00 to these Reserved bits                                                                                                         |
| [19:0]  | DFBADR       | <b>Data Flash Base Address</b><br>This pointer sets the address for the start of data flash memory. Address must be on a 1KB sector boundary so DFBADR[9:0] must be 0x000. |

## 6.8 In-System Programming (ISP)

The program and data flash memory support both in hardware In-Circuit Programming (ICP) and firmware based In-System programming (ISP). Hardware ICP programming mode uses the Serial-Wire Debug (SWD) port to program chip. Dedicated ICE Debug hardware or ICP gang-writers are available to reduce programming and manufacturing costs. For firmware updates in the field, the ISD9160 provides an ISP mode allowing a device to be reprogrammed under software control.

ISP is performed without removing the device from the system. Various interfaces enable LDROM firmware to fetch new program code from an external source. A common method to perform ISP would be via a UART controlled by firmware in LDROM. In this scenario, a PC could transfer new APROM code through a serial port. The LDROM firmware receives it and reprograms APROM through ISP commands. An alternative might be to fetch new firmware from an attached SD-Card via the SPI interface.

### 6.8.1 ISP Procedure

The ISD9160 will boot from APROM or LDROM from a power-on reset as defined by user configuration bit CBS. If user desires to update application program in APROM, the ISPCON.BS can be set to '1' and a software reset issued. This will cause the chip to boot from LDROM. An example flow diagram of the ISP sequence is shown in Figure 6-5.

The ISPCON register is a protected register, user must first follow the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#)) to gain access. This procedure is to protect the flash memory from unintentional access.

To enable ISP functionality software must first ensure the ISP clock (AHBCLK.ISP\_EN) is present then set the ISPCON.ISPEN bit.

Several error conditions are checked after software writes the ISPTRIG register. If an error condition occurs, ISP operation is not started and the ISP fail flag (ISPCON.ISPFF) will be set instead. The ISPFF flag will remain set until it is cleared by software. Subsequent ISP procedure can be started even if ISPFF is set. It is recommended that software check ISPFF bit and clear it after each ISP operation if set.

When ISPTRIG register is set, the CoretxM0 CPU will wait for ISP operation to finish, during this period; peripherals operate as usual. If any interrupt requests occur, CPU will not service them until ISP operation finishes. As the ISP functions affect the operation of the flash memory M0 instruction pipeline should be flushed with an ISB (Instruction Synchronization Barrier) instruction after the ISP is triggered.



Figure 6-4 ISP Operation Timing



Figure 6-5 Boot Sequence and ISP Procedure

The ISP command set is shown in Table 6-4. Three registers determine the action of a command: ISPCMD is the command register and accepts commands for reading ID registers and read/write/erase of flash memory. The ISPADR is the address register where the flash memory address for access is written. ISPDAT is the data register that input data is written to and return data read from. An ISP command is executed by setting ISPCMD, ISPDAT and ISPADR then writing to the trigger register ISPTRIG.

There is an ISP command to read the device ID register. This register returns a code that reports the memory configuration of the ISD9160 part as given in Table 6-5.

Table 6-4 ISP Command Set

| <b>ISP Mode</b>   | <b>ISPCMD</b> | <b>ISPADR</b> |       |         | <b>ISPDAT</b>              |
|-------------------|---------------|---------------|-------|---------|----------------------------|
|                   | ISPCMD[5:0]   | A21           | A20   | A[19:0] | D[31:0]                    |
| Standby           | 0x3x          | x             | x     | x       | x                          |
| Read Company ID   | 0x0B          | x             | x     | x       | Returns 0x0000_00DA        |
| Read Device ID    | 0x0C          | x             | x     | 0x00000 | 0x1D00_01nn. See Table 6-5 |
| FLASH Page Erase  | 0x22          | 0             | A[20] | A[19:0] | x                          |
| FLASH Program     | 0x21          | 0             | A[20] | A[19:0] | Data input                 |
| FLASH Read        | 0x00          | 0             | A[20] | A[19:0] | Data output                |
| CONFIG Page Erase | 0x22          | 1             | 1     | A[19:0] | x                          |
| CONFIG Program    | 0x21          | 1             | 1     | A[19:0] | Data input                 |
| CONFIG Read       | 0x00          | 1             | 1     | A[19:0] | Data output                |

Table 6-5 Device ID Memory Size

| DID[7:4] | Flash Size (KB) | DID[3:0] | RAM Size (KB) |
|----------|-----------------|----------|---------------|
| 8        | 145             | 3        | 12            |

## 6.9 Flash Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                                   | Offset       | R/W | Description          | Reset Value | Reference                  |
|--------------------------------------------|--------------|-----|----------------------|-------------|----------------------------|
| <b>Base Address (FMC_BA) : 0x5000_C000</b> |              |     |                      |             |                            |
| ISPCON                                     | FMC_BA+0x000 | R/W | ISP Control Register | 0x0000_0000 | <a href="#">Table 6-6</a>  |
| ISPADR                                     | FMC_BA+0x004 | R/W | ISP Address Register | 0x0000_0000 | <a href="#">Table 6-7</a>  |
| ISPDAT                                     | FMC_BA+0x008 | R/W | ISP Data Register    | 0x0000_0000 | <a href="#">Table 6-8</a>  |
| ISPCMD                                     | FMC_BA+0x00C | R/W | ISP Command Register | 0x0000_0000 | <a href="#">Table 6-9</a>  |
| ISPTRG                                     | FMC_BA+0x010 | R/W | ISP Trigger Register | 0x0000_0000 | <a href="#">Table 6-10</a> |
| DFBADR                                     | FMC_BA+0x014 | R   | Data Flash Start     | 0x0000_0000 | <a href="#">Table 6-11</a> |

## 6.10 Flash Control Register Description

### ISP Control Register (ISPCON)

The ISPCON register is a protected register, user must first follow the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#)) to gain access.

| Register | Offset      | R/W | Description          |  |  |  | Reset Value |
|----------|-------------|-----|----------------------|--|--|--|-------------|
| ISPCON   | FMC_BA+0x00 | R/W | ISP Control Register |  |  |  | 0x0000_0000 |

|       |       |       |        |   |   |    |       |
|-------|-------|-------|--------|---|---|----|-------|
| 7     | 6     | 5     | 4      | 3 | 2 | 1  | 0     |
| SWRST | ISPFF | LDUEN | CFGUEN | - | - | BS | ISPEN |

Table 6-6 ISP Control Register (ISPCON, address 0x5000\_C000)

| Bits  | Descriptions  |                                                                                                                                                                                                                                                                                                                                              |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | <b>SWRST</b>  | <b>Software Reset</b><br>Writing 1 to this bit will initiate a software reset. It is cleared by hardware after reset.                                                                                                                                                                                                                        |
| [6]   | <b>ISPFF</b>  | <b>ISP Fail Flag</b><br>This bit is set by hardware when a triggered ISP meets any of the following conditions:<br>(1) APROM writes to itself.<br>(2) LDROM writes to itself.<br>(3) Destination address is illegal, such as over an available range.<br>Write 1 to clear.                                                                   |
| [5]   | <b>LDUEN</b>  | <b>LDROM Update Enable</b><br>LDROM update enable bit.<br>1 = LDROM can be updated when the MCU runs in APROM.<br>0 = LDROM cannot be updated                                                                                                                                                                                                |
| [4]   | <b>CFGUEN</b> | <b>CONFIG Update Enable</b><br>1 = Enable, 0 = Disable<br>When enabled, ISP functions can access the CONFIG address space and modify device configuration area.                                                                                                                                                                              |
| [3:2] | Reserved      | Reserved                                                                                                                                                                                                                                                                                                                                     |
| [1]   | <b>BS</b>     | <b>Boot Select</b><br>1: LDROM, 0: APROM<br>Modify this bit to select which ROM next boot is to occur. This bit also functions as MCU boot status flag, which can be used to check where MCU booted from. <b>This bit is initialized after power-on reset with the inverse of CBS in Config0; It is not reset for any other reset event.</b> |

|     |              |                                                                          |
|-----|--------------|--------------------------------------------------------------------------|
| [0] | <b>ISPEN</b> | <b>ISP Enable</b><br>1 = Enable ISP function<br>0 = Disable ISP function |
|-----|--------------|--------------------------------------------------------------------------|

Preliminary

ISP Address Register (ISPADR)

| Register | Offset       | R/W | Description          | Reset Value |
|----------|--------------|-----|----------------------|-------------|
| ISPADR   | FMC_BA+ 0x04 | R/W | ISP Address Register | 0x0000_0000 |

Table 6-7 ISP Address Register (ISPADR, address 0x5000\_C004)

| Bits   | Descriptions  |                                                                                                                                                                                                                                  |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>ISPADR</b> | <b>ISP Address Register</b><br>This is the memory address register that a subsequent ISP command will access. ISP operation are carried out on 32bit words only, consequently ISPARD[1:0] must be 00b for correct ISP operation. |

ISP Data Register (ISPDAT)

| Register | Offset       | R/W | Description       | Reset Value |
|----------|--------------|-----|-------------------|-------------|
| ISPDAT   | FMC_BA+ 0x08 | R/W | ISP Data Register | 0x0000_0000 |

Table 6-8 ISP Data Register (ISPDAT, address 0x5000\_C008)

| Bits   | Descriptions  |                                                                                                                                                      |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>ISPDAT</b> | <b>ISP Data Register</b><br>Write data to this register before an ISP program operation.<br>Read data from this register after an ISP read operation |

ISP Command (ISPCMD)

| Register | Offset       | R/W | Description          | Reset Value |
|----------|--------------|-----|----------------------|-------------|
| ISPCMD   | FMC_BA+ 0x0C | R/W | ISP Command Register | 0x0000_0000 |

Table 6-9 ISP Data Register (ISPCMD, address 0x5000\_C00C)

| Bits           | Descriptions |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
|----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|---------|------|------|------|---------|------|------------|------|----------|------|----------|------|
| [31:6]         | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                               |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| [5:0]          | ISPCMD       | <p><b>ISP Command</b></p> <table border="1"> <tr> <td>Operation Mode</td> <td>ISPCMD</td> </tr> <tr> <td>Standby</td> <td>0x3X</td> </tr> <tr> <td>Read</td> <td>0x00</td> </tr> <tr> <td>Program</td> <td>0x21</td> </tr> <tr> <td>Page Erase</td> <td>0x22</td> </tr> <tr> <td>Read CID</td> <td>0x0B</td> </tr> <tr> <td>Read DID</td> <td>0x0C</td> </tr> </table> | Operation Mode | ISPCMD | Standby | 0x3X | Read | 0x00 | Program | 0x21 | Page Erase | 0x22 | Read CID | 0x0B | Read DID | 0x0C |
| Operation Mode | ISPCMD       |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| Standby        | 0x3X         |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| Read           | 0x00         |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| Program        | 0x21         |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| Page Erase     | 0x22         |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| Read CID       | 0x0B         |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |
| Read DID       | 0x0C         |                                                                                                                                                                                                                                                                                                                                                                        |                |        |         |      |      |      |         |      |            |      |          |      |          |      |

ISP Trigger Control Register (ISPTRG)

The ISPTRG register is a protected register, user must first follow the unlock sequence ([see Protected Register Lock Key Register \(REGLOCK\)](#)) to gain access.

| Register | Offset       | R/W | Description                  | Reset Value |
|----------|--------------|-----|------------------------------|-------------|
| ISPTRG   | FMC_BA+ 0x10 | R/W | ISP Trigger Control Register | 0x0000_0000 |

Table 6-10 ISP Trigger Control Register (ISPTRG, address 0x5000\_C010)

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [0]    | ISPGO        | <p><b>ISP Start Trigger</b></p> <p>Write 1 to start ISP operation. This will be cleared to 0 by hardware automatically when ISP operation is finished.</p> <p>1 = ISP is on going<br/>0 = ISP operation is finished</p> <p>After triggering an ISP function M0 instruction pipeline should be flushed with a ISB instruction to guarantee data integrity.</p> <p>This is a protected register, user must first follow the unlock sequence (<a href="#">see Protected Register Lock Key Register (REGLOCK)</a>) to gain access.</p> |

Data Flash Base Address Register (DFBADR)

| Register | Offset       | R/W | Description             | Reset Value |
|----------|--------------|-----|-------------------------|-------------|
| DFBADR   | FMC_BA+ 0x14 | R   | Data Flash Base Address | 0xXXXX_XXXX |

Table 6-11 Data Flash Base Address Register (DFBADR, address 0x5000\_C014)

| Bits   | Descriptions |                                                                                                                                                                                                                                       |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>DFBA</b>  | <b>Data Flash Base Address</b><br>This register reports the data flash starting address. It is a read only register.<br>Data flash size is defined by user configuration, register content is loaded from Config1 when chip is reset. |

## 7 ANALOG SIGNAL PATH BLOCKS

This section describes the functional blocks that perform analog signal functions on the ISD9160. This includes the ADC, DPWM Speaker Driver, PGA Gain Amplifier, Automatic Gain Control and a variety of auxiliary analog functional blocks.

### 7.1 Audio Analog-to-Digital Converter (ADC)

#### 7.1.1 Functional Description

The ISD9160 includes a 2<sup>nd</sup> Order Delta-Sigma Audio Analog-to-Digital converter providing SNR >85dB and THD >70dB. The converter can run at sampling rates up to 6.144MHz while a configurable decimation filter allows oversampling ratios of 64/128/192 and 384. This provides support for standard audio sampling rates from 8kHz to 48kHz.

#### 7.1.2 Features

- Front-end PGA providing gain range of -12dB – 35dB.
- Boost Gain stage of 0dB or 26dB.
- Configurable OSR (Over Sampling Ratio) of 64/128/192/384
- Configurable clock rate through master oscillator integer division.
- Decimation signal can be used directly or passed to biquad filter for further filtering.
- Audio data buffered to 8 word FIFO, accessible via APB and PDMA.

#### 7.1.3 Block Diagram



Figure 7-1 ADC Signal Path Block Diagram



Figure 7-2 ADC Clock Control

### 7.1.4 Operation

The ADC is an Audio Delta-Sigma converter that operates by oversampling the analog input at low resolution and decimating the result by an over-sampling ratio to obtain a high resolution output which is pushed into the FIFO. The ultimate data rate is determined by the converter clock frequency SDCLK, and the oversampling ratio.

The data stream generated by the ADC is most conveniently handled by PDMA which can load data into a streaming audio buffer for further processing. Alternatively an interrupt driven approach can be used to monitor the FIFO.

If FIFO is not serviced then oldest data is over-written such that the FIFO always contains the eight most recent samples.

#### 7.1.4.1 Determining Sample Rate

The maximum clock rate of the Delta-Sigma Converter is 6.144MHz. Best performance is gained with clocks rates between 1.024MHz and 4.096MHz. Sample rate is given by the following formula:

$$F_s = HCLK \div CLK\_DIV \div OSR$$

Tables of common audio sample rates are provided below.

Table 7-1 Sample Rates for HCLK=49.152MHz

| HCLK=49.152MHz | SD_CLK    | Sample Rate (Hz) for OSR |        |        |        |
|----------------|-----------|--------------------------|--------|--------|--------|
|                |           | 64                       | 128    | 192    | 384    |
| 8              | 6,144,000 | 96,000                   | 48,000 | 32,000 | 16,000 |
| 16             | 3,072,000 | 48,000                   | 24,000 | 16,000 | 8,000  |
| 24             | 2,048,000 | 32,000                   | 16,000 | 10,667 | 5,333  |
| 32             | 1,536,000 | 24,000                   | 12,000 | 8,000  | 4,000  |
| 48             | 1,024,000 | 16,000                   | 8,000  | 5,333  | 2,667  |

Table 7-2 Sample Rates for HCLK=32.768MHz

| HCLK=32.768MHz | SD_CLK    | Sample Rate (Hz) for OSR |        |        |        |
|----------------|-----------|--------------------------|--------|--------|--------|
|                |           | 64                       | 128    | 192    | 384    |
| 8              | 4,096,000 | 64,000                   | 32,000 | 21,333 | 10,667 |
| 16             | 2,048,000 | 32,000                   | 16,000 | 10,667 | 5,333  |
| 24             | 1,365,333 | 21,333                   | 10,667 | 7,111  | 3,556  |
| 32             | 1,024,000 | 16,000                   | 8,000  | 5,333  | 2,667  |

Table 7-3 Sample Rates for HCLK=24.576MHz

| HCLK=24.576MHz | SD_CLK    | Sample Rate (Hz) for OSR |        |        |       |
|----------------|-----------|--------------------------|--------|--------|-------|
|                |           | 64                       | 128    | 192    | 384   |
| 8              | 3,072,000 | 48,000                   | 24,000 | 16,000 | 8,000 |
| 12             | 2,048,000 | 32,000                   | 16,000 | 10,667 | 5,333 |
| 16             | 1,536,000 | 24,000                   | 12,000 | 8,000  | 4,000 |
| 24             | 1,024,000 | 16,000                   | 8,000  | 5,333  | 2,667 |

Table 7-4 Sample Rates for HCLK=16.384MHz

| HCLK=16.384MHz | SD_CLK    | Sample Rate (Hz) for OSR |        |        |        |
|----------------|-----------|--------------------------|--------|--------|--------|
|                |           | 64                       | 128    | 192    | 384    |
| 4              | 4,096,000 | 64,000                   | 32,000 | 21,333 | 10,667 |
| 8              | 2,048,000 | 32,000                   | 16,000 | 10,667 | 5,333  |
| 16             | 1,024,000 | 16,000                   | 8,000  | 5,333  | 2,667  |
| 24             | 682,667   | 10,667                   | 5,333  | 3,556  | 1,778  |
| 32             | 512,000   | 8,000                    | 4,000  | 2,667  | 1,333  |

#### 7.1.4.2 Configuring Analog Path

To operate the ADC the entire analog path from analog input to ADC needs to be configured for correct operation. This involves:

- Selecting and powering up VMID reference.
- Powering up modulator and reference buffers.
- Selecting an input source with the analog MUX.
- Configure sample rate and ADC clock source.

#### 7.1.4.3 Interrupt Sources

The ADC can be configured to generate an interrupt when the data level in the FIFO exceeds a defined threshold. The interrupt condition is only cleared by disabling the interrupt or reading values from the FIFO. In addition two comparators can monitor the ADC FIFO output to generate interrupts when set levels are exceeded.



Figure 7-3 SDADC Controller Interrupt

#### 7.1.4.4 Peripheral DMA Request

Normal use of the ADC is with PDMA. In this mode ADC requests PDMA service whenever data is in FIFO. PDMA channel will copy this data to a buffer and alert the CPU when buffer is full. In this way an entire buffer of data can be collected without any CPU intervention.

#### 7.1.5 ADC Register Map

R: read only, W: write only, R/W: both read and write, C: Only value 0 can be written

| Register                    | Offset      | R/W | Description                       | Reset Value | Reference                  |
|-----------------------------|-------------|-----|-----------------------------------|-------------|----------------------------|
| <b>ADC_BA = 0x400E_0000</b> |             |     |                                   |             |                            |
| ADCOUT                      | ADC_BA+0x00 | R   | FIFO Data Out.                    | 0x0000_XXXX | <a href="#">Table 7-5</a>  |
| EN                          | ADC_BA+0x04 | R/W | ADC Enable Register               | 0x0000_0000 | <a href="#">Table 7-6</a>  |
| CLK_DIV                     | ADC_BA+0x08 | R/W | ADC Clock Divider Register        | 0x0000_0000 | <a href="#">Table 7-7</a>  |
| DEC                         | ADC_BA+0x0C | R/W | ADC Decimation Control Register   | 0x0000_0000 | <a href="#">Table 7-8</a>  |
| INT                         | ADC_BA+0x10 | R/W | ADC Interrupt Control Register    | 0x0000_0000 | <a href="#">Table 7-9</a>  |
| ADCPDMA                     | ADC_BA+0x14 | R/W | ADC PDMA Control Register         | 0x0000_0000 | <a href="#">Table 7-10</a> |
| ADCMPR[0]                   | ADC_BA+0x18 | R/W | ADC Comparator 0 Control Register | 0x0000_0000 | <a href="#">Table 7-11</a> |
| ADCMPR[1]                   | ADC_BA+0x1C | R/W | ADC Comparator 1 Control Register | 0x0000_0000 | <a href="#">Table 7-11</a> |

### 7.1.6 ADC Register Description

#### FIFO Audio Data Register (ADCOUT)

| Register | Offset      | R/W | Description              | Reset Value |
|----------|-------------|-----|--------------------------|-------------|
| ADCOUT   | ADC_BA+0x00 | R   | ADC Audio Data FIFO Read | 0x0000_XXXX |

Table 7-5 FIFO Audio Data Register (ADCOUT, address 0x400E\_0000)

| Bits    | Descriptions |                                                                                                                                                                                                                                                                   |
|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved     | 0x0000                                                                                                                                                                                                                                                            |
| [15:0]  | ADCOUT       | <b>ADC Audio Data FIFO read.</b><br>A read of this register will read data from the audio FIFO and increment the read pointer. A read past empty will repeat the last data. Can be used with FIFO_IE_LEV interrupt to determine if valid data is present in FIFO. |

#### ADC Enable Register (EN)

| Register | Offset      | R/W | Description         | Reset Value |
|----------|-------------|-----|---------------------|-------------|
| EN       | ADC_BA+0x04 | R/W | ADC Enable Register | 0x0000_0000 |

Table 7-6 ADC Enable Register (EN, address 0x400E\_0004)

| Bits   | Descriptions |                                                                                                                      |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved     | -                                                                                                                    |
| [0]    | EN           | <b>ADC Enable</b><br>1 = ADC Conversion enabled.<br>0 = Conversion stopped and ADC is reset including FIFO pointers. |

ADC Clock Division Register (CLK\_DIV)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| CLK_DIV  | ADC_BA+0x08 | R/W | ADC Converter Clock Divider | 0x0000_0000 |

Table 7-7 ADC Clock Divider Register (CLK\_DIV, address 0x400E\_0008)

| Bits   | Descriptions   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [7:0]  | <b>CLK_DIV</b> | <p><b>ADC Clock Divider</b></p> <p>This register determines the clock division ratio between the incoming ADC_CLK (=HCLK by default) and the Delta-Sigma sampling clock of the ADC. This together with the over-sampling ratio (OSR) determines the audio sample rate of the converter.</p> <p>CLK_DIV should be set to give a SD_CLK frequency in the range of 1.024-6.144MHz.</p> <p>CLK_DIV must be greater than 2.</p> <p>SD_CLK frequency = HCLK ÷ CLK_DIV</p> |

ADC Decimation Control Register (DEC)

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| DEC      | ADC_BA+0x0C | R/W | ADC Decimation Control Register | 0x0000_0000 |

Table 7-8 ADC Decimation Control Register (DEC, address 0x400E\_000C)

| Bits    | Descriptions |                                                                                                                                                                                                                                                                      |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19:16] | <b>GAIN</b>  | <p><b>CIC Filter additional Gain.</b></p> <p>This should normally remain default 0. Can be set to non-zero values to provide additional digital gain from the decimation filter. An additional gain is applied to signal of GAIN÷2.</p>                              |
| [3:0]   | <b>OSR</b>   | <p><b>Decimation Over-Sampling Ratio</b></p> <p>This term determines the over-sampling ratio of the decimation filter. Valid values are:</p> <ul style="list-style-type: none"> <li>0: OSR=64</li> <li>1: OSR=128</li> <li>2: OSR=192</li> <li>3: OSR=384</li> </ul> |

ADC Interrupt Control Register (INT)

| Register | Offset      | R/W | Description                    | Reset Value |
|----------|-------------|-----|--------------------------------|-------------|
| INT      | ADC_BA+0x10 | R/W | ADC Interrupt Control Register | 0x0000_0000 |

Table 7-9 ADC Interrupt Control Register (INT, address 0x400E\_0010)

| Bits  | Descriptions      |                                                                                                                                                                                                            |
|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]  | <b>IE</b>         | <b>Interrupt Enable</b><br>If set to '1' an interrupt is generated whenever FIFO level exceeds that set in FIFO_IE_LEV.                                                                                    |
| [2:0] | <b>FIFO_IELEV</b> | <b>FIFO Interrupt Level</b><br>Determines at what level the ADC FIFO will generate a servicing interrupt to the CPU. Interrupt will be generated when number of words present in ADC FIFO is > FIFO_IELEV. |

ADC PDMA Control Register (ADCPDMA)

| Register | Offset      | R/W | Description               | Reset Value |
|----------|-------------|-----|---------------------------|-------------|
| ADCPDMA  | ADC_BA+0x14 | R/W | ADC PDMA Control Register | 0x0000_0000 |

Table 7-10 ADC PDMA Control Register (ADCPDMA, address 0x400E\_0014)

| Bits | Descriptions   |                                                                                                                               |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
| [0]  | <b>RxDmaEn</b> | <b>Enable ADC PDMA Receive Channel</b><br>Enable ADC PDMA. If set, then ADC will request PDMA service when data is available. |

A/D Compare Register 0/1 (ADCMPR0/1)

| Register  | Offset      | R/W | Description            |  |  |  | Reset Value |
|-----------|-------------|-----|------------------------|--|--|--|-------------|
| ADCMPR[0] | ADC_BA+0x18 | R/W | A/D Compare Register 0 |  |  |  | 0x0000_0000 |
| ADCMPR[1] | ADC_BA+0x1C | R/W | A/D Compare Register 1 |  |  |  | 0x0000_0000 |

|            |          |    |    |           |         |       |       |
|------------|----------|----|----|-----------|---------|-------|-------|
| 31         | 30       | 29 | 28 | 27        | 26      | 25    | 24    |
| CMPD[15:8] |          |    |    |           |         |       |       |
| 23         | 22       | 21 | 20 | 19        | 18      | 17    | 16    |
| CMPD[7:0]  |          |    |    |           |         |       |       |
| 15         | 14       | 13 | 12 | 11        | 10      | 9     | 8     |
| Reserved   |          |    |    | CMPPATCNT |         |       |       |
| 7          | 6        | 5  | 4  | 3         | 2       | 1     | 0     |
| CMPF       | Reserved |    |    |           | CMPCOND | CMPIE | CPMEN |

Table 7-11 ADC Comparator Control Registers (ADCMPR[n], address 0x400E\_0018, 0x400E\_001C)

| Bits    | Descriptions     |                                                                                                                                                                                                                                                                                                                            |
|---------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>CMPD</b>      | <b>Comparison Data</b><br>16 bit value to compare to FIFO output word.                                                                                                                                                                                                                                                     |
| [11:8]  | <b>CMPPATCNT</b> | <b>Compare Match Count</b><br>When the A/D FIFO result matches the compare condition defined by CMPCOND, the internal match counter will increase by 1. When the internal counter reaches the value to (CMPPATCNT +1), the CMPF bit will be set.                                                                           |
| [7]     | <b>CMPF</b>      | <b>Compare Flag</b><br>When the conversion result meets condition in ADCMPR0 this bit is set to 1. It is cleared by writing 1 to self.                                                                                                                                                                                     |
| [2]     | <b>CMPCOND</b>   | <b>Compare Condition</b><br>1= Set the compare condition that result is greater or equal to CMPD<br>0= Set the compare condition that result is less than CMPD<br><b>Note:</b> When the internal counter reaches the value (CMPPATCNT +1), the CMPF bit will be set.                                                       |
| [1]     | <b>CMPIE</b>     | <b>Compare Interrupt Enable</b><br>1 = Enable compare function interrupt. 0 = Disable compare function interrupt.<br>If the compare function is enabled and the compare condition matches the setting of CMPCOND and CMPPATCNT, CMPF bit will be asserted, if CMPIE is set to 1, a compare interrupt request is generated. |

|     |              |                                                                                                                                      |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| [0] | <b>CMPEN</b> | <b>Compare Enable</b><br>1 = Enable compare. 0 = Disable compare.<br>Set this bit to 1 to enable compare CMPD with FIFO data output. |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------|

## 7.2 Audio Class D Speaker Driver (DPWM)

### 7.2.1 Functional Description

The ISD9160 includes a differential Class D (PWM) speaker driver capable of delivering 1W into an 8Ω load at 5V supply voltage. The driver works by up-sampling and modulating a PCM input to differentially drive the SPK+ and SPK- pins. The speaker driver operates from its own independent supply VCCSPK and VSSSPK. This supply should be well decoupled as peak currents from speaker driver are large.

### 7.2.2 Features

- Differential Bridge-Tied-Load structure to directly drive 8Ω Speaker.
- Power delivery up to 1W @5V into 8Ω.
- Power efficiency of up to 85%.
- Configurable input sample rate.
- 16 Sample FIFO for audio output.
- PDMA data channel for streaming of PCM audio data.

### 7.2.3 Block Diagram



Figure 7-4 DPWM Block Diagram

### 7.2.4 Operation

The DPWM block receives audio data by writing 16bit PCM audio to the FIFO. FIFO is accessed through PDMA for ease of streaming. The audio stream is sampled by a zero-order hold and fed to an up-sampling Cascaded Integrator Comb (CIC) filter with an up-sampling ratio of 64. The signal is then modulated and sent to the driver stage through a non-overlap circuit. Master clock rate of the Delta-Sigma modulator is controlled by DPWM\_CLK. This clock is generated by the internal oscillator (OSC48M) and operates at the frequency of OSC48M or 2x the frequency of OSC48M (See CLKSEL1 register [Table 5-36](#)). Ultimate SNR (Signal-to-Noise Ratio) is determined by the time resolution of the master clock.

#### 7.2.4.1 Determining Sample Rate

The sample rate at which the DPWM block consumes audio data is given by:

$$F_s = HCLK \div ZOH\_DIV \div 64$$

Where HCLK is the master CPU clock rate and ZOH\_DIV is the divider control register. A table of common audio sample rates is provided below.

Table 7-12 DPWM Sample Rates for Various HCLK

| HCLK (MHz) | ZOH_DIV | Sample Rate (Hz) |
|------------|---------|------------------|
| 49.152     | 24      | 32,000           |
| 49.152     | 48      | 16,000           |
| 49.152     | 96      | 8,000            |
| 32.768     | 16      | 32,000           |
| 32.768     | 32      | 16,000           |
| 32.768     | 64      | 8,000            |
| 24.576     | 12      | 32,000           |
| 24.576     | 24      | 16,000           |
| 24.576     | 48      | 8,000            |

#### 7.2.4.2 Configuring Speaker Driver

To operate the speaker driver the following configuration is recommended:

- Enable DPWM clock source (APBCLK.DPWM\_EN [Table 5-33](#), CLKSEL1.DPWM\_S [Table 5-36](#)).
- Reset DPWM IP block. (IPRSTC2.DPWM\_RST [Table 5-4](#))
- Select sample rate based on current HCLK frequency.
- Setup PDMA channel to provide data to DPWM.
- Enable PDMA Request.
- Enable Driver.

#### 7.2.4.3 Peripheral DMA Request

Normal use of the DPWM is with PDMA. In this mode DPWM requests PDMA service whenever there is space in FIFO. PDMA channel will copy data from a streaming buffer to the DPWM and alert the CPU when buffer is empty. In this way an entire buffer of data can be sent to DPWM without any CPU intervention.

### 7.2.5 DPWM Register Map

R: read only, W: write only, R/W: both read and write.

| Register                     | Offset       | R/W | Description                            | Reset Value | Reference                  |
|------------------------------|--------------|-----|----------------------------------------|-------------|----------------------------|
| <b>DPWM_BA = 0x4007_0000</b> |              |     |                                        |             |                            |
| <b>CTRL</b>                  | DPWM_BA+0x00 | R/W | DPWM Control Register.                 | 0x0000_0000 | <a href="#">Table 7-13</a> |
| <b>STAT</b>                  | DPWM_BA+0x04 | R   | DPWM FIFO Status                       | 0x0000_0002 | <a href="#">Table 7-14</a> |
| <b>DMA</b>                   | DPWM_BA+0x08 | R/W | DPWM PDMA Control Register             | 0x0000_0000 | <a href="#">Table 7-15</a> |
| <b>FIFO</b>                  | DPWM_BA+0x0C | W   | DPWM FIFO Input                        | 0x0000_0000 | <a href="#">Table 7-16</a> |
| <b>ZOH_DIV</b>               | DPWM_BA+0x10 | R/W | DPWM Zero Order Hold Division Register | 0x0000_0030 | <a href="#">Table 7-17</a> |

### 7.2.6 DPWM Register Description

#### DPWM Control Register (CTRL)

| Register | Offset       | R/W | Description           | Reset Value |
|----------|--------------|-----|-----------------------|-------------|
| CTRL     | DPWM_BA+0x00 | R/W | DPWM Control Register | 0x0000_0000 |

|          |        |        |          |      |   |   |   |
|----------|--------|--------|----------|------|---|---|---|
| 7        | 6      | 5      | 4        | 3    | 2 | 1 | 0 |
| Reserved | Enable | Dither | Deadtime | Freq |   |   |   |

Table 7-13 DPWM Control Register (DPWM->CTRL, address 0x4007\_0000)

| Bits  | Descriptions      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
|-------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------|------------------------------------|---|-----|---------|---|-----|---------|---|----|-----------|---|----|-----------|---|-----|---------|---|-----|---------|---|-----|---------|---|-----|---------|--|
| [6]   | <b>Enable</b>     | <b>DPWM Enable.</b><br>1: Enable DPWM, SPK pins are enabled and driven, data is taken from FIFO.<br>0: Disable DPWM, SPK pins are tri-state, CIC filter is reset, FIFO pointers are reset (FIFO data is not reset).                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| [5:4] | <b>Dither</b>     | <b>DPWM Signal Dither Control</b><br>To prevent structured noise on PWM output due to DC offsets in the input signal it is possible to add random dither to the PWM signal. These bits control the dither:<br>0: No dither.<br>1: $\pm 1$ bit dither<br>3: $\pm 2$ bit dither                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| [3]   | <b>Deadtime</b>   | <b>DPWM Driver Deadtime Control.</b><br>Enabling this bit will insert an additional clock cycle deadtime into the switching of PMOS and NMOS driver transistors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| [2:0] | <b>Freq</b>       | <b>DPWM Modulation Frequency.</b><br>This parameter controls the carrier modulation frequency of the PWM signal as a proportion of DPWM_CLK.<br><table border="1"><thead><tr><th>Freq</th><th>DPWM_CLK Division</th><th>Frequency for DPWM_CLK = 98.304MHz</th></tr></thead><tbody><tr><td>0</td><td>228</td><td>431,158</td></tr><tr><td>1</td><td>156</td><td>630,154</td></tr><tr><td>2</td><td>76</td><td>1,293,474</td></tr><tr><td>3</td><td>52</td><td>1,890,462</td></tr><tr><td>4</td><td>780</td><td>126,031</td></tr><tr><td>5</td><td>524</td><td>187,603</td></tr><tr><td>6</td><td>396</td><td>248,242</td></tr><tr><td>7</td><td>268</td><td>366,806</td></tr></tbody></table> | Freq | DPWM_CLK Division | Frequency for DPWM_CLK = 98.304MHz | 0 | 228 | 431,158 | 1 | 156 | 630,154 | 2 | 76 | 1,293,474 | 3 | 52 | 1,890,462 | 4 | 780 | 126,031 | 5 | 524 | 187,603 | 6 | 396 | 248,242 | 7 | 268 | 366,806 |  |
| Freq  | DPWM_CLK Division | Frequency for DPWM_CLK = 98.304MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 0     | 228               | 431,158                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 1     | 156               | 630,154                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 2     | 76                | 1,293,474                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 3     | 52                | 1,890,462                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 4     | 780               | 126,031                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 5     | 524               | 187,603                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 6     | 396               | 248,242                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |
| 7     | 268               | 366,806                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                   |                                    |   |     |         |   |     |         |   |    |           |   |    |           |   |     |         |   |     |         |   |     |         |   |     |         |  |

DPWM FIFO Status Register (STAT)

| Register | Offset       | R/W | Description               | Reset Value |
|----------|--------------|-----|---------------------------|-------------|
| STAT     | DPWM_BA+0x04 | R   | DPWM FIFO Status Register | 0x0000_0002 |

Table 7-14 DPWM FIFO Status Register (STAT, address 0x4007\_0004)

| Bits | Descriptions |                                                                |
|------|--------------|----------------------------------------------------------------|
| [1]  | <b>EMPTY</b> | FIFO Empty<br>1= FIFO is empty<br>0= FIFO is not empty         |
| [0]  | <b>FULL</b>  | <b>FIFO Full</b><br>1 = FIFO is full.<br>0 = FIFO is not full. |

DPWM PDMA Control Register (DMA)

| Register | Offset       | R/W | Description                | Reset Value |
|----------|--------------|-----|----------------------------|-------------|
| DMA      | DPWM_BA+0x08 | R/W | DPWM PDMA Control Register | 0x0000_0000 |

Table 7-15 DPWM PDMA Control Register (DMA, address 0x4007\_0008)

| Bits   | Descriptions      |                                                                                                                                                                                                |  |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:8] | Reserved          | -                                                                                                                                                                                              |  |
| [0]    | <b>EnablePDMA</b> | <b>Enable DPWM DMA Interface.</b><br>1= Enable PDMA. Block will request data from PDMA controller whenever FIFO is not empty.<br>0= Disable PDMA. No requests will be made to PDMA controller. |  |

DPWM FIFO Input (FIFO)

| Register | Offset       | R/W | Description     | Reset Value |
|----------|--------------|-----|-----------------|-------------|
| FIFO     | DPWM_BA+0x0C | W   | DPWM FIFO Input | 0x0000_0000 |

Table 7-16 DPWM FIFO Input (FIFO, address 0x4007\_000C)

| Bits   | Descriptions |                                                                                                                                                                                    |  |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [15:0] | <b>FIFO</b>  | <b>DPWM FIFO Audio Data Input</b><br>A write to this register pushes data onto the DPWM FIFO and increments the write pointer. This is the address that PDMA writes audio data to. |  |

DPWM ZOH Division (ZOH\_DIV)

| Register | Offset       | R/W | Description                            | Reset Value |
|----------|--------------|-----|----------------------------------------|-------------|
| ZOH_DIV  | DPWM_BA+0x10 | R/W | DPWM Zero Order Hold Division Register | 0x0000_0030 |

Table 7-17 DPWM Zero Order Hold Division Register (FIFO, address 0x4007\_0010)

| Bits  | Descriptions   |                                                                                                                                                                                                                                                                                                                                        |  |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [7:0] | <b>ZOH_DIV</b> | <b>DPWM Zero Order Hold, down-sampling divisor.</b><br>The input sample rate of the DPWM is set by HCLK frequency and the divisor set in this register by the following formula:<br>$F_s = HCLK \div ZOH_{DIV} \div 64$<br>Valid range is 1,...,255. Default is 48, which gives a sample rate of 16kHz for a 49.152MHz (default) HCLK. |  |

## 7.3 Analog Comparator

### 7.3.1 Functional Description

ISD9160 contains two analog comparators. The comparator output is a logical one when positive input greater than negative input, otherwise the output is a zero. Each comparator can be configured to cause an interrupt when the comparator output value changes. The block diagram is shown in Figure 7-5.

Note that the analog input port pins must be configured as input type or analog alternate function before Analog Comparator function is enabled.

### 7.3.2 Features

- Analog input voltage range: 0~5.0V
- Comparator 0 multiplexed to all analog enabled GPIO (GPIOB[7:0]).
- Comparator 0 can compare against VMID or VBG.
- Comparator 1 can compare GPIOB[7] to GPIOB[6] or VBG.
- Single comparator interrupt requested by either comparator.
- Can be used in conjunction with Capacitive Touch Sensing block for capacitive touch sensing.

### 7.3.3 Block Diagram



Figure 7-5 Analog Comparator Block Diagram

### 7.3.4 Operational Procedure

#### Setup Procedure

To use the Analog Comparator block, use the following sequence:

1. Configure GPIO for use as analog input by setting type to input.
2. Enable the peripheral clock (SYSCLK->APBCLK.ACMP\_EN)
3. Reset the Comparator block (SYS->IPRSTC2.ACMP\_RST, [Table 5-4](#))
4. If using VMID ensure that VMID block is powered up ([Section 7.4.4](#))
5. Select comparison sources with CMPnCR and CMPSEL.
6. Enable comparators and appropriate interrupts with CMPnCR.
7. Enables system interrupt if appropriate (e.g. NVIC\_EnableIRQ(ACMP IRQn); )

#### Interrupt Sources

The comparator generates an output  $COn$  ( $n=0,1$ ) which is reported in CMPSR register. If  $CMPnCR.IE$  bit is set then a state change on the comparator output  $COn$  will cause comparator flag  $CMPFn$  to go high and the comparator interrupt is requested. Software can write a one to  $CMPFn$  to clear flag and interrupt request.



Figure 7-6 Comparator Controller Interrupt Sources

### 7.3.5 Register Map

R: read only, W: write only, R/W: both read and write

| Register                     | Offset       | R/W | Description           | Reset Value | Reference                  |
|------------------------------|--------------|-----|-----------------------|-------------|----------------------------|
| <b>ACMP_BA = 0x400D_0000</b> |              |     |                       |             |                            |
| <b>CMPCCR[0]</b>             | ACMP_BA+0x00 | R/W | CMP0 Control Register | 0x0000_0000 | <a href="#">Table 7-18</a> |
| <b>CMPCCR[1]</b>             | ACMP_BA+0x04 | R/W | CMP1 Control Register | 0x0000_0000 | <a href="#">Table 7-19</a> |
| <b>CMPSR</b>                 | ACMP_BA+0x08 | R/W | CMP Status Register   | 0x0000_00XX | <a href="#">Table 7-20</a> |
| <b>CMPSEL</b>                | ACMP_BA+0x0C | R/W | CMP Select Register   | 0x0000_0000 | <a href="#">Table 7-21</a> |

### 7.3.6 Register Description

#### Comparator 0 Control Register (CMPCR[0])

| Register | Offset      | R/W | Description                   |  |  |  |  | Reset Value |
|----------|-------------|-----|-------------------------------|--|--|--|--|-------------|
| CMPCR[0] | CMP_BA+0x00 | R/W | Comparator 0 Control Register |  |  |  |  | 0x0000_0000 |

| 7 | 6 | 5 | 4            | 3 | 2 | 1            | 0            |
|---|---|---|--------------|---|---|--------------|--------------|
| - | - | - | <b>CMPCN</b> | - |   | <b>CMPIE</b> | <b>CMPEN</b> |

Table 7-18 Comparator 0 Control Register (CMPCR[0], address 0x400D\_0000).

| Bits | Descriptions |                                                                                                                              |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------|
| [4]  | <b>CMPCN</b> | <b>Comparator0 negative input select</b><br>1 = VMID reference voltage = VCCA/2<br>0 = VBG, Bandgap reference voltage = 1.2V |
| [1]  | <b>CMPIE</b> | <b>CMP0 Interrupt Enable</b><br>1 = Enable CMP0 interrupt function<br>0 = Disable CMP0 interrupt function                    |
| [0]  | <b>CMPEN</b> | <b>Comparator Enable</b><br>1 = Enable<br>0 = Disable                                                                        |

Comparator 1 Control Register (CMPCR[1])

| Register | Offset      | R/W | Description                   |  |  |  | Reset Value |
|----------|-------------|-----|-------------------------------|--|--|--|-------------|
| CMPCR[1] | CMP_BA+0x04 | R/W | Comparator 1 Control Register |  |  |  | 0x0000_0000 |

| 7 | 6 | 5 | 4            | 3 | 2 | 1            | 0            |
|---|---|---|--------------|---|---|--------------|--------------|
| - | - | - | <b>CMPCN</b> | - |   | <b>CMPIE</b> | <b>CMPEN</b> |

Table 7-19 Comparator 1 Control Register (CMPCR[1], address 0x400D\_0004).

| Bits | Descriptions |                                                                                                          |
|------|--------------|----------------------------------------------------------------------------------------------------------|
| [4]  | <b>CMPCN</b> | <b>Comparator1 negative input select</b><br>1 = VBG, Bandgap reference voltage = 1.2V<br>0 = GPIOB[7]    |
| [1]  | <b>CMPIE</b> | <b>CMP1 Interrupt Enable</b><br>1 = Enable CMP1 interrupt function<br>0 = Disable CMP1interrupt function |
| [0]  | <b>CMPEN</b> | <b>Comparator Enable</b><br>1 = Enable<br>0 = Disable                                                    |

CMP Status Register (CMPSR)

| Register | Offset      | R/W | Description         |  |  |  | Reset Value |
|----------|-------------|-----|---------------------|--|--|--|-------------|
| CMPSR    | CMP_BA+0x08 | R/W | CMP Status Register |  |  |  | undefined   |

|          |   |   |     |   |     |   |        |  |
|----------|---|---|-----|---|-----|---|--------|--|
| 7        | 6 | 5 | 4   | 3 | 2   | 1 | 0      |  |
| Reserved |   |   | CO1 |   | CO0 |   | CMPPF1 |  |

Table 7-20 CMP Status Register (CMPSR, address 0x400D\_0008).

| Bits | Descriptions |                                                                                                                                                                                                            |  |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [3]  | CO1          | <b>Comparator1 Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the comparator is disabled (CMP1EN = 0).                                                             |  |
| [2]  | CO0          | <b>Comparator0 Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the comparator is disabled (CMP0EN = 0).                                                             |  |
| [1]  | CMPF1        | <b>Compare 1 Flag</b><br>This bit is set by hardware whenever the comparator output changes state. This bit will cause a hardware interrupt if enabled. <b>This bit is cleared by writing 1 to itself.</b> |  |
| [0]  | CMPF0        | <b>Compare 0 Flag</b><br>This bit is set by hardware whenever the comparator output changes state. This bit will cause a hardware interrupt if enabled. <b>This bit is cleared by writing 1 to itself.</b> |  |

CMP Select Register (CMPSEL)

| Register | Offset      | R/W | Description         |  | Reset Value |
|----------|-------------|-----|---------------------|--|-------------|
| CMPSEL   | CMP_BA+0x0C | R/W | CMP Select Register |  | 0x0000_0000 |

Table 7-21 CMP Select Register (CMPSEL, address 0x400D\_000C).

| Bits  | Descriptions |                                                                                                                             |  |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------|--|
| [2:0] | CMPSEL       | <b>Comparator0 GPIO Selection</b><br>GPIOB[CMPSEL] is the active analog GPIO input selected to Comparator 0 positive input. |  |

**7.4 Analog Functional Blocks**

### 7.4.1 Overview

The ISD9160 contains a variety of analog functional blocks that facilitate audio processing, enable analog GPIO functions (current source, relaxation oscillator, and comparator), adjust and measure internal oscillator and provide voltage regulation. These blocks are controlled by registers in the analog block address space. This section describes these functions and registers.

### 7.4.2 Features

- VMID reference voltage generation.
- Current source generation for AGPIO (Analog enabled GPIO).
- LDO control for GPIOA[7:0] power domain and external device use.
- Microphone Bias generator.
- Analog Multiplexor.
- Programmable Gain Amplifier (PGA).
- OSC48M Frequency Control.
- Capacitive Touch Sensing Relaxation Oscillator.
- Oscillator Frequency Measurement block.

### 7.4.3 Register Map

R: read only, W: write only, R/W: read/write

| Register                    | Offset      | R/W | Description                         | Reset Value | Reference                     |
|-----------------------------|-------------|-----|-------------------------------------|-------------|-------------------------------|
| <b>ANA_BA = 0x4008_0000</b> |             |     |                                     |             |                               |
| <b>VMID</b>                 | ANA_BA+0x00 | R/W | VMID Reference Control Register     | 0x0000_0007 | <a href="#">Table 7-22</a>    |
| <b>ISRC</b>                 | ANA_BA+0x08 | R/W | Current Source Control Register     | 0x0000_0000 | <a href="#">Table 7-23</a>    |
| <b>LDOSET</b>               | ANA_BA+0x20 | R/W | LDO Voltage Select Register         | 0x0000_0000 | <a href="#">Table 7-24</a>    |
| <b>LDOPD</b>                | ANA_BA+0x24 | R/W | LDO Power Down Register             | 0x0000_0001 | <a href="#">Table 7-25</a>    |
| <b>MICBSEL</b>              | ANA_BA+0x28 | R/W | Microphone Bias Select Register     | 0x0000_0000 |                               |
| <b>MICBEN</b>               | ANA_BA+0x2C | R/W | Microphone Bias Enable Register     | 0x0000_0000 | <a href="#">Table 7-27</a>    |
| <b>VSET</b>                 | ANA_BA+0x38 | R/W | Logic Power Control Register        | 0x0000_0000 | <a href="#">Do Not Modify</a> |
| <b>TMPOWER</b>              | ANA_BA+0x3C | R/W | Power Test Mode Register            | 0x0000_0000 | <a href="#">Do Not Modify</a> |
| <b>TMANALOG</b>             | ANA_BA+0x40 | R/W | Analog Test Mode Register           | 0x0000_0000 | <a href="#">Do Not Modify</a> |
| <b>AMUX</b>                 | ANA_BA+0x50 | R/W | Analog Multiplexer Control Register | 0x0000_0000 | <a href="#">Table 7-28</a>    |
| <b>PGAEN</b>                | ANA_BA+0x60 | R/W | PGA Enable Register                 | 0x0000_0000 | <a href="#">Table 7-31</a>    |
| <b>PGAMUTE</b>              | ANA_BA+0x64 | R/W | PGA Mute Register                   | 0x0000_0000 |                               |
| <b>PGASEL</b>               | ANA_BA+0x68 | R/W | PGA Gain Select Register            | 0x0000_0010 | <a href="#">Table 7-33</a>    |
| <b>PGASCK</b>               | ANA_BA+0x6C | R/W |                                     | 0x0098_00ff |                               |

|                  |             |     |                                                        |             |                               |
|------------------|-------------|-----|--------------------------------------------------------|-------------|-------------------------------|
| <b>TMOSC</b>     | ANA_BA+0x80 | R/W | Oscillator Test Mode Register                          | 0x0000_0000 | <a href="#">Do Not Modify</a> |
| <b>TRIM</b>      | ANA_BA+0x84 | R   | Oscillator Trim Setting                                | 0x0000_xxxx |                               |
| <b>CAPS_CTRL</b> | ANA_BA+0x8C | R/W | Capacitive Touch Sensing Relaxation Oscillator Control | 0x0000_0000 | <a href="#">Table 7-34</a>    |
| <b>CAPS_CNT</b>  | ANA_BA+0x90 | R   | Capacitive Touch Sensing Relaxation Oscillator Count   | 0x0000_0000 | <a href="#">Table 7-35</a>    |
| <b>FREQ_CTRL</b> | ANA_BA+0x94 | R/W | Oscillator Frequency Measurement Control               | 0x0000_0001 | <a href="#">Table 7-37</a>    |
| <b>FREQ_CNT</b>  | ANA_BA+0x98 | R   | Oscillator Frequency Measurement Count                 | 0x0000_0000 | <a href="#">Table 7-38</a>    |

#### 7.4.4 VMID Reference Voltage Generation

The analog path and blocks require a low noise, mid-rail, Voltage reference for operation, the VMID generation block provides this. Control of this block allows user to power down the block, select its power down condition and control over the reference impedance. The block consists of a switchable resistive divider connected to the device VMID pin. A  $4.7\mu F$  capacitor should be placed on this pin and returned to analog ground (VSSA) as shown in Figure 7-7.

Before using the ADC, PGA or other analog blocks, the VMID reference needs to be enabled. A low impedance option allows fast charging of the external noise de-coupling capacitor, while a higher impedance options provides lower power consumption. A pulldown option allows the reference to be discharged when off.



Figure 7-7 VMID Reference Generation

#### VMID Control Register (ANA->VMID)

| Register | Offset      | R/W | Description            | Reset Value |
|----------|-------------|-----|------------------------|-------------|
| VMID     | ANA_BA+0x00 | R/W | VMID Control Register. | 0x0000_0007 |

|          |   |   |   |   |   |         |         |          |
|----------|---|---|---|---|---|---------|---------|----------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1       | 0       |          |
| Reserved |   |   |   |   |   | PDHIRES | PDLORES | PULLDOWN |

Table 7-22 VMID Control Register (VMID, address 0x4008\_0000).

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                         |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]  | PDHIRES      | <b>Power Down High (<math>360k\Omega</math>) Resistance Reference.</b><br>1: The High Resistance reference is disconnected from VMID. Default power down and reset condition.<br>0: Connect the High Resistance reference to VMID. Use this setting for minimum power consumption.                                      |
| [1]  | PDLORES      | <b>Power Down Low (<math>4.8k\Omega</math>) Resistance Reference.</b><br>1: The Low Resistance reference is disconnected from VMID. Default power down and reset condition.<br>0: Connect the Low Resistance reference to VMID. Use this setting for fast power up of VMID. Can be turned off after 50ms to save power. |
| [0]  | PULLDOWN     | <b>VMID Pulldown.</b><br>1: Pull VMID pin to ground. Default power down and reset condition.<br>0: Release VMID pin for reference operation.                                                                                                                                                                            |

#### 7.4.5 GPIO Current Source Generation

The GPIOB port consists of analog enabled GPIO. One of the features of these pins is the ability to route a current source to the pin. This is useful for a variety of purposes such as providing a current load to a sensor such as a photo-transistor or CDS cell. It can also be used to do capacitive touch sensing in combination with the relaxation oscillator control circuit.

The current generation block consists of a programmable current source controlled by ISRC.VAL and individual switches to each of the GPIOB pins as shown in Figure 7-8. Power control for this block is merged with the analog comparator, this block must be enabled to use current source (ACMP->CMP0CR.EN=1).

Analog peripheral clock must be enabled before register can be written. At least one of the analog comparators must be enabled to enable current source.



Figure 7-8 GPIOB Current Source Generation

#### Current Source Control Register (ANA->ISRC)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| ISRC     | ANA_BA+0x08 | R/W | GPIO Current Source Control Register. | 0x0000_0000 |

  

|          |    |    |    |    |    |     |   |
|----------|----|----|----|----|----|-----|---|
| 15       | 14 | 13 | 12 | 11 | 10 | 9   | 8 |
| Reserved |    |    |    |    |    | VAL |   |
| 7        | 6  | 5  | 4  | 3  | 2  | 1   | 0 |
| EN[7:0]  |    |    |    |    |    |     |   |

Table 7-23 GPIO Current Source Control Register (ISRC, address 0x4008\_0008).

| Bits    | Descriptions |                                                                                                                                                                                                     |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved     | Reserved                                                                                                                                                                                            |
| [9:8]   | VAL          | <b>Current Source Value.</b> Select master current for source generation<br>3=5µA., 2= 2.5µA, 1= 1µA, 0= 0.5µA                                                                                      |
| [7:0]   | EN[x]        | <b>Enable Current Source to GPIOB[x]</b><br>Individually enable current source to GPIOB pins. Each GPIOB pin has a separate current source.<br>1: Enable current source to pin GPIOB[x], 0: Disable |

#### 7.4.6 LDO Power Domain Control

The ISD9160 provides a Low Dropout Regulator (LDO) that provides power to the I/O domain of GPIOA[7:0]. Using this regulator device can operate from a 5V supply rail and generate a 2.4-3.3V regulated supply to operate the GPIOA[7:0] domain and external loads up to 30mA. The supply pin for the LDO is the VCCLDO pin which should be connected to VCCD. If the LDO is not used, both VCCLDO and VD33 should be tied to VCCD. Upon POR or reset the default condition of the LDO is off, meaning supply will be high impedance. Software must configure the LDO before GPIOA[7:0] is usable (unless VD33=VCCD).



Figure 7-9 LDO Power Domain

#### LDO Voltage Control Register (ANA->LDOSSET)

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| LDOSSET  | ANA_BA+0x20 | R/W | LDO Voltage Control Register | 0x0000_0000 |

Table 7-24 LDO Voltage Control Register (LDOSSET, address 0x4008\_0020).

| Bits   | Descriptions |                                                                                                                                                      |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved     | Reserved                                                                                                                                             |
| [1:0]  | LDOSSET      | <b>Select LDO Output Voltage.</b> Note that maximum I/O pad operation speed only specified for voltage >2.4V.<br>3= 3.3V , 2= 2.4V, 1= 1.8V, 0= 3.0V |

#### LDO Power Down Register (ANA->LDOPD)

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| LDOPD    | ANA_BA+0x24 | R/W | LDO Power Down Control Register | 0x0000_0001 |

|          |   |   |   |   |   |       |    |
|----------|---|---|---|---|---|-------|----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1     | 0  |
| Reserved |   |   |   |   |   | DISCH | PD |

Table 7-25 LDO Power Down Control Register (LDOPD, address 0x4008\_0024).

| Bits | Descriptions |                                                                                                        |
|------|--------------|--------------------------------------------------------------------------------------------------------|
| [1]  | DISCH        | 1: Switch discharge resistor to VD33. 0: No load on VD33                                               |
| [0]  | PD           | <b>Power Down LDO.</b> When powered down no current delivered to VD33.<br>1= Power Down. 0: Enable LDO |

#### 7.4.7 Microphone Bias Generator

The ISD9160 provides a microphone bias generator (MICBIAS) for improved recording quality. The MICBIAS can provide a maximum current of 1mA with a -60dB power supply rejection. The MICBIAS output voltage can be configured with MICBSEL[1:0] to select bias voltages from 50% to 90% of the VCCA supply voltage (see description below). The user should consider the microphone manufacturers specification in deciding on the optimum MICBIAS voltage to use. Generally, a microphone will require a current of 0.1mA to a maximum 0.5mA and a voltage of 1V to 3V across it.

Referring to the application diagram of Figure 7-11, external resistor  $R_1$  and  $R_2$  values are selected to limit the current to a maximum that can be provided by MICBIAS; 1mA. On the ISD9160, the minimum total resistance ( $R_1 + R_2$ ) is 4Kohms. MICBIAS output voltage should be such that the following condition is met:

$$V_{MICBIAS} > V_s + (R_1 + R_2) \times I_{MIC}$$

where  $V_s$  is the desired voltage across the microphone from specification and  $I_{MIC}$  is the current through the microphone (0.1-0.5mA)

From Figure 7-11, MIC\_IN1 and MIC\_IN2 are AC coupled to the ISD9160 MIC+ and MIC- respectively for differential inputs. In single-ended operation, MIC\_IN1 should go to MIC- of the ISD9160.  $C_1$  and  $C_2$  are AC coupling capacitors. In single-ended application,  $R_2$  can be removed and  $R_1$  increased to at least 4Kohms. For improved performance, it is recommended to keep  $R_2$  to provide additional rejection from ground noise.



Figure 7-10 MICBIAS Block Diagram



Figure 7-11 MICBIAS Application Diagram

**Microphone Bias Select (ANA->MICBSEL)**

| Register | Offset      | R/W | Description                        | Reset Value |
|----------|-------------|-----|------------------------------------|-------------|
| MICBSEL  | ANA_BA+0x28 | R/W | Microphone Bias Selection Register | 0x0000_0000 |

Table 7-26 Microphone Bias Selection Register (MICBSEL, address 0x4008\_0028).

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:3] |              |                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| [2]    | REF          | Select reference source for MICBIAS generator. VMID provides superior noise performance for MICBIAS generation and should be used unless fixed voltage is absolutely necessary, then noise performance can be sacrificed and bandgap voltage used as reference.<br>0: VMID = VCCA/2 is reference source.<br>1: VBG (bandgap voltage reference) is reference source. |  |  |
| [1:0]  | SEL          | Select Microphone Bias Voltage.<br><br>MICBMODE=0      MICBMODE=1<br><br>0: 90% VCCA      0: 2.4V<br>1: 65% VCCA      1: 1.7V<br>2: 75% VCCA      2: 2.0V<br>3: 50% VCCA      3: 1.3V                                                                                                                                                                               |  |  |

**Microphone Bias Enable Register (ANA->MICBEN)**

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| MICBEN   | ANA_BA+0x2C | R/W | Microphone Bias Enable Register | 0x0000_0000 |

|          |   |   |   |   |   |   |    |
|----------|---|---|---|---|---|---|----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
| Reserved |   |   |   |   |   |   | EN |

Table 7-27 Microphone Bias Enable Register (MICBEN, address 0x4008\_002C)

| Bits | Descriptions |                                                                   |
|------|--------------|-------------------------------------------------------------------|
|      |              |                                                                   |
| [0]  | MICBEN       | Enable Microphone Bias Generator.<br>1: Enabled. 0: Powered Down. |

### 7.4.8 Analog Multiplexer

The ISD9160 provides an analog multiplexer (AMUX) which allows the PGA input to be switched from the dedicated MICP/MICN analog inputs to any of the analog enabled GPIO (GPIOB[7:0]). The negative input of the PGA connects to GPIOB[7:0], while the positive PGA input connects to the odd numbered GPIOB[7:1]. Figure 7-12 shows the multiplexer block diagram and Table 7-28 shows the multiplexer control signals.



Figure 7-12 Analog Multiplexer Block Diagram

#### Analog Multiplexer Control Register (ANA->AMUX)

| Register | Offset      | R/W | Description                         | Reset Value |
|----------|-------------|-----|-------------------------------------|-------------|
| AMUX     | ANA_BA+0x50 | R/W | Analog Multiplexer Control Register | 0x0000_0000 |

|          |    |         |          |          |    |   |   |
|----------|----|---------|----------|----------|----|---|---|
| 15       | 14 | 13      | 12       | 11       | 10 | 9 | 8 |
| Reserved | EN | MIC_SEL | TEMP_SEL | MUXP_SEL |    |   |   |
| 7        | 6  | 5       | 4        | 3        | 2  | 1 | 0 |
| MUXN_SEL |    |         |          |          |    |   |   |

Table 7-28 Analog Multiplexer Control Register (AMUX, address 0x4008\_0050).

| Bits    | Symbol        | Descriptions                                                                                                                                                                                    |
|---------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:15] | Reserved      | Reserved                                                                                                                                                                                        |
| [14]    | EN            | Enable the analog multiplexer.<br>EN=0: All channels disabled<br>EN=1: Selection determined by register setting.                                                                                |
| [13]    | MIC_SEL       | Select MICP/MICN to PGA inputs                                                                                                                                                                  |
| [12]    | TEMP_SEL      | Select PTAT current, I_PTAT, to PGA_INN, negative input to PGA, for temperature measurement.                                                                                                    |
| [11:8]  | MUXP_SEL[3:0] | Selects connection of GPIOB[7,5,3,1] to PGA_INP, positive input of PGA.<br>1000b: GPIOB[7] connected to PGA_INP<br>0100b: GPIOB[5] connected to PGA_INP<br>0010b: GPIOB[3] connected to PGA_INP |

|       |               |                                                                                                                                |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------|
|       |               | 0001b: GPIOB[1] connected to PGA_INP                                                                                           |
| [7:0] | MUXN_SEL[7:0] | Selects connection of GPIOB[7:0] to PGA_INN, negative input of PGA.<br>If MUXN_SEL[n]=1 then GPIOB[n] is connected to PGA_INN. |

### Temperature Sensor Measurement

In addition, the multiplexer can route a PTC (positive temperature coefficient) current, PTAT current, to the ADC to perform temperature measurements. To configure the signal path to do temperature measurement, configure the ADC path as follows:

- 1) Enable the multiplexer, PGA, IPBOOST, and sigma-delta modulator. (See Section 7.4.9, Section 7.1).
- 2) Have the multiplexer select I\_PTAT current as input and choose VBG (bandgap voltage ) as reference (REF\_SEL).
- 3) Set the 6-bit PGA\_GAIN[5:0] gain value to hex 0x17 and choose 0dB gain setting for IPBOOST gain block.
- 4) The temperature can be inferred by the information given in Table 7-29 and equation below.

$$T (\text{°C}) = 27 + (\text{ADC\_VAL}-0x42EA)/50. \text{ (Equation 7-1)}$$

The settings corresponding to this configuration are:

ANA->SIGCTRL=0x1E, ANA->PGAEN=0x07, ANA->AMUX=0x5000, ANA->PGA\_GAIN=0x17

Table 7-29 Temperature Sensor Measurement.

| Parameter                                                                | Specification (Reference) |        |      |        | Test Condition   |
|--------------------------------------------------------------------------|---------------------------|--------|------|--------|------------------|
|                                                                          | Min.                      | Typ.   | Max. | Unit   |                  |
| Temperature Sensor Output                                                |                           | 0x42EA |      | Code   | At 27° C         |
| Temperature Sensor Delta Coefficient<br>(number of bits per degree °C)** |                           | 50     |      | LSB/°C | Relative to 27°C |

\*\*LSB is the least significant bit of a 16-bit ADC with a defined full-scale RMS input voltage of 0.77V

#### 7.4.9 Programmable Gain Amplifier

The ISD9160 provides a Programmable Gain Amplifier (PGA) as the front-end to the ADC to allow the adjustment of signal path gain. It is used in conjunction with the ALC block to provide automatic level control of incoming audio signals. Figure 7-13 shows the signal path diagram. The PGA provides a gain from -12dB to 35.25dB in increments of 0.75dB steps using a 6-bit control, PGA\_GAIN[5:0]. The gain is monotonically increasing with 0x00 for lowest gain (-12dB) and 0x3f for the maximum gain (35.25dB). The signal path is enabled by powering up the gain elements (PU\_PGA, PU\_IPBOOST). The PGA and IPBOOST blocks can be muted with the SIGCTRL register. Input to the PGA can be either differential or single-ended on the PGA\_INN input. The Analog MUX controls connection of the signal path to external pins. PGA input impedance varies based on the gain setting. Table 7-30 shows a table of input impedance for different gain setting.

The IPBOOST block can provide 0dB or 26dB of gain to provide a maximum gain of 61dB in the signal path. Front-end anti-alias filtering for the sigma-delta ADC is also provided by PGA/IPBOOST blocks with an attenuation of -45dB at 6MHz frequency. The signal path defaults to have VCCA/2 as the reference voltage.



Figure 7-13 PGA Signal Path Block Diagram



Figure 7-14 PGA Structure

Table 7-30 PGA Input Impedance Variation with Gain Setting

| Gain (dB)                  | -12 | -9 | -6 | -3 | 0  | 3  | 6  | 9  | 12 | 18 | 30  | 35.2 |
|----------------------------|-----|----|----|----|----|----|----|----|----|----|-----|------|
| <b>MICN Impedance (kΩ)</b> | 75  | 69 | 63 | 55 | 47 | 35 | 31 | 25 | 19 | 11 | 2.9 | 1.6  |
| <b>MICP Impedance (kΩ)</b> | 94  | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94  | 94   |

**PGA Enable Register (ANA->PGAEN)**

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| PGAEN    | ANA_BA+0x60 | R/W | PGA Enable and Control Register | 0x0000_0000 |

|          |   |   |   |           |          |        |         |
|----------|---|---|---|-----------|----------|--------|---------|
| 7        | 6 | 5 | 4 | 3         | 2        | 1      | 0       |
| Reserved |   |   |   | BOOSTGAIN | PU_BOOST | PU_PGA | REF_SEL |

Table 7-31 PGA Enable and Control Register (PGAEN, address 0x4008\_0060)

| Bits | Descriptions     |                                                                                                                                                                                                                                                                        |
|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]  | <b>BOOSTGAIN</b> | Boost stage gain setting.<br>1: Gain = 26dB<br>0: Gain = 0dB.                                                                                                                                                                                                          |
| [2]  | <b>PU_BOOST</b>  | Power Up control for boost stage amplifier. This amplifier must be powered up for signal path operation.<br>1: Power up.<br>0: Power Down.                                                                                                                             |
| [1]  | <b>PU_PGA</b>    | Power Up control for PGA amplifier. This amplifier must be powered up for signal path operation.<br>1: Power up.<br>0: Power down.                                                                                                                                     |
| [0]  | <b>REF_SEL</b>   | <b>Select Reference for Analog path.</b> Signal path is normally referenced to VMID (VCCA/2). To use an absolute reference this can be set to VBG=1.2V.<br>1: Select Bandgap voltage as analog ground reference.<br>0: Select VMID voltage as analog ground reference. |

Signal Path Control Register (ANA->SIGCTRL)

| Register | Offset      | R/W | Description                  |  |  |  | Reset Value |
|----------|-------------|-----|------------------------------|--|--|--|-------------|
| SIGCTRL  | ANA_BA+0x64 | R/W | Signal Path Control Register |  |  |  | 0x0000_0000 |

| 7        | 6            | 5        | 4      | 3        | 2         | 1         | 0      |
|----------|--------------|----------|--------|----------|-----------|-----------|--------|
| Reserved | MUTE_IPBOOST | MUTE_PGA | PU_MOD | PU_IBGEN | PU_BUFDAC | PU_BUFPGA | PU_ZCD |

Table 7-32 Signal Path Mute Control Register (PGAMUTE, address 0x4008\_0064)

| Bits | Descriptions                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]  | <b>MUTE_IPBOOST</b><br>Boost stage mute control<br>1: Signal Muted. 0: Normal.                                                                                                                                                                                                                                                                                                                       |
| [5]  | <b>MUTE_PGA</b><br>PGA Mute control.<br>1: Signal Muted. 0: Normal.                                                                                                                                                                                                                                                                                                                                  |
| [4]  | <b>PU_MOD</b><br>Power up ADC $\Sigma\Delta$ Modulator. This block must be powered up for ADC operation.<br>1: Power up. 0: Power down.                                                                                                                                                                                                                                                              |
| [3]  | <b>PU_IBGEN</b><br>Power up control for current bias generation. This block must be powered up for signal path operation.<br>1: Power up. 0: Power down.                                                                                                                                                                                                                                             |
| [2]  | <b>PU_BUFDAC</b><br>Power up control for ADC reference buffer. This block must be powered up for signal path operation.<br>1: Power up. 0: Power down.                                                                                                                                                                                                                                               |
| [1]  | <b>PU_BUFPGA</b><br>Power up control for PGA reference buffer. This block must be powered up for signal path operation.<br>1: Power up. 0: Power down.                                                                                                                                                                                                                                               |
| [0]  | <b>PU_ZCD</b><br>Power up and enable control for Zero Cross Detect Comparator. When enabled PGA gain settings will only be updated when ADC input signal crosses zero signal threshold. To operate ZCD the ALC peripheral clock (SYSCLK.BIQALC_EN) must also be enabled and BIQ->BIQ_CTRL.RSTn=1 to allow ZCD clocks to be generated.<br>1: Power up and enable zero cross detection. 0: Power down. |

PGA GAIN Control Register (ANA->PGA\_GAIN)

| Register | Offset      | R/W | Description              |  |  |  |  | Reset Value |
|----------|-------------|-----|--------------------------|--|--|--|--|-------------|
| GAIN     | ANA_BA+0x68 | R/W | PGA Gain Select Register |  |  |  |  | 0x0000_0010 |

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

Table 7-33 PGA Gain Control Register (PGA\_GAIN, address 0x4008\_0068)

| Bits   |           | Descriptions                                                                                                                                      |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [13:8] | GAIN_READ | Read Only. Current PGA Gain, may be different from GAIN register when AGC is enabled and is controlling the PGA gain.                             |
| [5:0]  | GAIN      | Selects the PGA gain setting from -12dB to 35.25dB in 0.75dB step size. 0x00 is lowest gain setting at -12dB and 0x3F is largest gain at 35.25dB. |

#### 7.4.10 Capacitive Touch Sensing Relaxation Oscillator/Counter

The ISD9160 provides a functional unit that is used with analog GPIO functions to form a relaxation oscillator. The major application of this function is to measure the capacitive load on a GPIO pin. This measurement allows the user to implement a capacitive touch sensing scheme. With appropriate touch sensor design, the capacitance of the sensor will change appreciably in the presence of a finger, and the Capacitive Touch Sensing Relaxation Oscillator can measure this.

This block is used in conjunction with the analog comparator block and current source block to form a relaxation oscillator and counter circuit that can sense capacitance changes. A block diagram of the system is shown in Figure 7-15.



Figure 7-15 Capacitive Touch Sensing Function Block Diagram

##### 7.4.10.1 Functional Description

The principle behind the operation of this block is that a certain capacitance is present on one of the analog enabled GPIO (GPIOB[7:0]). This capacitance consists of a certain parasitic capacitance  $C_{par}$  and the capacitor that is to be sensed  $C_{sense}$ . The GPIO is configured into the Capacitive Touch Sensing mode by setting SYS->GPB\_ALT.GPBn = 2 and enabling a current source to this pin (ANA->ISRC.EN =  $2^n$ ). The Analog Comparator 0 is also setup to compare the voltage at the pin to a reference voltage (ACMP->CMPSEL = n, ACMP->CMP0CR.EN = 1).

In this configuration the circuit will charge the total capacitance with current ANA->ISRC.VAL = 0.5 $\mu$ A-5 $\mu$ A. When the voltage reaches the reference voltage (normally set to VBG=1.2V), the Capacitive Touch Sensing block will reset the GPIO pin to 0V. The circuit can be configured to do this  $2^{CYCLE\_CNT}$  times before generating an interrupt. While the capacitor is charging, a 24bit counter is also enabled such that the total charge time is recorded. After completion of  $2^{CYCLES\_CNT}$  cycles the software can read the ANA->CAP\_CNT register to get a value proportional to the total capacitance on the pin. Once this is done, the count can be reset with RST\_CNT and a new measurement started either on the same GPIO or selecting a different GPIO.

##### 7.4.10.2 Design Considerations

Selecting parameters for capacitive touch sensing measurement is a trade-off between speed and accuracy/noise immunity. The higher the current source setting, the faster the oscillation but lower the resolution. The higher the cycle count the slower the measurement but the higher the accuracy and noise immunity.

## 7.4.10.3 Register Descriptions

Capacitive Touch Sensing Control Register (ANA->CAPS\_CTRL)

| Register  | Offset      | R/W | Description                               |  |  |  |  | Reset Value |
|-----------|-------------|-----|-------------------------------------------|--|--|--|--|-------------|
| CAPS_CTRL | ANA_BA+0x8C | R/W | Capacitive Touch Sensing Control Register |  |  |  |  | 0x0000_0000 |

|          |        |            |           |    |    |          |    |
|----------|--------|------------|-----------|----|----|----------|----|
| 31       | 30     | 29         | 28        | 27 | 26 | 25       | 24 |
| EN       | INT_EN | RST_CNT    | Reserved  |    |    |          |    |
| 23       | 22     | 21         | 20        | 19 | 18 | 17       | 16 |
| Reserved |        |            |           |    |    |          |    |
| 15       | 14     | 13         | 12        | 11 | 10 | 9        | 8  |
| CLK_DIV  |        |            |           |    |    |          |    |
| 7        | 6      | 5          | 4         | 3  | 2  | 1        | 0  |
| Reserved |        | REF_CLK_MD | CYCLE_CNT |    |    | LOW_TIME |    |

Table 7-34 Capacitive Touch Sensing Control Register (CAPS\_CTRL, address 0x4008\_008C).

| Bits   | Symbol     | Description                                                                                                                                                         |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | EN         | <b>Enable.</b> 1: Enable Block. 0: Disable/Reset block.                                                                                                             |
| [30]   | INT_EN     | <b>Interrupt Enable:</b> 1: Enable CAPS_IRQ interrupt. 0: Disable/Reset CAPS_IRQ interrupt.                                                                         |
| [29]   | RST_CNT    | Reset Count. 1: Set high to reset CAP_CNT. 0: Release/Activate CAP_CNT                                                                                              |
| [15:8] | CLK_DIV    | <b>Reference clock divider.</b> Circuit can be used to generate a reference clock output of SDCLK/2/(CLK_DIV+1) instead of a Capacitive Touch Sensing reset signal. |
| [5]    | REF_CLK_MD | <b>Reference Clock Mode.</b> 1: Circuit is in Reference clock generation mode. 0: Capacitive Touch Sensing Mode.                                                    |
| [4:2]  | CYCLE_CNT  | <b>Number of Relaxation Cycles.</b> Peripheral performs $2^{(CYCLE\_CNT)}$ relaxation cycles before generating interrupt.                                           |
| [1:0]  | LOW_TIME   | <b>Output Low Time.</b> Number of PCLK cycles to discharge external capacitor. 0=1cycle, 1=2cycles, 2=8cycles, 3=16cycles.,                                         |

Capacitive Touch Sensing Count Register (ANA->CAPS\_CNT)

| Register | Offset      | R/W | Description                             |  | Reset Value |
|----------|-------------|-----|-----------------------------------------|--|-------------|
| CAPS_CNT | ANA_BA+0x90 | R   | Capacitive Touch Sensing Count Register |  | 0x0000_0000 |

Table 7-35 Capacitive Touch Sensing Count Register (CAPS\_CNT, address 0x4008\_0090).

| Bits   | Symbol   | Description                                                       |
|--------|----------|-------------------------------------------------------------------|
| [23:0] | CAPS_CNT | <b>Counter read back value of Capacitive Touch Sensing Block.</b> |

#### 7.4.11 Oscillator Frequency Measurement and Control

The ISD9160 provides a functional unit that can be used to measure PCLK frequency given a reference frequency such as the 32.768kHz crystal or an I2S frame synchronization signal. This is simply a special purpose timer/counter as shown in Figure 7-16.



Figure 7-16 Oscillator Frequency Measurement Block Diagram

The block can be used to trim/measure the internal high frequency oscillator to the reference frequency of the 32.768kHz oscillator or an external reference frequency fed in on the I2S frame sync input. With this the internal clock can be set at arbitrary frequencies, other than those trimmed at manufacturing, or can be periodically trimmed to account for temperature variation. The block can also be used to measure the 10kHz oscillator frequency relative to the internal master oscillator.

An example of use would be to measure the internal oscillator with reference to the 32768Hz crystal. To do this:

```

SYSCLK->APBCLK.ANA_EN = 1; /* Turn on analog peripheral clock */
ANA->FREQ_CTRL.FM_SEL = 1; // Select reference source as 32kHz XTAL input
ANA->FREQ_CTRL.FM_CYCLE = DRVOSC_NUM_CYCLES-1;
ANA->FREQ_CTRL.FM_GO = TRUE;
while( (ANA->FREQ_CTRL.FM_DONE != 1) && (Timeout++ < 0x100000));
    if( Timeout >= 0x100000)
        return(E_DRVOSC_MEAS_TIMEOUT);
Freq = ANA->FREQ_CNT;
ANA->FREQ_CTRL.FM_GO = FALSE;
Freq = Freq*32768 /DRVOSC_NUM_CYCLES;

```

To adjust the oscillator the user can write to the OSCTRIM register (see [Table 5-11](#)). In addition, to obtain frequencies in between OSCTRIM trim settings a SUPERFINE function is available. The SUPERFINE function dithers the trim setting between the current setting and FINE trim settings above and below the current setting. An example of how the SUPERFINE trim register can adjust the measured oscillator frequency is shown in the figure below



Figure 7-17 Example SUPERFINE Trim Frequency Adjustment.



Figure 7-18 Typical Oscillator Frequency versus OSCTRIM Setting.

Oscillator Trim Register (ANA->TRIM)

| Register | Offset      | R/W | Description               |  |  |  | Reset Value |
|----------|-------------|-----|---------------------------|--|--|--|-------------|
| TRIM     | ANA_BA+0x84 | R/W | Oscillator Trim Register. |  |  |  | 0x0000_XXXX |

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

Table 7-36 Oscillator Trim Register (TRIM, address 0x4008\_0084).

| Bits    | Symbol           | Description                                                                                                                                                                                                                                                                                                                                           |
|---------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:16] | <b>SUPERFINE</b> | The <b>SUPERFINE</b> trim setting is an 8bit signed integer. It adjusts the master oscillator by dithering the FINE trim setting between the current setting and one setting above (values 1,127) or below (values -1, -128) the current trim setting. Each step effectively moves the frequency 1/128 <sup>th</sup> of the full FINE trim step size. |
| [15:8]  | <b>COARSE</b>    | <b>COARSE.</b> Current COARSE range setting of the oscillator. Read Only                                                                                                                                                                                                                                                                              |
| [7:0]   | <b>OSCTRIM</b>   | <b>Oscillator Trim.</b> Reads current oscillator trim setting. Read Only.                                                                                                                                                                                                                                                                             |

Frequency Measurement Control Register (ANA->FREQ\_CTRL)

| Register  | Offset      | R/W | Description                             |  |  |  | Reset Value |
|-----------|-------------|-----|-----------------------------------------|--|--|--|-------------|
| FREQ_CTRL | ANA_BA+0x94 | R/W | Frequency Measurement Control Register. |  |  |  | 0x0000_0001 |

|          |          |    |    |    |    |    |    |
|----------|----------|----|----|----|----|----|----|
| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
| GO       | Reserved |    |    |    |    |    |    |
| 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
| FM_CYCLE |          |    |    |    |    |    |    |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
| Reserved |          |    |    |    |    |    |    |

|          |   |   |   |   |         |        |   |
|----------|---|---|---|---|---------|--------|---|
| 7        | 6 | 5 | 4 | 3 | 2       | 1      | 0 |
| Reserved |   |   |   |   | FM_DONE | FM_SEL |   |

Table 7-37 Frequency Measurement Control Register (FREQ\_CTRL, address 0x4008\_0094).

| Bits    | Symbol   | Description                                                                                                                                                                                                                                              |
|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | GO       | GO. 1: Start Frequency Measurement. 0: Disable/Reset block.                                                                                                                                                                                              |
| [23:16] | FM_CYCLE | <b>Frequency Measurement Cycles:</b> Number of reference clock periods plus one to measure target clock (PCLK). For example if reference clock is OSC32K ( $T=30.5175\mu s$ ), FM_CYCLE=7, then measurement period would be $30.5175*(7+1)=244.1\mu s$ . |
| [2]     | FM_DONE  | <b>Measurement Done.</b> 1: Measurement Complete. 0: Measurement Ongoing.                                                                                                                                                                                |
| [1:0]   | FM_SEL   | <b>Reference clock source.</b> 00b: OSC10K, 01b: OSC32K (default), 1xb: I2S_WS – can be GPIOA[4,8,12] according to GPA_ALT register, configure I2S in SLAVE mode to enable.                                                                              |

#### Frequency Measurement Count (ANA->FREQ\_CNT)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| FREQ_CNT | ANA_BA+0x98 | R/W | Frequency Measurement Count Register. | 0x0000_0000 |

Table 7-38 Frequency Measurement Count Register (FREQ\_CNT, address 0x4008\_0098).

| Bits   | Symbol   | Description                                                                                                                                                                                                                                                                               |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | FREQ_CNT | <b>Frequency Measurement Count:</b> When FM_DONE=1 and GO=1, this is number of PCLK periods counted for frequency measurement.<br>The frequency will be $PCLK = FREQ_CNT * Fref / (FM_CYCLE + 1) \text{ Hz}$<br>Maximum resolution of measurement is $Fref / (FM_CYCLE + 1)^2 \text{ Hz}$ |

## 7.5 Automatic Level Control (ALC)

### 7.5.1 Overview and Features

The ALC seeks to control the PGA gain such that the PGA output maintains a constant envelope. This helps to prevent clipping at the input of the sigma delta ADC while maximizing the full dynamic range of the ADC. The ALC monitors the output of the ADC biquad filter when that filter is enabled in the ADC path, or the output of the SINC filter otherwise. The ADC output is fed into a peak detector, which updates the measured peak value whenever the absolute value of the input signal is higher than the current measured peak. The measured peak gradually decays to zero unless a new peak is detected, allowing for an accurate measurement of the signal envelope. Based on a comparison between the measured peak value and the target value, the ALC block adjusts the gain control, which is fed back to the PGA.



Figure 7-19 ALC Block Diagram

The ALC is enabled by setting ALCSEL. The ALC shares a clock source with the Biquad filter so SYSCLK->APBCLK.BIQALC\_EN must be set to operate ALC. The ALC has two functional modes, which is set by ALCMODE.

- Normal mode (ALCMODE = LOW)
- Peak Limiter mode (ALCMODE = HIGH)

When the ALC is disabled, the input PGA returns to the PGA gain setting held in ANA → PGA\_GAIN.GAIN. In order to have a smooth transition when disabling the ALC, the user may prefer to fetch the ALC trained gain setting from ANA → PGA\_GAIN.GAIN\_READ and write that value to ANA → PGA\_GAIN.GAIN prior to disabling the ALC. An input gain update must be made by writing to PGASEL[5:0]. A digital peak detector monitors the input signal amplitude and compares it to a register defined threshold level ALCLVL[3:0].



Figure 7-20: ALC Response Graph

The registers listed in the following sections allow configuration of ALC operation with respect to:

- ALC target level
- Gain increment and decrement rates

- Minimum and maximum PGA gain values for ALC operating range
- Hold time before gain increments in response to input signal
- Inhibition of gain increment during noise inputs
- Limiter mode operation

The operating range of the ALC is set by ALCMAX and ALCMIN bits such that the PGA gain generated by the ALC is constrained to be between the programmed minimum and maximum levels. When the ALC is enabled, the PGA gain setting from PGASEL has no effect.

In Normal mode, the ALCMAX bits set the maximum level for the PGA but in the Limiter mode ALCMAX has no effect because the maximum level is set by the initial PGA gain setting upon enabling of the ALC.

#### 7.5.1.1 *Normal Mode*

Normal mode is selected when ALCMODE is set LOW and the ALC is enabled by setting ALCSEL HIGH. This block adjusts the PGA gain setting up and down in response to the input level. A peak detector circuit measures the envelope of the input signal and compares it to the target level set by ALCLVL. The ALC increases the gain when the measured envelope is less than (target – 1.5dB) and decreases the gain when the measured envelope is greater than the target. The following waveform illustrates the behavior of the ALC.



Figure 7-21: ALC Normal Mode Operation

#### 7.5.1.2 *ALC Hold Time (Normal mode Only)*

The hold parameter ALCHLD configures the time between detection of the input signal envelope being below the target range and the actual gain increase.

Input signals with different characteristics (e.g., voice vs. music) may require different settings for this parameter for optimal performance. Increasing the ALC hold time prevents the ALC from reacting too quickly to brief periods of silence such as those that may appear in music recordings; having a shorter hold time, on the other hand, may be useful in voice applications where a faster reaction time helps to adjust the volume setting for speakers with different volumes. The waveform below shows the operation of the ALCHLD parameter.



Figure 7-22: ALC Hold Time

#### 7.5.1.3 Peak Limiter Mode

Peak Limiter mode is selected when ALCMODE is set to HIGH and the ALC is enabled by setting ALCSEL. In limiter mode, the PGA gain is constrained to be less than or equal to the gain setting at the time the limiter mode is enabled. In addition, attack and decay times are faster in limiter mode than in normal mode as indicated by the different lookup tables for these parameters for limiter mode. The following waveform illustrates the behavior of the ALC in Limiter mode in response to changes in various ALC parameters.



Figure 7-23: ALC Limiter Mode Operations

When the input signal exceeds 87.5% of full scale, the ALC block ramps down the PGA gain at the maximum attack rate (ALCATT=0000) regardless of the mode and attack rate settings until the ADC output level has been reduced below the threshold. This limits ADC clipping if there is a sudden increase in the input signal level.

#### 7.5.1.4 Attack Time

When the absolute value of the ADC output exceeds the level set by the ALC threshold, ALCLVL, attack mode is initiated at a rate controlled by the attack rate register ALCATT. The peak detector in the ALC block loads the ADC output value when the absolute value of the ADC output exceeds the current measured peak; otherwise, the peak decays towards zero, until a new peak has been identified. This sequence is continuously running. If the peak is ever below the target threshold, then there is no gain decrease at the next attack timer time; if it is ever above the target-1.5dB, then there is no gain increase at the next decay timer time.

### 7.5.1.5 Decay Times

The decay time ALCDCY is the time constant used when the gain is increasing. In limiter mode, the time constants are faster than in ALC mode.

### 7.5.1.6 Noise gate (normal mode only)

A noise gate is used when there is no input signal or the noise level is below the noise gate threshold. The noise gate is enabled by setting NGEN to HIGH. It does not remove noise from the signal. The noise gate threshold NGTH is set to a desired level so when there is no signal or a very quiet signal (pause), which is composed mostly of noise, the ALC holds the gain constant instead of amplifying the signal towards the target threshold. The noise gate only operates in conjunction with the ALC (ALCSEL HIGH) and ONLY in Normal mode. The noise gate flag is asserted when

(Signal at ADC – PGA gain – MIC Boost gain) < NGTH (dB)

Levels at the extremes of the range may cause inappropriate operation, so care should be taken when setting up the function.



Figure 7-24: ALC Operation with Noise Gate disabled



Figure 7-25: ALC Operation with Noise Gate Enabled

### 7.5.1.7 Zero Crossing

The PGA gain comes from either the ALC block when it is enabled or from the PGA gain register setting when the ALC is disabled. Zero crossing detection may be enabled to cause PGA gain changes to occur only at an input zero crossing. Enabling zero crossing detection limits clicks and pops that may occur if the gain changes while the input signal has a high volume.

There are two zero crossing detection enables:

- Register ALCZC – is only relevant when the ALC is enabled.
- Register ANA\_EN\_ZCD – is only relevant when the ALC is disabled.

If the zero crossing function is enabled (using either register), the zero cross timeout function may take effect. If the zero crossing flag does not change polarity within 0.25 seconds of a PGA gain update (either via ALC update or PGA gain register update), then the gain will update. This backup system prevents the gain from locking up if the input signal has a small swing and a DC offset that prevents the zero crossing flag from toggling.

Preliminary

### 7.5.2 ALC Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                    | Offset     | R/W | Description          | Reset Value | Reference                  |
|-----------------------------|------------|-----|----------------------|-------------|----------------------------|
| <b>ALC_BA = 0x400B_0048</b> |            |     |                      |             |                            |
| ALC_CTRL                    | BIQ_BA+0x0 | R/W | ALC control          | 0x0E01_6320 | <a href="#">Table 7-39</a> |
| ALC_STATUS                  | BIQ_BA+0x4 | R   | ALC status           | 0x0000_0000 | <a href="#">Table 7-40</a> |
| ALC_INT                     | BIQ_BA+0x8 | R/W | ALC interrupt        | 0x0000_0000 | <a href="#">Table 7-41</a> |
| ALC_INTEN                   | BIQ_BA+0xC | R/W | ALC interrupt enable | 0x0000_0000 | <a href="#">Table 7-42</a> |

### 7.5.3 ALC Control Register Description

#### ALC Control Register (ALC\_CTRL)

| Register | Offset     | R/W | Description          | Reset Value |
|----------|------------|-----|----------------------|-------------|
| ALC_CTRL | ALC_BA+0x0 | R/W | ALC Control Register | 0x0E01_6320 |

Table 7-39 ALC Control Register (ALC\_CTRL, address 0x400B\_0048)

| 31          | 30       | 29       | 28      | 27     | 26   | 25 | 24        |
|-------------|----------|----------|---------|--------|------|----|-----------|
| ALCPKLM     | ALCPKSEL | ALCNGSEL | ALCSEL  | ALCMAX |      |    | ALCMIN[2] |
| 23          | 22       | 21       | 20      | 19     | 18   | 17 | 16        |
| ALCMIN[1:0] |          | ALCZC    | ALCHLD  |        |      |    | ALCLVL[3] |
| 15          | 14       | 13       | 12      | 11     | 10   | 9  | 8         |
| ALCLVL[2:0] |          |          | ALCMODE | ALCDCY |      |    |           |
| 7           | 6        | 5        | 4       | 3      | 2    | 1  | 0         |
| ALCATK      |          |          |         | NGEN   | NGTH |    |           |

| Bits | Descriptions |                                                                                                                                                                                     |  |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31] | ALCPKLM      | <b>ALC peak limiter enable</b><br>0 = enable fast decrement when signal exceeds 87.5% of full scale (default)<br>1 = disable fast decrement when signal exceeds 87.5% of full scale |  |
| [30] | ALCPKSEL     | <b>ALC gain peak detector select</b><br>0 = use absolute peak value for ALC training (default)<br>1 = use peak-to-peak value for ALC training                                       |  |

|         |          |                                                                                                                                                                                                 |
|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [29]    | ALCNGSEL | <b>ALC noise gate peak detector select</b><br>0 = use peak-to-peak value for noise gate threshold determination (default)<br>1 = use absolute peak value for noise gate threshold determination |
| [28]    | ALCSEL   | <b>ALC select</b><br>0 = ALC disabled (default)<br>1 = ALC enabled                                                                                                                              |
| [27:25] | ALCMAX   | <b>ALC maximum gain</b><br>Maximum level for ALC operation<br>0 = -6.75 dB<br>1 = -.75 dB<br>2 = +5.25 dB<br>3 = +11.25 dB<br>...<br>7 = +35.25 dB                                              |
| [24:22] | ALCMIN   | <b>ALC minimum gain</b><br>Minimum level for ALC operation<br>0 = -12dB<br>1 = -6dB<br>2 = 0dB<br>3 = +6dB<br>...<br>7 = +30dB                                                                  |
| [21]    | ALCZC    | <b>ALC zero crossing</b><br>0 = zero crossing disabled<br>1 = zero crossing enabled                                                                                                             |
| [20:17] | ALCHLD   | <b>ALC hold time (value: 0~10)</b><br>0 = 0 ms<br>1 = 2 ms<br>2 = 4 ms (doubles every step)<br>...<br>10+ = 1 s                                                                                 |

|         |         |                                                                                                                                                          |
|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16:13] | ALCLVL  | <b>ALC target level</b><br>0 = -28.5 dB<br>1 = -27 dB<br>2 = -25.5 dB<br>...<br>14 = -7.5 dB<br>15 = -6 dB                                               |
| [12]    | ALCMODE | <b>ALC mode</b><br>0 = ALC normal operation mode<br>1 = ALC limiter mode                                                                                 |
| [11:8]  | ALCDCY  | <b>ALC decay time (value: 0~10)</b><br>ALCMODE=0<br>Range: 125us to 128ms<br>ALCMODE=1<br>Range: 31us to 32ms (time doubles with every step)             |
| [7:4]   | ALCATK  | <b>ALC attack time (value: 0~10)</b><br>ALCMODE=0<br>Range: 500us to 512ms<br>ALCMODE=1<br>Range: 125us to 128ms (Both ALC time doubles with every step) |
| [3]     | NGEN    | <b>Noise gate enable</b><br>0 = Noise gate disabled<br>1 = Noise gate enabled                                                                            |

|       |      |                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:0] | NGTH | <p><b>Noise gate threshold</b></p> <p>Boost disabled:</p> <p>000 = -81dB<br/>001 = -75dB<br/>010 = -69dB<br/>011 = -63dB<br/>100 = -57dB<br/>101 = -51dB<br/>110 = -45dB<br/>111 = -39dB</p> <p>Boost enabled:</p> <p>000 = -87dB<br/>001 = -81dB<br/>010 = -75dB<br/>011 = -69dB<br/>100 = -63dB<br/>101 = -57dB<br/>110 = -51dB<br/>111 = -45dB</p> |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**ALC Status Register (ALC\_STATUS)**

| Register   | Offset     | R/W | Description |  |  |  | Reset Value |
|------------|------------|-----|-------------|--|--|--|-------------|
| ALC_STATUS | ALC_BA+0x4 | R   | ALC status  |  |  |  | 0x0000_0000 |

Table 7-40 ALC Status Register (ALC\_STATUS, address 0x400D\_004C)

|           |    |    |    |    |           |       |          |
|-----------|----|----|----|----|-----------|-------|----------|
| 31        | 30 | 29 | 28 | 27 | 26        | 25    | 24       |
| Reserved  |    |    |    |    |           |       |          |
| 23        | 22 | 21 | 20 | 19 | 18        | 17    | 16       |
| Reserved  |    |    |    |    | PEAK[8:5] |       |          |
| 15        | 14 | 13 | 12 | 11 | 10        | 9     | 8        |
| PEAK[4:0] |    |    |    |    | P2P[8:6]  |       |          |
| 7         | 6  | 5  | 4  | 3  | 2         | 1     | 0        |
| P2P[5:0]  |    |    |    |    |           | NOISE | FAST_DEC |

| Bits    | Descriptions |                                                                                      |
|---------|--------------|--------------------------------------------------------------------------------------|
| [31:19] | Reserved     | Reserved                                                                             |
| [18:11] | PEAK         | Peak value<br>9 MSBs of measured absolute peak value                                 |
| [10:2]  | P2P          | Peak-to-peak value<br>9 MSBs of measured peak-to-peak value                          |
| [1]     | NOISE        | Noise flag asserted when signal level is detected to be below NGTH                   |
| [0]     | FAST_DEC     | Clipping flag asserted when signal level is detected to be above 87.5% of full scale |

ALC Interrupt Register (ALC\_INT)

| Register | Offset     | R/W | Description   | Reset Value |
|----------|------------|-----|---------------|-------------|
| ALC_INT  | ALC_BA+0x8 | R/W | ALC interrupt | 0x0000_0000 |

Table 7-41 ALC Interrupt Register (ALC\_INT, address 0x400D\_0050)

|          |   |   |   |   |   |   |         |
|----------|---|---|---|---|---|---|---------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
| Reserved |   |   |   |   |   |   | ALC_INT |

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved     | Reserved                                                                                                                                                                                                                                                                       |
| [0]    | ALC_INT      | <p><b>ALC interrupt</b></p> <p>This interrupt flag asserts whenever the interrupt is enabled and the PGA gain is updated, either through an ALC change with the ALC enabled or through a PGA gain write with the ALC disabled.</p> <p>Write a 1 to this register to clear.</p> |

ALC Interrupt Enable Register

| Register  | Offset     | R/W | Description          | Reset Value |
|-----------|------------|-----|----------------------|-------------|
| ALC_INTEN | ALC_BA+0xC | R/W | ALC interrupt enable | 0x0000_0000 |

Table 7-42 ALC Interrupt Enable Register (ALC\_INTEN, address 0x400D\_0054)

|          |   |   |   |   |   |   |           |
|----------|---|---|---|---|---|---|-----------|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
| Reserved |   |   |   |   |   |   | ALC_INTEN |

| Bits   | Descriptions |                                                                                        |
|--------|--------------|----------------------------------------------------------------------------------------|
| [31:1] | Reserved     | Reserved                                                                               |
| [0]    | ALC_INTEN    | <p><b>ALC Interrupt Enable</b></p> <p>0 = ALC_INT disabled<br/>1 = ALC_INT enabled</p> |

## 7.6 Biquad Filter (BIQ)

### 7.6.1 Overview and Features

A coefficient programmable 3-stage Biquad filter (6<sup>th</sup>-Order IIR filter) is available which can be used on either ADC path or DPWM path to further reduce unwanted noise or filter the signal. Each biquad filter has the transfer function as  $H(z)$  and is implemented in Direct Form II Transpose structure as.

$$H(z) = \frac{b_0 + b_1 z^{-1} + b_2 z^{-2}}{1 + a_1 z^{-1} + a_2 z^{-2}}$$

Upon power on reset or when the BIQ\_CTRL.RSTn=0 is released, a set of default coefficients  $b_{n0}$ ,  $b_{n1}$ ,  $b_{n2}$ ,  $a_{n1}$ ,  $a_{n2}$  (n = 1,2,3 which is the stage number of the filter) will be written to the coefficient RAM automatically. And these coefficients can be over-written by the processor for different filter specifications.

Note that the fixed point coefficients have the format of 3.16 (19 bits) and are stored in the coefficient RAM under normal operation. It takes 32 internal system clocks for the automatic write to finish when the BIQ\_CTRL.RSTn bit is released; it is important that the processor has enough delay before start the coefficient programming or enabling biquad (BIQ\_CTRL.EN). Attempting to program the coefficients before the auto programming is done will result in unsuccessful programming. The default coefficient setting is a low pass filter with 3db cut-off frequency at 7/16 Fs (Sample Rate).

Biquad is released from reset by setting BIQ\_CTRL.RSTn=1. After 32 clock cycles, processor can setup other Biquad parameters or re-program coefficients before enabling filter.

The BIQ\_CTRL.SELPWM register bit determines which path the BIQ is going to use. The default value is 0 which is the microphone ADC path, by setting this bit 1, the BIQ will be used in DPWM path.

The operating Sample Rate of the filter can be setup by the following registers: The default value of BIQ\_CTRL.SR\_DIV (sample rate divider) is 3071, when the chip is running at HCLK=49.152Mhz, the operating SR of BIQ can be calculated by equation  $HCLK/(SR\_DIV+1) = 16Khz$ . The processor can change the operating sample rate (SR) by changing the SR\_DIV register.

If the BIQ is intended to be used in DPWM path, the BIQ can up sample the data rate by programming BIQ\_CTRL.UPSR register which has default value at 3. The final BIQ sampling rate for DPWM path is based on both SR\_DIV and BIQ\_CTRL.UPSR registers which is equal to  $SR * (BIQ\_CTRL.UPSR+1)$  . So the default DPWM operating sample rate is  $16 * (3+1) = 64Khz$ .

The BIQ filter is in reset state in default. To use the BIQ function, the following sequence is recommended:

1. Set BIQ\_CTRL.RSTn bit. By releasing the reset, the filter controller will download default coefficients automatically to the RAM.
2. Turn on the BIQ\_CTRL.PRGCOEF bit if intending to change the coefficients. Otherwise skip to next step.
3. Setup the BIQ operation sample rate by program UPSR or SR\_DIV register bits if necessary.
4. Decide the ADC or DPWM path to be used for the BIQ by programming SELPWM, and turn off PRGCOEF bit (if it was turned on in step #2).
5. Turn on BIQ\_CTRL.EN. BIQ will start filter function.

## 7.6.2 BIQ Control Register Map

### 7.6.2.1 BIQ filter coefficients registers

| Register                    | Offset        | R/W                                          | Description                                                | Reset Value |
|-----------------------------|---------------|----------------------------------------------|------------------------------------------------------------|-------------|
| <b>BIQ_BA = 0x400B_0000</b> |               | <b>1<sup>st</sup> stage BIQ Coefficients</b> |                                                            |             |
| BIQ_COEFF[0]                | BIQ_BA + 0x00 | R/W                                          | Coefficient b0 in H(z) transfer function.<br>(3.16 format) | 0xd010      |
| BIQ_COEFF[1]                | BIQ_BA+0x04   | RW                                           | Coefficient b1 in H(z) transfer function.<br>(3.16 format) | 0xc020      |
| BIQ_COEFF[2]                | BIQ_BA+0x08   | RW                                           | Coefficient b2 in H(z) transfer function.<br>(3.16 format) | 0xc020      |
| BIQ_COEFF[3]                | BIQ_BA+0x0c   | RW                                           | Coefficient a1 in H(z) transfer function.<br>(3.16 format) | 0xad66      |
| BIQ_COEFF[4]                | BIQ_BA+0x10   | RW                                           | Coefficient a2 in H(z) transfer function.<br>(3.16 format) | 0xd1dc      |

| Register                    | Offset        | R/W                                          | Description                                                | Reset Value |
|-----------------------------|---------------|----------------------------------------------|------------------------------------------------------------|-------------|
| <b>BIQ_BA = 0x400B_0000</b> |               | <b>2<sup>nd</sup> stage BIQ Coefficients</b> |                                                            |             |
| BIQ_COEFF[5]                | BIQ_BA + 0x14 | R/W                                          | Coefficient b0 in H(z) transfer function.<br>(3.16 format) | 0xc1d0      |
| BIQ_COEFF[6]                | BIQ_BA+0x18   | RW                                           | Coefficient b1 in H(z) transfer function.<br>(3.16 format) | 0x183a0     |
| BIQ_COEFF[7]                | BIQ_BA+0x1c   | RW                                           | Coefficient b2 in H(z) transfer function.<br>(3.16 format) | 0xc1d0      |
| BIQ_COEFF[8]                | BIQ_BA+0x20   | RW                                           | Coefficient a1 in H(z) transfer function.<br>(3.16 format) | 0x17445     |
| BIQ_COEFF[9]                | BIQ_BA+0x24   | RW                                           | Coefficient a2 in H(z) transfer function.<br>(3.16 format) | 0x092f6     |

| Register                    | Offset        | R/W                                          | Description                               | Reset Value |
|-----------------------------|---------------|----------------------------------------------|-------------------------------------------|-------------|
| <b>BIQ_BA = 0x400B_0000</b> |               | <b>3<sup>rd</sup> stage BIQ Coefficients</b> |                                           |             |
| BIQ_COEFF[10]               | BIQ_BA + 0x28 | R/W                                          | Coefficient b0 in H(z) transfer function. | 0xb3cc      |

|               |              |    |                                                            |         |
|---------------|--------------|----|------------------------------------------------------------|---------|
|               |              |    | (3.16 format)                                              |         |
| BIQ_COEFF[11] | BIQ_BA+0x02c | RW | Coefficient b1 in H(z) transfer function.<br>(3.16 format) | 0x16798 |
| BIQ_COEFF[12] | BIQ_BA+0x030 | RW | Coefficient b2 in H(z) transfer function.<br>(3.16 format) | 0x0b3cc |
| BIQ_COEFF[13] | BIQ_BA+0x034 | RW | Coefficient a1 in H(z) transfer function.<br>(3.16 format) | 0x1595d |
| BIQ_COEFF[14] | BIQ_BA+0x038 | RW | Coefficient a2 in H(z) transfer function.<br>(3.16 format) | 0x075d2 |

#### 7.6.2.2 BIQ Control Register (BIQ\_CTRL)

| Register | Offset       | R/W | Description | Reset Value |
|----------|--------------|-----|-------------|-------------|
| BIQ_CTRL | BIQ_BA+0x040 | R/W | BIQ control | 0x0BFF_0030 |

Table 7-43 BIQ Control Register (BIQ\_CTRL, address 0x400B\_0040)

|             |      |    |              |      |         |        |    |
|-------------|------|----|--------------|------|---------|--------|----|
| 31          | 30   | 29 | 28           | 27   | 26      | 25     | 24 |
| Reserved    |      |    | SR_DIV[12:8] |      |         |        |    |
| 23          | 22   | 21 | 20           | 19   | 18      | 17     | 16 |
| SR_DIV[7:0] |      |    |              |      |         |        |    |
| 15          | 14   | 13 | 12           | 11   | 10      | 9      | 8  |
| Reserved    |      |    |              |      |         |        |    |
| 7           | 6    | 5  | 4            | 3    | 2       | 1      | 0  |
| Reserved    | UPSR |    |              | RSTn | PRGCOEF | SELPWM | EN |

| Bits    | Descriptions |                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [28:16] | SR_DIV       | <b>Sample Rate divider</b><br>This register is used to program the operating sampling rate of the biquad filter. The sample rate is defined as<br>$HCLK/(SR\_DIV+1)$ .<br>Default to 3071 so the sampling rate is 16K when HCLK is 49.152MHz. |  |  |  |  |  |  |

|       |                 |                                                                                                                                                                                                                                                                                                          |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6:4] | <b>UPSR</b>     | <b>DPWM path up sample rate (from SR_DIV result)</b><br>This register is only used when SELPWM is set to 1. The operating sample rate for the biquad filter will be<br>$(UPSR+1)*HCLK/(SR\_DIV+1)$ .<br>Default value for this register is 3.                                                            |
| [3]   | <b>RSTn</b>     | <b>Move BIQ out of reset state</b><br>0 = BIQ filter is in reset state.<br>1 = When this bit is on, the default coefficients will be downloaded to the coefficient ram automatically in 32 internal system clocks. Processor must delay enough time before changing the coefficients or turn the BIQ on. |
| [2]   | <b>PRGCOEFF</b> | 0 = Coefficient RAM is in normal mode.<br>1 = coefficient RAM is under programming mode.<br>This bit must be turned off when BIQEN is on.                                                                                                                                                                |
| [1]   | <b>SELPWM</b>   | <b>AC path selection for BIQ</b><br>0 = used in ADC path<br>1 = used in DPWM path                                                                                                                                                                                                                        |
| [0]   | <b>EN</b>       | <b>BIQ filter start to run</b><br>0 = BIQ filter is not processing<br>1 = BIQ filter is on.                                                                                                                                                                                                              |

## 8 APPLICATION DIAGRAM



## 9 ELECTRICAL CHARACTERISTICS

### 9.1 Absolute Maximum Ratings

| SYMBOL                                    | PARAMETER           | MIN     | MAX     | UNIT |
|-------------------------------------------|---------------------|---------|---------|------|
| DC Power Supply                           | VDD-VSS             | -0.3    | +6.0    | V    |
| Input Voltage                             | VIN                 | VSS-0.3 | VDD+0.3 | V    |
| Oscillator Frequency                      | 1/t <sub>CLCL</sub> | 0       | 40      | MHz  |
| Operating Temperature                     | TA                  | -40     | +85     | °C   |
| Storage Temperature                       | TST                 | -55     | +150    | °C   |
| Maximum Current into V <sub>DD</sub>      |                     | -       | 120     | mA   |
| Maximum Current out of V <sub>SS</sub>    |                     |         | 120     | mA   |
| Maximum Current sunk by a I/O pin         |                     |         | 35      | mA   |
| Maximum Current sourced by a I/O pin      |                     |         | 35      | mA   |
| Maximum Current sunk by total I/O pins    |                     |         | 100     | mA   |
| Maximum Current sourced by total I/O pins |                     |         | 100     | mA   |

Note: Exposure to conditions beyond those listed under absolute maximum ratings may adversely affects the life and reliability of the device.

## 9.2 DC Electrical Characteristics

(VDD-VSS=3.3V, TA = 25°C, Fosc = 49.152 MHz unless otherwise specified.)

| PARAMETER                                            | SYM.                                | SPECIFICATION |      |                  |      | TEST CONDITIONS                            |
|------------------------------------------------------|-------------------------------------|---------------|------|------------------|------|--------------------------------------------|
|                                                      |                                     | MIN.          | TYP. | MAX.             | UNIT |                                            |
| Operation voltage                                    | V <sub>DD</sub>                     | 2.4           |      | 5.5              | V    | V <sub>DD</sub> = 2.4V ~ 5.5V up to 50 MHz |
| Power Ground                                         | V <sub>SS</sub><br>AV <sub>SS</sub> | -0.3          |      |                  | V    |                                            |
| Analog Operating Voltage                             | AV <sub>DD</sub>                    | 0             |      | V <sub>DD</sub>  | V    |                                            |
| Analog Reference Voltage                             | Vref                                | 0             |      | AV <sub>DD</sub> | V    |                                            |
| Operating Current<br>Normal Run Mode<br>@ 49.152 MHz | I <sub>DD1</sub>                    |               | 27   |                  | mA   | V <sub>DD</sub> = 5.5V,<br>Enable all IP.  |
|                                                      | I <sub>DD2</sub>                    |               | 24   |                  | mA   | V <sub>DD</sub> = 5.5V,<br>disable all IP  |
|                                                      | I <sub>DD3</sub>                    |               | 24   |                  | mA   | V <sub>DD</sub> = 3V,<br>enable all IP     |
|                                                      | I <sub>DD4</sub>                    |               | 21   |                  | mA   | V <sub>DD</sub> = 3V,<br>disable all IP    |
| Operating Current<br>Normal Run Mode<br>@ 12.288MHz  | I <sub>DD5</sub>                    |               | 19   |                  | mA   | V <sub>DD</sub> = 5.5V<br>enable all IP    |
|                                                      | I <sub>DD6</sub>                    |               | 15   |                  | mA   | V <sub>DD</sub> = 5.5V,<br>disable all IP  |
|                                                      | I <sub>DD7</sub>                    |               | 15   |                  | mA   | V <sub>DD</sub> = 3V<br>enable all IP      |
|                                                      | I <sub>DD8</sub>                    |               | 7    |                  | mA   | V <sub>DD</sub> = 3V,<br>disable all       |

|                                                     |                    |  |     |  |    |                                               |
|-----------------------------------------------------|--------------------|--|-----|--|----|-----------------------------------------------|
| Operating Current<br>Normal Run Mode<br>@ 4.9152Mhz | I <sub>DD13</sub>  |  | 9.8 |  | mA | V <sub>DD</sub> = 5.5V,<br>Enable all IP.     |
|                                                     | I <sub>DD14</sub>  |  | 7.9 |  | mA | V <sub>DD</sub> = 5.5V,<br>Disable all IP.    |
|                                                     | I <sub>DD15</sub>  |  | 8.9 |  | mA | V <sub>DD</sub> = 3V,<br>Enable all IP.       |
|                                                     | I <sub>DD16</sub>  |  | 7.1 |  | mA | V <sub>DD</sub> = 3V,<br>Disable all IP.      |
| Operating Current<br>Normal Run Mode<br>@ 32.768Mhz | I <sub>DD9</sub>   |  | 15  |  | mA | V <sub>DD</sub> = 5.5V,<br>Enable all IP.     |
|                                                     | I <sub>DD10</sub>  |  | 11  |  | mA | V <sub>DD</sub> = 5.5V,<br>Disable all IP.    |
|                                                     | I <sub>DD11</sub>  |  | 19  |  | mA | V <sub>DD</sub> = 3V,<br>Enable all IP.       |
|                                                     | I <sub>DD12</sub>  |  | 7.1 |  | mA | V <sub>DD</sub> = 3V,<br>Disable all IP.      |
| Operating Current<br>Sleep Mode                     | I <sub>IDLE1</sub> |  | 10  |  | mA | V <sub>DD</sub> = 5.5V                        |
|                                                     | I <sub>IDLE1</sub> |  | 9   |  | mA | V <sub>DD</sub> = 3.3V                        |
| Operating Current<br>Deep Sleep Mode                | I <sub>IDLE1</sub> |  | 10  |  | mA | V <sub>DD</sub> =5.5V                         |
|                                                     | I <sub>IDLE1</sub> |  | 8   |  | mA | V <sub>DD</sub> = 3.3V                        |
| Stop Mode Current                                   | I <sub>IDLE1</sub> |  | 5   |  | uA | V <sub>DD</sub> = 5.5V 32K/10K running        |
| Standby Power down<br>mode(SPD)                     | I <sub>IDLE1</sub> |  | 3   |  | uA | V <sub>DD</sub> =3.3V 32K running with RTC    |
|                                                     | I <sub>IDLE1</sub> |  | 1   |  | uA | V <sub>DD</sub> = 3.3V 10K running            |
| Operating Current<br>Deep Power down mode(DPD)      | I <sub>IDLE1</sub> |  | 500 |  | nA | V <sub>DD</sub> =3.3V Wakeup with10K          |
|                                                     | I <sub>IDLE1</sub> |  |     |  | nA | V <sub>DD</sub> = 3.3V wakeup with wakeup pin |

|                                                                        |                |             |     |                |         |                                                        |
|------------------------------------------------------------------------|----------------|-------------|-----|----------------|---------|--------------------------------------------------------|
| Input Current PA, PB<br>(Quasi-bidirectional mode)                     | $I_{IN1}$      | -60         | -   | +15            | $\mu A$ | $V_{DD} = 5.5V, V_{IN} = 0V \text{ or } V_{IN}=V_{DD}$ |
| Input Current at /RESET <sup>[1]</sup>                                 | $I_{IN2}$      | -55         | -45 | -30            | $\mu A$ | $V_{DD} = 3.3V, V_{IN} = 0.45V$                        |
| Input Leakage Current PA, PB                                           | $I_{LK}$       | -2          | -   | +2             | $\mu A$ | $V_{DD} = 5.5V, 0 < V_{IN} < V_{DD}$                   |
| Logic 1 to 0 Transition Current<br>PA~PB (Quasi-bidirectional<br>mode) | $I_{TL}^{[3]}$ | -650        | -   | -200           | $\mu A$ | $V_{DD} = 5.5V, V_{IN} < 2.0V$                         |
| Input Low Voltage PA, PB (TTL<br>input)                                | $V_{IL1}$      | -0.3        | -   | 0.8            | V       | $V_{DD} = 4.5V$                                        |
|                                                                        |                | -0.3        | -   | 0.6            |         | $V_{DD} = 2.5V$                                        |
| Input High Voltage PA, PB (TTL<br>input)                               | $V_{IH1}$      | 2.0         | -   | $V_{DD} + 0.2$ | V       | $V_{DD} = 5.5V$                                        |
|                                                                        |                | 1.5         | -   | $V_{DD} + 0.2$ |         | $V_{DD} = 3.0V$                                        |
| Input Low Voltage XT1 <sup>[2]</sup>                                   | $V_{IL3}$      | 0           | -   | 0.8            | V       | $V_{DD} = 4.5V$                                        |
|                                                                        |                | 0           | -   | 0.4            |         | $V_{DD} = 3.0V$                                        |
| Input High Voltage XT1 <sup>[2]</sup>                                  | $V_{IH3}$      | 3.5         | -   | $V_{DD} + 0.2$ | V       | $V_{DD} = 5.5V$                                        |
|                                                                        |                | 2.4         | -   | $V_{DD} + 0.2$ |         | $V_{DD} = 3.0V$                                        |
| Input Low Voltage X32I <sup>[2]</sup>                                  | $V_{IL4}$      | 0           | -   | 0.4            | V       |                                                        |
| Input High Voltage X32I <sup>[2]</sup>                                 | $V_{IH4}$      | 1.7         | -   | 2.5            | V       |                                                        |
| Negative going threshold<br>(Schmitt input), /REST                     | $V_{ILS}$      | -0.5        | -   | $0.3V_{DD}$    | V       |                                                        |
| Positive going threshold<br>(Schmitt input), /REST                     | $V_{IHS}$      | $0.7V_{DD}$ | -   | $V_{DD} + 0.5$ | V       |                                                        |
| Hysteresis voltage of<br>PA~PB(Schmitt input)                          | $V_{HY}$       |             |     | $0.2V_{DD}$    | V       |                                                        |

|                                                                 |                    |      |      |      |    |                                                |
|-----------------------------------------------------------------|--------------------|------|------|------|----|------------------------------------------------|
| Source Current PA, PB<br>(Quasi-bidirectional Mode)             | I <sub>SR11</sub>  | -300 | -370 | -450 | μA | V <sub>DD</sub> = 4.5V, V <sub>S</sub> = 2.4V  |
|                                                                 | I <sub>SR12</sub>  | -50  | -70  | -90  | μA | V <sub>DD</sub> = 2.7V, V <sub>S</sub> = 2.2V  |
|                                                                 | I <sub>SR12</sub>  | -40  | -60  | -80  | μA | V <sub>DD</sub> = 2.5V, V <sub>S</sub> = 2.0V  |
| Source Current PA, PB (Push-pull Mode)                          | I <sub>SR21</sub>  | -20  | -24  | -28  | mA | V <sub>DD</sub> = 4.5V, V <sub>S</sub> = 2.4V  |
|                                                                 | I <sub>SR22</sub>  | -4   | -6   | -8   | mA | V <sub>DD</sub> = 2.7V, V <sub>S</sub> = 2.2V  |
|                                                                 | I <sub>SR22</sub>  | -3   | -5   | -7   | mA | V <sub>DD</sub> = 2.5V, V <sub>S</sub> = 2.0V  |
| Sink Current PA, PB<br>(Quasi-bidirectional and Push-pull Mode) | I <sub>SK1</sub>   | 10   | 16   | 20   | mA | V <sub>DD</sub> = 4.5V, V <sub>S</sub> = 0.45V |
|                                                                 | I <sub>SK1</sub>   | 7    | 10   | 13   | mA | V <sub>DD</sub> = 2.7V, V <sub>S</sub> = 0.45V |
|                                                                 | I <sub>SK1</sub>   | 6    | 9    | 12   | mA | V <sub>DD</sub> = 2.5V, V <sub>S</sub> = 0.45V |
| Brownout voltage with BOV_VL [2:0] =000b                        | V <sub>BO2.1</sub> |      | 2.15 |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =001b                        | V <sub>BO2.2</sub> |      | 2.25 |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =010b                        | V <sub>BO2.4</sub> |      | 2.45 |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =011b                        | V <sub>BO2.5</sub> |      | 2.55 |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =100b                        | V <sub>BO2.7</sub> |      | 2.7  |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =101b                        | V <sub>BO2.8</sub> |      | 2.8  |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =110b                        | V <sub>BO3.0</sub> |      | 3.0  |      | V  |                                                |
| Brownout voltage with BOV_VL [2:0] =111b                        | V <sub>BO4.5</sub> |      | 4.55 |      | V  |                                                |
| Hysteresis range of BOD voltage                                 | V <sub>BH</sub>    |      | -    |      | mV | V <sub>DD</sub> = 2.4V~5.5V                    |

**Notes:**

1. /REST pin is a Schmitt trigger input.
2. Crystal Input is a CMOS input.
3. Pins of P0, P1, P2, P3 and P4 can source a transition current when they are being externally driven from 1 to 0. In the condition of V<sub>DD</sub>=5.5V, the transition current reaches its maximum value when V<sub>in</sub> approximates to 2V .

### 9.3 AC Electrical Characteristics

#### 9.3.1 External 32kHz XTAL Oscillator

| PARAMETER             | CONDITION        | MIN. | TYP.   | MAX. | UNIT |
|-----------------------|------------------|------|--------|------|------|
| Input clock frequency | External crystal | -    | 32.768 | -    | kHz  |
| Temperature           | -                | -40  | -      | 85   | °C   |
| V <sub>DD</sub>       | -                | 2.4  | -      | 5.5  | V    |

#### 9.3.2 Internal 49.152MHz Oscillator

| PARAMETER                                | CONDITION                                  | MIN. | TYP.   | MAX. | UNIT |
|------------------------------------------|--------------------------------------------|------|--------|------|------|
| Supply voltage <sup>[1]</sup>            | -                                          | 2.4  | -      | 5.5  | V    |
| Center Frequency                         | -                                          | -    | 49.152 | -    | MHz  |
| Calibrated Internal Oscillator Frequency | +25°C; V <sub>DD</sub> =5V                 | -    | -      | -    | %    |
|                                          | -40°C~+85°C;<br>V <sub>DD</sub> =2.5V~5.5V | -    | -      | -    | %    |

#### 9.3.3 Internal 10 kHz Oscillator

| PARAMETER                                | CONDITION                                  | MIN. | TYP. | MAX. | UNIT |
|------------------------------------------|--------------------------------------------|------|------|------|------|
| Supply voltage                           | -                                          | 2.4  | -    | 5.5  | V    |
| Center Frequency                         | -                                          | -    | 10   | -    | kHz  |
| Calibrated Internal Oscillator Frequency | +25°C; V <sub>DD</sub> =5V                 | -    | -    | -    | %    |
|                                          | -40°C~+85°C;<br>V <sub>DD</sub> =2.5V~5.5V | -    | -    | -    | %    |

## 9.4 Analog Characteristics

### 9.4.1 Specification of ADC and Speaker Driver

Conditions: V<sub>CCD</sub> = 3.3V, V<sub>CCA</sub> = 3.3V, T<sub>A</sub> = +25°C, 1kHz signal, f<sub>s</sub> = 16kHz, 16-bit audio data, unless otherwise stated.

| Parameter                                       | Symbol            | Comments/Condition s                     | Min                      | Typ      | Max | Units                   |
|-------------------------------------------------|-------------------|------------------------------------------|--------------------------|----------|-----|-------------------------|
| <b>Analog to Digital Converter (ADC)</b>        |                   |                                          |                          |          |     |                         |
| Full scale input signal <sup>1</sup>            | V <sub>INFS</sub> | PGABST = 0dB<br>PGAGAIN = 0dB            |                          | 1.0<br>0 |     | V <sub>rms</sub><br>dBV |
| Signal-to-noise ratio                           | SNR               | Gain = 0dB, A-weighted                   | tbd                      | 90       |     | dB                      |
| Total harmonic distortion <sup>2</sup>          | THD+N             | Input = -3dB FS input                    |                          | -80      | tbd | dB                      |
| <b>PWM Speaker Output (8Ω bridge-tied-load)</b> |                   |                                          |                          |          |     |                         |
| Full scale output <sup>4</sup>                  |                   | SPKBST = 1                               | V <sub>CCSPK</sub> / 3.3 |          |     | V <sub>rms</sub>        |
| Total harmonic distortion <sup>2</sup>          | THD+N             | P <sub>o</sub> = 200mW,<br>VDDSPK=3.3V   |                          | *63      |     | dB                      |
|                                                 |                   | P <sub>o</sub> = 320mW,<br>VDDSPK = 3.3V |                          | -64      |     | dB                      |
|                                                 |                   | P <sub>o</sub> = 860mW,<br>VDDSPK = 5V   |                          | -60      |     | dB                      |
|                                                 |                   | P <sub>o</sub> = 1000mW,<br>VDDSPK = 5V  |                          | -36      |     | dB                      |
| Signal-to-noise ratio                           | SNR               | VDDSPK = 3.3V                            |                          | 91       |     | dB                      |
|                                                 |                   | VDDSPK=5V                                |                          | 90       |     | dB                      |
| Power supply rejection ratio<br>(50Hz - 22kHz)  | PSRR              | VDDSPK = 3.3V                            |                          | 81       |     | dB                      |
|                                                 |                   | VDDSPK = 5V                              |                          | 72       |     | dB                      |

#### 9.4.2 Specification of PGA and BOOST

Conditions: V<sub>CCD</sub> = 3.3V, V<sub>CCA</sub> = 3.3V, T<sub>A</sub> = +25°C, 1kHz signal, f<sub>s</sub> = 16kHz, 16-bit audio data, unless otherwise stated.

| Parameter                                                                   | Symbol | Comments/Condition s                                                                                      | Min | Typ                   | Max   | Units                |
|-----------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------|-----|-----------------------|-------|----------------------|
| <b>Microphone Inputs (MICP, MICN) and Programmable Gain Amplifier (PGA)</b> |        |                                                                                                           |     |                       |       |                      |
| Full scale input signal <sup>1</sup>                                        |        | PGABST = 0dB<br>PGAGAIN = 0dB                                                                             |     | 1.0<br>0              |       | Vrms<br>dBV          |
| Programmable gain                                                           |        |                                                                                                           | -12 |                       | 35.25 | dB                   |
| Programmable gain step size                                                 |        | Guaranteed Monotonic                                                                                      |     | 0.75                  |       | dB                   |
| Mute Attenuation                                                            |        |                                                                                                           |     | 120                   |       | dB                   |
| Input resistance                                                            |        | Inverting Input<br>PGA Gain = 35.25dB<br>PGA Gain = 0dB<br>PGA Gain = -12dB<br><b>Non-inverting Input</b> |     | 1.6<br>47<br>75<br>94 |       | kΩ<br>kΩ<br>kΩ<br>kΩ |
| Input capacitance                                                           |        |                                                                                                           |     | 10                    |       | pF                   |
| PGA equivalent input noise                                                  |        | 0 to 20kHz, Gain set to 35.25dB                                                                           |     | 120                   |       | μV                   |
| <b>Input Boost</b>                                                          |        |                                                                                                           |     |                       |       |                      |
| Gain boost                                                                  |        | Boost disabled<br>Boost enabled                                                                           |     | 0<br>26               |       | dB<br>dB             |

### 9.4.3 Specification of ALC and MICBIAS

Conditions: VCCD = 3.3V, VCCA = 3.3V, TA = +25°C, 1kHz signal, fs = 16kHz, 16-bit audio data, unless otherwise stated.

| Parameter                                           | Symbol               | Comments/Conditions                          | Min                                     | Typ | Max   | Units     |
|-----------------------------------------------------|----------------------|----------------------------------------------|-----------------------------------------|-----|-------|-----------|
| <b>Automatic Level Control (ALC) &amp; Limiter:</b> |                      |                                              |                                         |     |       |           |
| Target record level                                 |                      |                                              | -22.5                                   |     | -1.5  | dBFS      |
| Programmable gain                                   |                      |                                              | -12                                     |     | 35.25 | dB        |
| Gain hold time <sup>3</sup>                         | t <sub>HOLD</sub>    | Doubles every gain step, with 16 steps total | 0 / 2.67 / 5.33 / ... / 43691           |     |       | ms        |
| Gain ramp-up (decay) <sup>3</sup>                   | t <sub>DCY</sub>     | ALC Mode<br>ALC = 0                          | 4 / 8 / 16 / ... / 4096                 |     |       | ms        |
|                                                     |                      | Limiter Mode<br>ALC = 1                      | 1 / 2 / 4 / ... / 1024                  |     |       | ms        |
| Gain ramp-down (attack) <sup>3</sup>                | t <sub>ATK</sub>     | ALC Mode<br>ALC = 0                          | 1 / 2 / 4 / ... / 1024                  |     |       | ms        |
|                                                     |                      | Limiter Mode<br>ALC = 1                      | 0.25 / 0.5 / 1 / ... / 128              |     |       | ms        |
| Mute Attenuation                                    |                      |                                              |                                         | 120 |       | dB        |
| <b>Microphone Bias</b>                              |                      |                                              |                                         |     |       |           |
| Bias voltage                                        | V <sub>MICBIAS</sub> |                                              | 0.90, 0.65 ,0.75, 0.50,<br>2.4, 1.7,2.0 |     |       | VDDA<br>V |
| Bias current source                                 | I <sub>MICBIAS</sub> |                                              |                                         | 3   |       | mA        |
| Output noise voltage                                | V <sub>n</sub>       | 1kHz to 20kHz                                |                                         | 14  |       | nV/√Hz    |

#### Notes

1. Full Scale is relative to the magnitude of VCCA and can be calculated as FS = VDDA/3.3.
2. Distortion is measured in the standard way as the combined quantity of distortion products plus noise. The signal level for distortion measurements is at 3dB below full scale, unless otherwise noted.
3. Time values scale proportionally with HCLK. Complete descriptions and definitions for these values are contained in the detailed descriptions of the ALC functionality.

#### 9.4.4 Specification of LDO & Power management

| PARAMETER                             | MIN  | TYP      | MAX  | UNIT | NOTE                   |
|---------------------------------------|------|----------|------|------|------------------------|
| Input Voltage                         | 2.7  | 5        | 5.5  | V    | $V_{DD}$ input voltage |
| Output Voltage<br>(bypass=0)          | -10% | 2.45     | +10% | V    | $V_{DD} > 2.7V$        |
| Output Voltage<br>(bypass=1)          | -10% | $V_{DD}$ | +10% | V    | $V_{DD} < 2.7V$        |
| Temperature                           | -40  | 25       | 85   | oC   |                        |
| Quiescent Current<br>(PD=0, bypass=0) | -    | 100      | -    | uA   |                        |
| Quiescent Current<br>(PD=1, bypass=0) | -    | 5        | -    | uA   |                        |
| Iload (PD=0)                          | -    | -        | 100  | mA   |                        |
| Iload (PD=1)                          | -    | -        | 100  | uA   |                        |
| Cbp                                   | -    | 1u       | -    | F    | Resr=1ohm              |
| Cload                                 | -    | 250p     | -    | F    |                        |

Note:

1. It is recommended that a 10uF or higher capacitor and a 100nF bypass capacitor are connected between VCCD and the VSSD pin of the device.
2. For ensuring power stability, a 4.7uF or higher capacitor must be connected between LDO pin and the VSSD pin of the device. Also a 100nF bypass capacitor between LDO and VSSD will help suppress output noise.

**9.4.5 Specification of Brownout Detector**

| PARAMETER         | CONDITION       | MIN. | TYP. | MAX. | UNIT |
|-------------------|-----------------|------|------|------|------|
| Operation voltage | -               | 2.4  | -    | 5.5  | V    |
| Quiescent current | AVDD=5.5V       | -    | -    | 125  | µA   |
| Temperature       | -               | -40  | 25   | 85   | °C   |
| Brown-out voltage | BOV_VL[1:0]=11  |      |      |      | V    |
|                   | BOV_VL [1:0]=10 |      |      |      | V    |
|                   | BOV_VL [1:0]=01 |      |      |      | V    |
|                   | BOV_VL [1:0]=00 |      |      |      | V    |
| Hysteresis        | -               |      |      |      | V    |

**9.4.6 Specification of Power-On Reset (VCCD)**

| PARAMETER             | CONDITION         | MIN. | TYP. | MAX. | UNIT |
|-----------------------|-------------------|------|------|------|------|
| Temperature           | -                 | -40  | 25   | 85   | °C   |
| Reset voltage         | VCC ramping down  | -    | 1.0  | -    | V    |
| Reset Release voltage | VCC ramping up    |      | 1.5  |      | V    |
| Quiescent current     | Vin>reset voltage | -    | 60   | -    | nA   |

#### 9.4.7 Specification of Temperature Sensor

| PARAMETER                     | MIN | TYP | MAX | UNIT  | CONDITIONS |
|-------------------------------|-----|-----|-----|-------|------------|
| Supply voltage <sup>[1]</sup> | 2.4 | -   | 5.5 | V     |            |
| Temperature                   | -40 | -   | 125 | °C    |            |
| Current consumption           |     |     |     | uA    |            |
| Gain                          |     |     |     | mV/°C |            |
| Offset                        |     |     |     | mV    | Temp=0 °C  |

Notes:

1. Internal operation voltage comes from LDO.

#### 9.4.8 Specification of Comparator

| PARAMETER               | MIN.  | TYP.  | MAX.    | CONDITION                                                                    |
|-------------------------|-------|-------|---------|------------------------------------------------------------------------------|
| Temperature             | -40°C | 25 °C | 85°C    | -                                                                            |
| VCCA                    | 2.4   | 3     | 5.5     | -                                                                            |
| VCCA current            | -     | 20uA  | 40uA    | 20uA@VDD=3V                                                                  |
| Input offset voltage    | -     | 5mV   | 15mV    | -                                                                            |
| Input common mode range | 0.1   | -     | VDD-1.2 | -                                                                            |
| DC gain                 | -     | 70dB  | -       | -                                                                            |
| Propagation delay       | -     | 200ns | -       | @VCM=1.2V & VDIFF=0.1V                                                       |
| Comparison voltage      | 10mV  | 20mV  | -       | 20mV@VCM=1V<br>50mV@VCM=0.1V<br>50mV@VCM=VDD-1.2<br>@10mV for non-hysteresis |
| Hysteresis              | -     | ±10mV | -       | One bit control<br>W/O & W. hysteresis<br>@VCM=0.4V ~ VDD-1.2V               |
| Wake up time            | -     | -     | 2us     | @CINP=1.3V<br>CINN=1.2V                                                      |

## 10 PACKAGE DIMENSIONS

### 10.1.1 48L LQFP (7x7x1.4mm footprint 2.0mm)



## 11 ORDERING INFORMATION

### I9160xFI



## 12 REVISION HISTORY

| VERSION | DATE           | PAGE/<br>CHAP. | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V0.1    | May 25, 2011   | -              | First Release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| V1.01   | Sep 6, 2011    | -              | <ul style="list-style-type: none"><li>• Correct CLK_DIV definition in ADC.</li><li>• Add better description of EINT0/1 and PB0/1 interrupts.</li><li>• Unify the naming of capacitive touch sensing.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                   |
| V1.10   | Sep 30, 2011   | -              | <ul style="list-style-type: none"><li>• Correct level value for BOD_LVL= 100b &amp; 111b. BOD values in Feature are also updated.</li><li>• Correct table 6-5 Device ID Memory Size</li><li>• Correct the OSCTRIM Reset Value and add description for OSCTRIM</li><li>• Add description for SLEEPDEEP of register SCR</li><li>• Add description for section 7.4.11 Oscillator Frequency Measurement and Control and register TRIM</li><li>• Correct the maximum of DC Power Supply in section 9.1 Absolute Maximum Ratings</li><li>• Remove section 9.2.1 ~ 9.2.3 description and characteristic chart</li></ul> |
| V1.22   | Nov 17, 2011   | -              | <ul style="list-style-type: none"><li>• Update DC spec.</li><li>• Add ordering information.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| V1.23   | Feb, 1, 2012   | -              | <ul style="list-style-type: none"><li>• Add watermark</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| V1.24   | April, 6, 2012 | -              | <ul style="list-style-type: none"><li>• Modify the UPSR description of BIQ_CTRL</li><li>• Revise DC Electrical Characteristics</li><li>• Modify description of CLK_DIV of CAPS_CTRL</li><li>• Revise the RSTSRC register</li></ul>                                                                                                                                                                                                                                                                                                                                                                               |

### Important Notice

Nuvoton products are not designed, intended, authorized or warranted for use as components in systems or equipment intended for surgical implantation, atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, or for other applications intended to support or sustain life. Furthermore, Nuvoton products are not intended for applications wherein failure of Nuvoton products could result or lead to a situation where personal injury, death or severe property or environmental damage could occur.

Nuvoton customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Nuvoton for any damages resulting from such improper use or sales.

---

Please note that all data and specifications are subject to change without notice. All the trademarks of products and companies mentioned in this datasheet belong to their respective owners.