User Manual, V 1.0, Nov. 2005

# CIC751 Companion IC

Microcontrollers



Never stop thinking

Edition 2005-11 Published by Infineon Technologies AG, St.-Martin-Strasse 53, 81669 München, Germany © Infineon Technologies AG 2005. All Rights Reserved.

#### **Attention please!**

The information herein is given to describe certain components and shall not be considered as a guarantee of characteristics.

Terms of delivery and rights to technical change reserved.

We hereby disclaim any and all warranties, including but not limited to warranties of non-infringement, regarding circuits, descriptions and charts stated herein.

#### Information

For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office (www.infineon.com).

#### Warnings

Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies Office.

Infineon Technologies Components may only be used in life-support devices or systems with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system, or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body, or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered.

# CIC751 Companion IC

# Microcontrollers



Never stop thinking

| CIC751<br>CONFID<br>Revisior | ENTIAL<br>h History: | 2005-11                             | V 1.0 |
|------------------------------|----------------------|-------------------------------------|-------|
| Previous Version:            |                      | None.                               |       |
| Page                         | Subjects             | (major changes since last revision) |       |
|                              |                      |                                     |       |

#### We Listen to Your Comments

Any information within this document that you feel is wrong, unclear or missing at all? Your feedback will help us to continuously improve the quality of this document. Please send your proposal (including a reference to this document) to: mcdocu.comments@infineon.com



| <b>1</b><br>1.1<br>1.2 | Introduction       1-         Overview       1-         Features       1- | 1 |
|------------------------|---------------------------------------------------------------------------|---|
| 1.2.1                  | Detailed Features 1-:                                                     | 2 |
| 1.2.1.1                | ADC 1-:                                                                   | 3 |
| 1.2.1.2                | MLI                                                                       | 4 |
| 1.2.1.3                | SSC 1                                                                     | 4 |
| 1.3                    | Signal Description 1-                                                     | 5 |
| 2                      | System and Control Unit (SCU)                                             | 1 |
| 2.1                    | Reset Control Block 2-                                                    | 1 |
| 2.1.1                  | Power-On Reset                                                            | 1 |
| 2.1.2                  | Embedded Voltage Regulator (EVR) Reset                                    | 1 |
| 2.2                    | Mode Selection                                                            | 1 |
| 2.2.1                  | MODE Pin                                                                  | 2 |
| 2.2.2                  | TESTMODE Pin                                                              | 2 |
| 2.3                    | Clock System                                                              | 2 |
| 2.3.1                  | Overview                                                                  | 2 |
| 2.3.2                  | Clock Generation Unit 2-2                                                 | 2 |
| 2.3.2.1                | RC Oscillator Circuit (RCOSC) 2-                                          | 3 |
| 2.3.2.2                | Phase-Locked Loop (PLL) Module 2-4                                        | 4 |
| 2.3.2.3                | Clock Control Unit                                                        |   |
| 2.4                    | Power Supply System 2-1                                                   | 0 |
| 2.4.1                  | Embedded Voltage Regulator 2-1                                            | 1 |
| 2.5                    | Event Control                                                             | 1 |
| 2.5.1                  | Event Sources 2-1                                                         | 1 |
| 2.5.2                  | External Trigger Inputs 2-1                                               | 1 |
| 2.5.3                  | Event Output Structure 2-12                                               | 2 |
| 2.5.3.1                | Service Request Routing 2-1                                               | 3 |
| 2.6                    | SCU Registers 2-14                                                        | 4 |
| 2.6.1                  | Clock Control Registers 2-14                                              | 4 |
| 2.6.2                  | Miscellaneous SCU Registers 2-1                                           | 6 |
| 2.7                    | SCU Register Overview 2-2-                                                | 4 |
| 3                      | Direct Memory Access Controller                                           | 1 |
| 3.1                    | DMA Request Generation and Control                                        | 1 |
| 3.1.1                  | Request Generation 3-                                                     | 1 |
| 3.1.1.1                | Preselection of the Indirect Requests                                     | 2 |
| 3.1.2                  | DMA Request Assignment Matrix 3-                                          | 4 |
| 3.2                    | DMA Controller Kernel Description 3-                                      | 8 |
| 3.2.1                  | Features                                                                  | 9 |
| 3.2.2                  | Definition of Terms 3-1                                                   | 0 |



| 3.2.3<br>3.2.4<br>3.2.4.1<br>3.2.4.2 | DMA Principles       DMA Channel Functionality         DMA Channel Functionality       Shadowed Source or Destination Address         DMA Channel Request Control       DMA Channel Request Control | 3-12<br>3-12 |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 3.2.4.3                              | DMA Channel Operation Modes                                                                                                                                                                         | 3-16         |
| 3.2.4.4                              | Channel Reset Operation                                                                                                                                                                             | 3-20         |
| 3.2.4.5                              | Transfer Count and Move Count                                                                                                                                                                       | 3-22         |
| 3.2.4.6                              | Circular Buffer                                                                                                                                                                                     | 3-24         |
| 3.2.5                                |                                                                                                                                                                                                     | 3-25         |
| 3.3                                  | DMA Module Kernel Registers                                                                                                                                                                         |              |
| 3.3.1                                | General Control/Status Registers                                                                                                                                                                    | 3-28         |
| 3.3.2                                | Move Engine Registers                                                                                                                                                                               | 3-37         |
| 3.3.3                                | Channel Control/Status Registers                                                                                                                                                                    |              |
| 3.3.4                                | Channel Address Registers                                                                                                                                                                           |              |
|                                      | -                                                                                                                                                                                                   |              |
| 4                                    | Micro Link Interface (MLI)                                                                                                                                                                          |              |
| 4.1                                  | MLI Protocol                                                                                                                                                                                        |              |
| 4.1.1                                |                                                                                                                                                                                                     |              |
| 4.1.2                                | MLI Specific Terms                                                                                                                                                                                  |              |
| 4.1.3                                | MLI Communication Principles                                                                                                                                                                        |              |
| 4.1.4                                | MLI Frame Types                                                                                                                                                                                     |              |
| 4.1.4.1                              | Copy Base Address Frame                                                                                                                                                                             |              |
| 4.1.4.2                              | Write Offset and Data Frame                                                                                                                                                                         |              |
| 4.1.4.3                              | Optimized Write Frame                                                                                                                                                                               | 4-10         |
| 4.1.4.4                              | Discrete Read Frame                                                                                                                                                                                 | 4-11         |
| 4.1.4.5                              | Optimized Read Frame                                                                                                                                                                                | 4-12         |
| 4.1.4.6                              |                                                                                                                                                                                                     | 4-13         |
| 4.1.4.7                              | Answer Frame                                                                                                                                                                                        | 4-14         |
| 4.1.5                                | Naming Conventions                                                                                                                                                                                  | 4-15         |
| 4.1.6                                | MLI Communication Examples                                                                                                                                                                          | 4-15         |
| 4.1.6.1                              | Ready Delay Time                                                                                                                                                                                    | 4-16         |
| 4.1.6.2                              | Non-Acknowledge Error                                                                                                                                                                               |              |
| 4.1.7                                | Parity Generation                                                                                                                                                                                   | 4-17         |
| 4.1.8                                | Address Prediction                                                                                                                                                                                  | 4-17         |
| 4.2                                  |                                                                                                                                                                                                     | 4-19         |
| 4.2.1                                | Frame Handling                                                                                                                                                                                      | 4-19         |
| 4.2.1.1                              | Copy Base Address Frame                                                                                                                                                                             | 4-19         |
| 4.2.1.2                              | Data Frames                                                                                                                                                                                         | 4-22         |
| 4.2.1.3                              | Read Frames                                                                                                                                                                                         | 4-26         |
| 4.2.1.4                              | Answer Frame                                                                                                                                                                                        | 4-29         |
| 4.2.1.5                              |                                                                                                                                                                                                     | 4-30         |
| 4.2.2                                | General MLI Features                                                                                                                                                                                | 4-34         |
| 4.2.2.1                              | Parity Generation and Checking                                                                                                                                                                      | 4-34         |



| 4.2.2.2  | Non-Acknowledge Error                                  | 4-37 |
|----------|--------------------------------------------------------|------|
| 4.2.2.3  | Address Prediction                                     | 4-38 |
| 4.2.2.4  | Automatic Data Mode                                    | 4-39 |
| 4.2.2.5  | Transmit Priority                                      | 4-39 |
| 4.2.3    | MLI Interface Control                                  | 4-40 |
| 4.2.4    | MLI Request Generation                                 | 4-41 |
| 4.2.5    | Transmitter Interrupts                                 | 4-41 |
| 4.2.5.1  | Parity/Time-out Error Interrupt                        | 4-43 |
| 4.2.5.2  | Normal Frame Sent x Interrupt                          | 4-43 |
| 4.2.5.3  | Command Frame Sent Interrupt                           | 4-43 |
| 4.2.6    | Receiver Interrupts                                    | 4-43 |
| 4.2.6.1  | Discarded Read Answer Interrupt                        | 4-43 |
| 4.2.6.2  | Parity Error Interrupt                                 | 4-44 |
| 4.2.6.3  | Normal Frame Received/Move Engine Terminated Interrupt | 4-44 |
| 4.2.6.4  | Interrupt Command Frame Interrupt                      | 4-44 |
| 4.2.6.5  | Command Frame Received Interrupt                       | 4-44 |
| 4.2.7    | Baud Rate Generation                                   | 4-45 |
| 4.3      | MLI Kernel Registers                                   | 4-47 |
| 4.3.1    | General Registers                                      | 4-49 |
| 4.3.1.1  | Fractional Divider Register                            | 4-49 |
| 4.3.1.2  | Set Clear Register                                     | 4-51 |
| 4.3.1.3  | Global Interrupt Set Register                          | 4-53 |
| 4.3.1.4  | Output Input Control Register                          | 4-54 |
| 4.3.2    | MLI Transmitter Registers                              | 4-59 |
| 4.3.2.1  | Transmitter Control Register                           | 4-59 |
| 4.3.2.2  | Transmitter Status Register                            | 4-62 |
| 4.3.2.3  | Transmitter Pipe x Status Registers                    | 4-64 |
| 4.3.2.4  | Transmitter Command Register                           | 4-66 |
| 4.3.2.5  | Transmitter-Receiver Status Register                   | 4-68 |
| 4.3.2.6  | Transmitter Pipe x Address Offset Register             | 4-70 |
| 4.3.2.7  | Transmitter Pipe x Data Register                       | 4-71 |
| 4.3.2.8  | Transmitter Data Read Answer Register                  | 4-72 |
| 4.3.2.9  | Transmitter Pipe x Base Address Register               | 4-73 |
| 4.3.2.10 | Transmitter Copy Base Address Register                 | 4-74 |
| 4.3.3    | MLI Receiver Registers                                 | 4-75 |
| 4.3.3.1  | Receiver Control Register                              | 4-75 |
| 4.3.3.2  | Receiver Pipe x Base Address Register                  | 4-78 |
| 4.3.3.3  | Receiver Pipe x Status Register                        | 4-79 |
| 4.3.3.4  | Receiver Address Register                              | 4-81 |
| 4.3.3.5  | Receiver Data Register                                 | 4-82 |
| 4.3.4    | Transmitter Interrupt Registers                        | 4-83 |
| 4.3.4.1  | Transmitter Interrupt Enable Register                  | 4-83 |
| 4.3.4.2  | Transmitter Interrupt Register                         | 4-85 |



| 4.3.4.3<br>4.3.5<br>4.3.5.1<br>4.3.5.2<br>4.3.5.3 | Transmitter Interrupt Node Pointer Register          Receiver Interrupt Registers          Receiver Interrupt Enable Register          Receiver Interrupt Status Register          Receiver Interrupt Node Pointer Register | 4-86<br>4-88<br>4-88<br>4-90<br>4-92 |
|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| 4.4                                               | MLI Address Map                                                                                                                                                                                                             | 4-94                                 |
| 5                                                 | Synchronous Serial Interface (SSC)                                                                                                                                                                                          |                                      |
| 5.1                                               | Overview                                                                                                                                                                                                                    |                                      |
| 5.2                                               | General Operation                                                                                                                                                                                                           |                                      |
| 5.2.1                                             | SPI Communication Basics                                                                                                                                                                                                    |                                      |
| 5.2.1.1                                           | Full-Duplex Operation                                                                                                                                                                                                       |                                      |
| 5.2.1.2                                           | Half-Duplex Operation                                                                                                                                                                                                       |                                      |
| 5.2.2                                             | Operating the SSC                                                                                                                                                                                                           | . 5-8                                |
| 5.2.2.1                                           | SSC Transaction Header                                                                                                                                                                                                      |                                      |
| 5.2.2.2                                           | SSC Data Flow Model                                                                                                                                                                                                         | . 5-9                                |
| 5.2.3                                             | Operating Mode Selection                                                                                                                                                                                                    | 5-13                                 |
| 5.2.4                                             | Error Detection Mechanisms                                                                                                                                                                                                  | 5-14                                 |
| 5.3                                               | Register Descriptions                                                                                                                                                                                                       | 5-15                                 |
| 5.4                                               | Port Control                                                                                                                                                                                                                | 5-23                                 |
| 5.4.1                                             | Connecting 2 or more CIC751 SSC Slaves to 1 Host                                                                                                                                                                            | 5-23                                 |
| 6                                                 | The Analog/Digital Converter                                                                                                                                                                                                | . 6-1                                |
| 6.1                                               | Mode Selection                                                                                                                                                                                                              | 6-3                                  |
| 6.1.1                                             | Compatibility Mode                                                                                                                                                                                                          | 6-3                                  |
| 6.1.2                                             | Enhanced Mode                                                                                                                                                                                                               | 6-3                                  |
| 6.2                                               | ADC Operation                                                                                                                                                                                                               | . 6-4                                |
| 6.2.1                                             | Channel Selection                                                                                                                                                                                                           | 6-4                                  |
| 6.2.2                                             | ADC Status Flags                                                                                                                                                                                                            | 6-4                                  |
| 6.2.3                                             | ADC Start/Stop Control                                                                                                                                                                                                      | 6-4                                  |
| 6.2.4                                             | Conversion Mode Selection                                                                                                                                                                                                   |                                      |
| 6.2.5                                             | Conversion Resolution Control                                                                                                                                                                                               | . 6-6                                |
| 6.2.5.1                                           | Conversion Result                                                                                                                                                                                                           | . 6-6                                |
| 6.2.6                                             | Fixed Channel Conversion Modes                                                                                                                                                                                              | 6-6                                  |
| 6.2.7                                             | Auto Scan Conversion Modes                                                                                                                                                                                                  | 6-6                                  |
| 6.2.8                                             | Wait for Read Mode                                                                                                                                                                                                          |                                      |
| 6.2.9                                             | Channel Injection Mode                                                                                                                                                                                                      |                                      |
| 6.2.10                                            | Arbitration of Conversions                                                                                                                                                                                                  |                                      |
| 6.3                                               | Automatic Calibration                                                                                                                                                                                                       | 6-11                                 |
| 6.4                                               | Multiplexer Test Mode                                                                                                                                                                                                       | 6-11                                 |
| 6.5                                               | Conversion Timing Control                                                                                                                                                                                                   | 6-12                                 |
| 6.6                                               | A/D Converter Interrupt Operation                                                                                                                                                                                           | 6-15                                 |
| 6.6.1                                             | Interrupt Event Handling                                                                                                                                                                                                    | 6-15                                 |
| 6.6.1.1                                           | Trigger an DMA Action                                                                                                                                                                                                       | 6-15                                 |
| 0.0.1.1                                           |                                                                                                                                                                                                                             | 0 10                                 |



| 6.6.1.2<br>6.7<br>6.7.1<br>6.7.2<br>6.7.3<br>6.7.3.1<br>6.7.3.2<br>6.8<br>6.8.1<br>6.8.2<br>6.8.3<br>6.8.4<br>6.8.5 | Forward to an SRn Pin<br>ADC Buffer Registers<br>Overview<br>Extended Result Registers<br>Doorbell Mechanism<br>Trigger an DMA Transfer<br>Stimulate SRn Pins<br>ADC Registers<br>ADC Control Registers for Compatibility Mode<br>ADC Control Registers for Enhanced Mode<br>ADC Result Registers<br>ADC Result Registers<br>ADC Extended Result Registers<br>ADC Doorbell Register | 6-16 |
|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 7                                                                                                                   | Parallel Ports                                                                                                                                                                                                                                                                                                                                                                      | 7_1  |
| 7.1                                                                                                                 | Port 0                                                                                                                                                                                                                                                                                                                                                                              |      |
| 7.1.1                                                                                                               | Block Diagram                                                                                                                                                                                                                                                                                                                                                                       |      |
| 7.1.2                                                                                                               | Input Stage                                                                                                                                                                                                                                                                                                                                                                         |      |
| 7.1.3                                                                                                               | Port 0 Routing                                                                                                                                                                                                                                                                                                                                                                      |      |
| 7.1.4                                                                                                               | Port 0 Register Description                                                                                                                                                                                                                                                                                                                                                         |      |
| 7.1.4.1                                                                                                             | Port 0 Control Register                                                                                                                                                                                                                                                                                                                                                             |      |
| 7.2                                                                                                                 | Port 1                                                                                                                                                                                                                                                                                                                                                                              |      |
| 7.2.1                                                                                                               | Block Diagram                                                                                                                                                                                                                                                                                                                                                                       | 7-13 |
| 7.2.2                                                                                                               | Input Stage                                                                                                                                                                                                                                                                                                                                                                         | 7-13 |
| 7.2.3                                                                                                               | Port 1 Routing                                                                                                                                                                                                                                                                                                                                                                      | 7-14 |
| 7.2.4                                                                                                               | Port 1 Register Description                                                                                                                                                                                                                                                                                                                                                         | 7-15 |
| 7.2.4.1                                                                                                             | Port Input Register                                                                                                                                                                                                                                                                                                                                                                 | 7-15 |
| 7.3                                                                                                                 | Ports Register Overview                                                                                                                                                                                                                                                                                                                                                             | 7-15 |
| 8                                                                                                                   | Register Overview                                                                                                                                                                                                                                                                                                                                                                   | 8-1  |
| 8.1                                                                                                                 | Address Map of CIC751                                                                                                                                                                                                                                                                                                                                                               |      |
| 8.1.1                                                                                                               | Access Rules                                                                                                                                                                                                                                                                                                                                                                        |      |
| 8.2                                                                                                                 | Registers Tables                                                                                                                                                                                                                                                                                                                                                                    |      |
| 8.3                                                                                                                 | Memory Registers                                                                                                                                                                                                                                                                                                                                                                    | 8-15 |





## 1 Introduction

The CIC751 is a companion IC for the Infineon AUDO-NG family of 32-bit microcontrollers. The major function of the CIC751 is to provide the AUDO-NG 32-bit microcontrollers with the capability of a 5 V Analog to Digital Converter (ADC). The interconnection of the CIC751 and the microcontroller is accomplished via either the Micro Link Interface (MLI) or the Synchronous Serial Interface (SSC). Internal operations of the CIC751 are supported by the very flexible on-chip DMA controller.

#### 1.1 Overview

**Figure 1-1** provides the block diagram of the CIC751 companion chip. This design allows access to the ADC by the host CPU without sacrificing any of the features of the ADC. This can be achieved because all registers of the ADC are mapped to the on-chip bus. This bus can be accessed via one of the two serial interfaces. Selection of the interface is made via pin MODE, which can be directly connected to the supply voltage or via pull-up/down resistors.

The bus domain is completely separated from the address domain on the CPU chip. The addresses of all modules on the companion chip are 32-bit addresses. Transactions between the CPU and the SSC are executed with the SSC transmission protocol; transactions between the MLI and the CPU use the MLI transmission protocol.

Each transaction via any of the two serial interfaces is defined by address, data, data width, and type of frame. The address from which data is read or written to, is related to the address domain. The data width may be 8, 16 or 32 bits for the MLI and 16 bits for the SSC. The ADC and the MLI may send request triggers to the DMA Controller.





Figure 1-1 CIC751 Block Diagram

#### 1.2 Features

This section provides a high-level description of the features on the CIC751.

- 5 V Analog to Digital Converter
- 16 analog input channels
- Internal low power oscillator
- Slave (SPI) SSC interface operating on 5 V or 3.3 V
- MLI Interface operating on 5 V or 3.3 V
- Maximum system frequency of 40 MHz
- Low-power design
- Single power supply concept design (for pad and core supply)
- Seperated ADC supply
- Input and output pins with 3.3 V and 5.0 V
- Flexible clocking concept
- Crossbar bus architecture

## 1.2.1 Detailed Features

The following sections provide detailed information about each of the on-chip modules.



## 1.2.1.1 ADC

The CIC751 provides an Analog/Digital Converter with 8-bit or 10-bit resolution and a sample & hold circuit on-chip. An input multiplexer selects between up to 16 analog input channels either via software (Fixed Channel Modes) or automatically (Auto Scan Modes).

To fulfill most requirements of embedded control applications, the ADC supports the following conversion modes:

- Standard Conversions
  - Fixed Channel Single Conversion
     produces just one result from the selected channel
  - Fixed Channel Continuous Conversion repeatedly converts the selected channel
  - Auto Scan Single Conversion
     produces one result from each of a selected group of channels
  - Auto Scan Continuous Conversion repeatedly converts the selected group of channels
  - Wait for Read Mode start a conversion automatically when the previous result was read
- **Channel Injection Mode** can insert the conversion of a specific channel into a group conversion (auto scan)

The key features of the ADC are:

- Use of Successive Approximation Method
- Integrated sample and hold functionality
- Analog Input Voltage Range from 0V to 5V
- 16 Analog Input Channels
- 16 ADC result registers
- Resolution:
   8 Bit or 10 Bit in Compating
- 8-Bit or 10-Bit in Compatibility Mode
- Minimum Conversion Time: 2.55 µs @ 10-Bit
- Total Unadjusted Error (TUE):±1 LSB @ 8-Bit, ± 2 LSB @ 10-Bit
- Support of several Conversion Modes
   Fixed Channel Single Conversion
   Fixed Channel Continuous Conversion
   Auto Scan Single Conversion
   Auto Scan Continuous Conversion
   Wait for Result Read and Start Next Conversion
   Channel Injection during Group Conversion
- Programmable Conversion and Sample Timing Scheme
- Automatic Self-Calibration to changing temperatures or process variations



## 1.2.1.2 MLI

The Micro Link Interface (MLI) is a fast synchronous serial interface that makes it possible to exchange data between microcontrollers or other devices.

The key features of the MLI are:

- Synchronous serial communication between an MLI transmitter and an MLI receiver
- Different system clock speeds are supported in the MLI transmitter and MLI receiver due to full handshake protocol (4 lines between a transmitter and a receiver)
- Fully transparent read/write access is supported (= remote programming)
- Complete address range of target device (Remote Controller) is available
- Specific frame protocol to transfer commands, addresses, and data
- Error detection by parity bit
- 32-bit, 16-bit, or 8-bit data transfers are supported
- Programmable baud rate:  $f_{MLI}/2$  (max.:  $f_{MLI} = f_{SYS}$ )
- Multiple receiving devices are supported

## 1.2.1.3 SSC

The SSC supports full-duplex and half-duplex serial synchronous communication up to 10 Mbit/s (@ 40 MHz module clock). The serial clock signal is received from an external master (Slave Mode). Data width, shift direction, clock polarity, and phase are programmable. This allows communication with SPI-compatible devices. Transmission and reception of data is double-buffered. A shift clock generator provides the SSC with a separate serial clock signal.

This section describes only the use of the SSC module as a slave because the CIC751 always operates as a slave to a host.

#### Features

- Slave Mode operation
  - Full-duplex or half-duplex operation
  - Automatic pad control possible
- Flexible data format
  - Programmable shift direction: LSB or MSB shift first
  - Programmable clock polarity: Idle low or idle high state for the shift clock
  - Programmable clock/data phase: Data shift with leading or trailing edge of the shift clock
  - Internal Master Function
    - Access to the all addresses
    - Automatic address handling
    - Automatic data handling



## 1.3 Signal Description

This section describes signals that connect off chip. **Table 1-1** gives a summery of the CIC751 external signals (pins).

| Table 1-1 | Pin Definitio | a Functions |                                                                                    |
|-----------|---------------|-------------|------------------------------------------------------------------------------------|
| Symbol    | Pin/Port      | I/O         | Function                                                                           |
| AIN0      | 35<br>P1.0    | I           | Analog Input 0 <sup>1)</sup><br>For this pin a Multiplexer Test Mode is available. |
| AIN1      | 36<br>P1.1    | I           | Analog Input 1 <sup>1)</sup>                                                       |
| AIN2      | 37<br>P1.2    | I           | Analog Input 2 <sup>1)</sup>                                                       |
| AIN3      | 38<br>P1.3    | I           | Analog Input 3 <sup>1)</sup>                                                       |
| AIN4      | 1<br>P1.4     | I           | Analog Input 4 <sup>1)</sup>                                                       |
| AIN5      | 2<br>P1.5     | I           | Analog Input 5 <sup>1)</sup>                                                       |
| AIN6      | 7<br>P1.6     | I           | Analog Input 6 <sup>1)</sup>                                                       |
| AIN7      | 8<br>P1.7     | I           | Analog Input 7 <sup>1)</sup>                                                       |
| AIN8      | 5<br>P1.8     | I           | Analog Input 8 <sup>1)</sup>                                                       |
| AIN9      | 6<br>P1.9     | I           | Analog Input 9 <sup>1)</sup>                                                       |
| AIN10     | 3<br>P1.10    | I           | Analog Input 10 <sup>1)</sup>                                                      |
| AIN11     | 4<br>P1.11    | I           | Analog Input 11 <sup>1)</sup>                                                      |
| AIN12     | 11<br>P1.12   | I           | Analog Input 12 <sup>1)</sup>                                                      |
| AIN13     | 12<br>P1.13   | I           | Analog Input 13 <sup>1)</sup>                                                      |
| AIN14     | 13<br>P1.14   | I           | Analog Input 14 <sup>1)</sup>                                                      |

 Table 1-1
 Pin Definitions and Functions



## **CIC751**

## Introduction

| Symbol      | Pin/Port    | I/O | Function                                                                                        |
|-------------|-------------|-----|-------------------------------------------------------------------------------------------------|
| AIN15       | 14<br>P1.15 | I   | Analog Input 15 <sup>1)</sup>                                                                   |
| VAREF       | 9           | I   | Analog Reference Voltage                                                                        |
| VAGND       | 10          | I   | Analog Ground                                                                                   |
| TCLK/SR3    | 17<br>P0.0  | I/O | MODE = 0:<br>MLI Transmit Channel Clock Output<br>MODE = 1:<br>Event output line 3              |
| TREADY/SR4  | 19<br>P0.1  | I/O | MODE = 0:<br>MLI Transmit Channel Ready Input<br>MODE = 1:<br>Event request output line 4       |
| TVALID/SCLK | 20<br>P0.2  | I/O | MODE = 0:<br>MLI Transmit Channel Valid Output<br>MODE = 1:<br>SPI Serial Channel Clock         |
| TDATA/MRST  | 21<br>P0.3  | I/O | MODE = 0:<br>MLI Transmit Channel Data Output<br>MODE = 1:<br>SPI Master Receive Slave Transmit |
| RCLK        | 22<br>P0.4  | I/O | MODE = 0:<br>MLI Receive Channel Clock Input<br>MODE = 1:<br>GPIO                               |
| RREADY/RDY  | 23<br>P0.5  | I/O | MODE = 0:<br>MLI Receive Channel Ready Output<br>MODE = 1:<br>SSC Ready Signal                  |
| RVALID/SLS  | 24<br>P0.6  | I/O | MODE = 0:<br>MLI Receive Channel Valid Input<br>MODE = 1:<br>SSC Select Slave                   |
| RDATA/MTSR  | 25<br>P0.7  | I/O | MODE = 0:<br>MLI Receive Channel Data Input<br>MODE = 1:<br>SPI Master Transmit Slave Receive   |



## **CIC751**

#### Introduction

| Symbol                 | Pin/Port       | I/O                    | Function                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|------------------------|----------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MODE <sup>2)</sup>     | 26 I/O<br>P0.8 |                        | Interface Selection<br>Pin MODE selects whether the on-chip MLI or<br>SSC are used to access the CIC751 device.<br>0: On-chip MLI<br>1: On-chip SSC<br>Event request output line 5 (SR5)<br>After latching the initial state with the rising edge of<br>the PORST signal (see Chapter 2.5), this pin car<br>be used as an additional general purpose or SR5<br>output line. |  |  |  |
| TESTMODE <sup>3)</sup> | 27<br>P0.9     | I/O                    | Test Mode Selection<br>0: Reserved; do no use<br>1: Normal Mode<br>After latching the initial state with the rising edge of<br>the PORST signal, this pin can be used as an<br>additional general purpose or special function I/O<br>line (see Chapter 2.5).                                                                                                                |  |  |  |
| SR0                    | 28<br>P0.10    | I/O                    | Event request output line 0                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| SR1                    | 29<br>P0.11    | I/O                    | External Trigger                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| SR2                    | 30<br>P0.12    | I/O                    | External Trigger                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| PORST                  | 31             | I                      | Power-on Reset                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| V <sub>DDM</sub>       | 34             | +5 V                   | Power Supply, supply for ADC module                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| V <sub>DDP</sub>       | 18, 33         | +3.3 V<br>or<br>+5.0 V |                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| V <sub>DDC</sub>       | 16             | +2.5 V                 | Power Supply, supply for digital module cores                                                                                                                                                                                                                                                                                                                               |  |  |  |
| V <sub>ss</sub>        | 15, 32         | 0 V                    | Ground                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |

#### Table 1-1 Pin Definitions and Functions (cont'd)

1) In addition to the analog input function of pin P1.x, a digital input stage is available. This input stage is activated while STCU\_SYSCON.P1DIDIS = 0.

2) The initial logic state on pin MODE is latched while the PORST input is active. A weak pull-up can be disabled if used as the SR5 pin.

3) The initial logic state on pin TESTMODE is latched while the PORST input is active.

Figure 1-2 shows the pin-out for a 38-pin package.





Figure 1-2 Pins for P/PG-TSSOP-38 Package







Figure 1-3 Pin Numbering for P/PG-TSSOP-38 Package



## 2 System and Control Unit (SCU)

The System and Control Unit (SCU) controls all system relevant tasks.

The system tasks of the SCU are:

- Reset operation (see Chapter 2.1)
- System clock control (see Chapter 2.3)
- Power supply system (see Chapter 2.4)
- System Interrupt control (see Chapter 2.5)

## 2.1 Reset Control Block

The single system reset function initializes the CIC751 into a defined default state and is invoked by any of the following trigger conditions:

- External PORST reset
  - Power-on reset; indicated by hardware reset input after power-on
- Internal EVR fail reset
  - The EVR encounters a problem and the required power supply levels are not longer guaranteed
- Setting bit SCU\_SYSCON.SWRST
  - This generates a software trigger reset

The entire CIC751 is reset, regardless of the means by which the reset was generated. A reset always triggers a new mode selection phase with the exception that a software reset does not trigger a new Mode Selection. A software reset retains the mode currently selected.

## 2.1.1 **Power-On Reset**

The PORST input pin requests a power-on reset. Driving the PORST pin low causes a non-synchronized reset of the entire device.

PORST is equipped with a noise suppression filter which suppresses glitches below 10 ns pulse width. PORST pulses with a width above 100 ns are safely recognized.

## 2.1.2 Embedded Voltage Regulator (EVR) Reset

If the power supply does not reach the value required for proper functionality, a reset is applied. This ensures a reproducible behavior after power-on or in the case of power-fail.

## 2.2 Mode Selection

The pins TESTMODE and MODE should supplied with specific voltage levels to ensure correct configuration of the CIC751.



## 2.2.1 MODE Pin

The MODE pin defines whether the MLI interface or the SSC interface is activated for Normal Mode. For MODE = 0, the MLI interface is activated and configured as the only communication interface. For MODE = 1, the SSC interface is activated and configured as the only communication interface.

The value that is sampled and used for this decision must be held for 400  $\mu s$  after  $V_{\text{DDP}}$  reached 1.5 V.

## 2.2.2 TESTMODE Pin

The pin must be tied to '1'.

#### 2.3 Clock System

This section describes the clock system of the CIC751. Topics include clock generation, clock domains, operation of clock circuitry, and clock control registers.

#### 2.3.1 Overview

The CIC751 clock system performs the following functions:

- Uses the internal free running frequency of the VCO block to create a fast clock frequency  $f_{SYS}$ .
- Uses the internal oscillator of the VCO block to create a fast clock frequency  $f_{SYS}$ .
- Acquires and buffers the external clock signal (RCLK) to create a fast clock frequency  $f_{SYS}$ .
- Distributes the in-phase synchronized clock signal throughout the CIC751's entire clock tree.

The clock system must be operational before the CIC751 can operate, so it contains special logic to handle power-up and reset operations. Its services are fundamental to the operation of the entire system, so it contains a special fail-safe logic.

#### 2.3.2 Clock Generation Unit

The Clock Generation Unit (CGU) allows very flexible clock generation for CIC751.

The CGU in the CIC751 consists of an oscillator circuit (RCOSC), one Phase-Locked Loop (PLL) module, and a Clock Control Unit (CCU). The CGU can convert a low-frequency clock signal to a high-speed internal clock.





#### Figure 2-1 Clock Generation Unit Block Diagram

The following sections describe the various parts of the CGU:

## 2.3.2.1 RC Oscillator Circuit (RCOSC)

The RC Oscillator Circuit (RCOSC) is designed to work without an external crystal oscillator or an external stable clock source. The RCOSC consists of an Schmitt Trigger RC oscillator core and a standard current reference to provide a VDD-independent bias current.

#### Internal Clock Mode

When operating without an external crystal or clock source, the RC oscillator provides a stabile clock frequency of 9 MHz. The stability of this clock frequency is influenced by the temperature.

The system clock  $f_{SYS}$  (for Normal Mode equal to  $f_{PLL}$ ) is generated from an oscillator clock  $f_{OSC}$  in one of four selectable ways:

- Bypass Mode (Direct Drive)
- Prescaler Mode
- Normal Mode
- Free running Mode



## 2.3.2.2 Phase-Locked Loop (PLL) Module

This section describes the PLL module of the CIC751. The PLL supplies the system with a single clock frequency.

## Features

- Programmable clock generation PLL
- Loop filter
- Input frequency<sup>1)</sup>: $f_{OSC} = 3.1$  to 37.5 MHz
- VCO frequency:  $f_{VCO} = 100$  to 250 MHz (select by range)
- VCO lock detection
- Oscillator run detection
- Output frequency: $f_{PLL} = 6.25$  to 250 MHz
- 2bit input divider P:(divide by PDIV+1)
- 5bit feedback divider N:(multiply by NDIV+1, stability restrictions possible)
- 4bit output divider K:(divide by KDIV+1)
- Bypass Mode
- Prescaler Mode
- Freerunning Mode
- Normal Mode
- Glitchless switching between Normal Mode and Prescaler Mode

#### PLL Functional Description

The PLL provides the system with a clock generated from one of the various potential clock sources.

<sup>1)</sup> For P = 1, otherwise multiplied by P.





## Figure 2-2 PLL Block Diagram

The PLL uses up to three dividers to manipulate the input frequency in a configurable way. Each of the three dividers can be bypassed in some way to define an operating mode

Bypassing P, N, and K divider; this defines the Bypass Mode

Bypassing N divider; this defines the Prescaler Mode

Bypassing no divider; this defines the Normal Mode

Ignoring the P divider; this defines the Freerunning Mode

#### Normal Mode

In Normal Mode, the input clock  $f_{OSC}$  is divided by a factor P, multiplied by a factor N, and then divided by a factor K.

So, the output frequency is given by

$$f_{PLL} = \frac{N}{P \cdot K} \cdot f_{OSC}$$
 (2.1)



The Normal Mode is selected by setting SCU\_PLLCON.PLLCTRL =  $11_B$ .

#### **Bypass Mode**

In Bypass Mode, the input clock  $f_{\rm OSC}$  is directly connected to the PLL output  $f_{\rm PLL}$ . So, the output frequency is given by

$$f_{PLL} = f_{OSC}$$
(2.2)

The Bypass Mode is selected by setting SCU\_PLLCON.BY =  $1_B$ .

#### **Prescaler Mode**

In Prescaler Mode, the input clock  $f_{OSC}$  is divided down by a factor P \* K. So, the output frequency is given by

$$f_{PLL} = \frac{f_{OSC}}{P \cdot K}$$
(2.3)

The Prescaler Mode is selected by setting SCU\_PLLCON.PLLCTRL =  $00_{B}$ .

#### Freerunning Mode

In Freerunning Mode, the base frequency output of the Voltage Controlled Oscillator (VCO)  $f_{\text{VCObase}}$  is only divided by a factor K.

So, the output frequency is given by

$$f_{PLL} = \frac{f_{VCObase}}{K}$$
 (2.4)

The Freerunning Mode is selected by setting SCU\_PLLCON.PLLCTRL =  $10_B$ .

#### **General Configuration Overview**

All three divider values and all necessary other values can be configured via the PLL configuration register **SCU\_PLLCON**.

**Table 2-1** lists a few possible values for the P factor and gives the valid output frequency range for the P divider dependent on P and the  $f_{OSC}$  frequency range:



| P = PDIV+1 | PDIV |            | =      |        |                  |        |
|------------|------|------------|--------|--------|------------------|--------|
|            |      | 4 MHz      | 10 MHz | 16 MHz | 20 MHz           | 25 MHz |
| 1          | 0    | 4          | 10     | 16     | 20               | 25     |
| 2          | 1    | not        | 5      | 8      | 10               | 12.5   |
| 3          | 2    | allowed    | 3.33   | 5.33   | 6.6 <del>6</del> | 8.33   |
| 4          | 3    | not allowe | ed     | 4      | 5                | 6.25   |

Divider Festere

Note: Of course, the entire range between two  $f_{OSC}$  columns in the above table is allowed. E.g. for a range  $f_{OSC} = 20$  to 25, and P = 3,  $f_{RFF} = 6.6\overline{6}$  to  $8.3\overline{3}$  MHz.

The P-divider output frequency  $f_{\text{REF}}$  is fed to a Voltage Controlled Oscillator (VCO). The VCO is part of the PLL with a feedback path. A divider in the feedback path (N divider) divides the VCO frequency. As well as N, the correct range of  $f_{VCO}$  must be chosen by configuring SCU\_PLLCON.PLLVB:

| PLLVB [1:0] | $f_{\sf VCOmin}$     | $f_{\sf VCOmax}$ | $f_{\rm VCObase}$ <sup>1)</sup> | Unit |  |
|-------------|----------------------|------------------|---------------------------------|------|--|
| 01          | 150                  | 200              | 40130                           | MHz  |  |
| 00          | 100                  | 150              | 2080                            | MHz  |  |
| 10          | 200                  | 250              | 60180                           | MHz  |  |
| 11          | Reserved; do not use |                  |                                 |      |  |

1) f<sub>VCObase</sub> is the free running operation frequency of the PLL, when no input clock is available. These values are only preliminary and are later updated with more exact simulation and measurement results from the PLL.

The VCO band (100...150 MHz, 150...200 MHz, 200...250 MHz) must be selected according to the desired VCO output frequency (100...250 MHz). Figure 2-3 illustrates how this output frequency depends on the input frequency and the multiplication factor.





#### Figure 2-3 VCO Band Selection

**Table 2-3** lists the possible N loop division rates and gives the valid output frequency range for  $f_{\text{REF}}$  depending on N and the VCO frequency range:

| N = NDIV+1 | NDIV | $f_{\sf REF}$ for $f_{\sf VCO}$ = |                   |       |       |  |  |  |  |
|------------|------|-----------------------------------|-------------------|-------|-------|--|--|--|--|
|            |      | 100                               | 150               | 200   | 250   |  |  |  |  |
| <b>≤</b> 7 | ≤ 6  | not allowe                        | əd <sup>1)</sup>  |       | L     |  |  |  |  |
| 8          | 7    |                                   | 18.75             | 25.00 | 31.25 |  |  |  |  |
| 9          | 8    | 11.11                             | 16.6 <del>6</del> | 22.22 | 27.77 |  |  |  |  |
| 10         | 9    | 10.00                             | 15.00             | 20.00 | 25.00 |  |  |  |  |
| 1130       | 1029 |                                   |                   |       |       |  |  |  |  |
| 31         | 30   | 3.22                              | 4.84              | 6.45  | 8.06  |  |  |  |  |
| 32         | 31   | 3.13                              | 4.69              | 6.25  | 7.81  |  |  |  |  |

#### Table 2-3N Loop Division Rates

1)Values in this range are allowed in Freerunning Mode, but have no impact there.

Note: Of course, the entire range between two  $f_{\rm VCO}$  columns in the above table is allowed.

The N-divider output frequency  $f_{\text{DIV}}$  is then compared with  $f_{\text{REF}}$  in the phase detector logic, which is within the VCO logic. The phase detector determines the difference between the two clock signals and accordingly controls the output frequency of the VCO,  $f_{\text{VCO}}$ .

Note: Due to this operation, the VCO clock of the PLL has a frequency that is a multiple of  $f_{REF}$ . The factor for this is controlled through the value applied to the N-divider in the feedback path. For this reason, this factor is often called a multiplier, although it actually controls division.

The output frequency of the VCO,  $f_{VCO}$ , is divided by K to provide the final desired output frequency  $f_{PLL}$ . Table 2-4 lists the output frequency range depending on the K divisor and the VCO frequency range:

| K =<br>K2DIV+1 | K2<br>DIV |       | Duty Cycle<br>[%] |                  |                  |         |
|----------------|-----------|-------|-------------------|------------------|------------------|---------|
|                |           | 100   | 150               | 200              | 250              |         |
| 1              | 0         | 100.0 | 150.0             | 200.0            | 250.0            | 45 - 55 |
| 2              | 1         | 50.0  | 75.0              | 100.0            | 125.0            | 50      |
| 3              | 2         | 33.3  | 50.0              | 66. <del>6</del> | 83.3             | 33      |
| 4              | 3         | 25.0  | 37.5              | 50.0             | 62.5             | 50      |
| 5              | 4         | 20.0  | 30.0              | 40.0             | 50.0             | 40      |
| 614            | 513       |       |                   |                  |                  |         |
| 15             | 14        | 6.6   | 10.0              | 13. <del>3</del> | 16. <del>6</del> | 46.6    |
| 16             | 15        | 6.25  | 9.38              | 12.5             | 18.75            | 50      |

Table 2-4K Divisor Table

Note: Note that the entire range between two  $f_{vco}$  columns in the above table is allowed.

Note: For divider factors that cause duty cycles far from 50% not only the cycle time has to be checked, but also the minimum clock pulse width.

#### **Oscillator Run Detection**

Oscillator Run Detection monitors the incoming clock from the oscillator and determines whether it is suitable for an operation in Normal Mode with the selected setting for the N-Divider. Only incoming frequencies that are too low to enable a stable operation of the VCO circuit are detected.



#### PLL Configuration and Status Registers

The PLL Configuration and Status Registers hold the hardware configuration bits of the PLL, and provide the control for the N, P and K-Dividers as well as the PLL status information.

The clock generation path is selected via the PLL control register SCU\_PLLCON.

## 2.3.2.3 Clock Control Unit

The Clock Control Unit (CCU) receives the clock that is created by the PLL  $f_{\rm PLL}$ . In Normal Mode the PLL output frequency  $f_{\rm PLL}$  is always used directly as the system clock  $f_{\rm SYS}$ .

## 2.4 Power Supply System

The power supply system is selected such that it offers maximum flexibility and requires a minimum of pins and system integration cost.

Features:

- 5 V supply for the ADC
- 5 V or 3.3 V supply for the I/O pads



Figure 2-4 CIC751 Power Supply System



## 2.4.1 Embedded Voltage Regulator

The Embedded Validated Voltage Regulator (EVR) is used for the reduction of supply interfaces between PCB and CIC751. In addition to the I/O voltage VDDP, the voltage supply for the core VDD is necessary. The handling of two different supply voltages can have a large impact on application board design. Thus, it is highly appreciated to provide the on-chip voltage by an on-chip voltage regulator. This embedded voltage regulator further helps reduce the power consumption of the entire chip.

## 2.5 Event Control

Events or interrupts are generated towards the system by the ADC, SSC, MLI, DMA, and pins. In this chip, the term event is used because the term interrupt is normally linked with the interruption of a code execution but a code executing unit is not present within the CIC751.

## 2.5.1 Event Sources

There are 13 event sources available for the CIC751.

- ADC event 0; injection conversion interrupt of the ADC module
- ADC event 1; standard conversion interrupt of the ADC module
- ADC event 2; the OR-combination of all valid bits of the ADC\_RESBn registers
- Doorbell event 0 that becomes active if the channel number written to INRES equals DBCTR.COMP0
- Doorbell event 1 that becomes active if the channel number written to INRES equals DBCTR.COMP1
- Doorbell event 2 that monitors the valid bit ADC\_RESBn.V of the result register selected by DBCTR.COMP0
- Doorbell event 3 that monitors the valid bit ADC\_RESBn.V of the result register selected by DBCTR.COMP1
- MLI Request 0 of the MLI module
- MLI Request 1 of the MLI module
- MLI Request 2 of the MLI module
- MLI Request 3 of the MLI module
- External trigger Input 0
- External trigger Input 1

## 2.5.2 External Trigger Inputs

The device supports external trigger sources to start ADC conversions or DMA transfers. The device has several input pins (SR0 - 2 for MLI Mode and SR0 - 4 for SSC Mode) capable of delivering a trigger input signal.





#### Figure 2-5 External Triggers

The rising edge and falling edge sensitivity of the selected input can be enabled individually. If both edge detections are enabled, an external trigger event is generated upon each change of the signal level (rising edge or falling edge).

The external trigger control register SCU\_ETCTR contains the bits defining the behavior of the external trigger inputs.

## 2.5.3 Event Output Structure

The CIC751 allows output of internal status or notification events on output pins. In order to support different applications and pin usage, internal events are generated. These events are then distributed to the service request pins SRn (n = 0...5).

The following status events can be selected as the source for an output of an SRn pin:

- Doorbell event 2
- Doorbell event 3
- ADC event 2; the OR-combination of all valid bits of the ADC\_RESBn registers
- ADC event 0
- ADC event 1



#### 2.5.3.1 Service Request Routing

The service request routing allows the user to combine the various events as output for the pins SRx. The alternative data outputs of the SRx pins are connected as shown in **Figure 2-6**.



Figure 2-6 Service Request Routing



## 2.6 SCU Registers

## 2.6.1 Clock Control Registers

The following register controls the clock system of the CIC751.

|    | CU_OSCCON<br>CU Oscillator Control Register |    |    |    |    |    | (80 | 00 <sub>H</sub> ) |    |    | Res    | et Va      | lue: 0   | 0000 ( | 0020 <sub>H</sub> |
|----|---------------------------------------------|----|----|----|----|----|-----|-------------------|----|----|--------|------------|----------|--------|-------------------|
| 31 | 30                                          | 29 | 28 | 27 | 26 | 25 | 24  | 23                | 22 | 21 | 20     | 19         | 18       | 17     | 16                |
|    | 1                                           | 1  | 1  | 1  | 1  | 1  | (   | 0                 |    | 1  | I<br>I | 1<br>1     |          |        |                   |
| 15 | 14                                          | 13 | 12 | 11 | 10 | 9  | 8   | r<br>7            | 6  | 5  | 4      | 3          | 2        | 1      | 0                 |
|    | 1                                           | 1  | 0  | 1  | 1  | 1  | 0   | RRC               | 0  | 1  | 0      | ORD<br>RES | OSC<br>R | osc    | SEL               |
|    |                                             |    | r  |    |    | I  | rw  | rh                | r  | r  | rw     | rwh        | rh       | r      | W                 |

| Field  | Bits  | Туре | Description                                                                                                                                                                                                                      |
|--------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSCSEL | [1:0] | rw   | Oscillator Select ConfigurationThis bit field selects the oscillator or clock input forthe PLL00The RC oscillator is used01Reserved, do not use10RCLK is directly used11RCLK is directly used (same setting as 10 <sub>B</sub> ) |
| OSCR   | 2     | rh   | Oscillator Run Status BitThis bit shows the state of the oscillator run state.0The oscillator is not running.1The oscillator is running.                                                                                         |
| ORDRES | 3     | rwh  | Oscillator Run Detection Reset0No operation1The oscillator run detection logic is reset and restarted.When set, this bit is automatically cleared.                                                                               |
| RRCOSC | 7     | rh   | RC Oscillator Status0Nominal bias voltages is not reached1Nominal bias voltages is reached                                                                                                                                       |
| 0      | 4, 8  | rw   | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                                                         |



| Field | Bits         | Туре | Description                                              |
|-------|--------------|------|----------------------------------------------------------|
| 1     | 5            | r    | Reserved;<br>Read as 1; should be written with 1.        |
| 0     | 6,<br>[31:9] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0. |

## SCU\_PLLCON

| -  | PLL ( |      | ol Re | giste | r  | (804 <sub>H</sub> ) |       |          |     |      | Reset Value: 0000 6B02 <sub>H</sub> |    |      |    |    |
|----|-------|------|-------|-------|----|---------------------|-------|----------|-----|------|-------------------------------------|----|------|----|----|
| 31 | 30    | 29   | 28    | 27    | 26 | 25                  | 24    | 23       | 22  | 21   | 20                                  | 19 | 18   | 17 | 16 |
|    |       | 1    |       | 1     | 1  | 1                   | •     | <b>)</b> | 1   | 1    | 1                                   | 1  | 1    | 1  | 1  |
| 15 | 14    | 13   | 12    | 11    | 10 | 9                   | 8     | r<br>7   | 6   | 5    | 4                                   | 3  | 2    | 1  | 0  |
| BY | PLLC  | CTRL |       | NDIV  |    |                     | PLLVB |          | _VB | PDIV |                                     |    | KDIV |    |    |
| rw | r     | w    |       | l     | rw | ļ                   | ļ     | r        | w   | r    | w                                   |    | r    | w  | ļ] |

| Field | Bits   | Туре | Description                                                                                                                                                                                                                                     |               |  |  |  |  |
|-------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--|--|
| KDIV  | [3:0]  | rw   | PLL K-Divider<br>Scales the PLL output frequency to the desired CPU<br>frequency.<br>$f_{PLL} = f_{VCO} / (KDIV+1)$                                                                                                                             |               |  |  |  |  |
| PDIV  | [5:4]  | rw   | PLL P-DividerAdjusts the oscillator frequency to the defined inputfrequency range of the PLL $f_{IN} = f_{OSC} / (PDIV+1)$ Valid values: $11_B00_B$                                                                                             |               |  |  |  |  |
| PLLVB | [7:6]  | rw   | PLL VCO Band Select           ValueVCO output frequencyBase frequency           00         100150 MHz           2080 MHz           01         150200 MHz           40130 MHz           10         200250 MHz           11Reserved <sup>1)</sup> |               |  |  |  |  |
| NDIV  | [12:8] | rw   | PLL N-Divider<br>by which the PLL multiplies its in<br>$f_{VCO} = f_{IN} * (NDIV+1)$<br>Valid values: 11111 <sub>B</sub> 00111 <sub>B</sub>                                                                                                     | put frequency |  |  |  |  |



| Field   | Bits    | Туре | Description                                                                                                                                                                                                                                   |
|---------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLLCTRL | [14:13] | rw   | PLL Operation Control00Bypass PLL clock mult., the VCO is off;<br>Prescaler Mode01Reserved, do not use this combination10VCO clock used, input clock switched off;<br>Freerunning Mode11VCO clock used, input clock connected;<br>Normal Mode |
| ВҮ      | 15      | rw   | PLL Bypass Control0PLL operates as defined by bit field CTRL1PLL operates in Bypass Mode                                                                                                                                                      |
| 0       | [31:16] | r    | Reserved;<br>Read as 0; should be written with 0.                                                                                                                                                                                             |

1) Operation in the upper VCO band cannot be guaranteed because of a possible malfunction of the K-divider.

## 2.6.2 Miscellaneous SCU Registers

## SCU\_SYSCON

| SCU | Syste | em Co    | ontro    | rol Register |    |    | (82 | 0 <sub>H</sub> ) Res |    |             | Rese | et Value: 0000 000C <sub>H</sub> |    |     |          |
|-----|-------|----------|----------|--------------|----|----|-----|----------------------|----|-------------|------|----------------------------------|----|-----|----------|
| 31  | 30    | 29       | 28       | 27           | 26 | 25 | 24  | 23                   | 22 | 21          | 20   | 19                               | 18 | 17  | 16       |
|     | 1     | 1        | 1        |              | 1  |    |     | D                    |    |             |      |                                  |    |     |          |
| 15  | 14    | 13       | 12       | 11           | 10 | 9  | 8   | r<br>7               | 6  | 5           | 4    | 3                                | 2  | 1   | 0        |
|     |       |          | 1        | 0            |    |    |     | -                    | ГМ | P1DI<br>DIS |      |                                  | -  |     | LOC<br>K |
| L   | I     | <u> </u> | <u> </u> | r            | I  | I  | Į   | r                    | w  | rw          | rw   | r                                | N  | rwh | rh       |

| Field | Bits | Туре | Description                                          |  |  |  |
|-------|------|------|------------------------------------------------------|--|--|--|
| LOCK  | 0    | rh   | PLL Lock Status Flag0PLL is not locked1PLL is locked |  |  |  |



| Field   | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|---------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| RESLD   | 1      | rwh  | Restart Lock DetectionSetting this bit will reset bit LOCK and restart the lockdetection. When set, this bit is automatically cleared.0No effect1Reset LOCK and restart lock detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| SWRST   | 4      | rw   | <b>Software Reset Trigger</b><br>Setting this bit will automatically request and<br>generate a reset. With the reset execution, this bit is<br>automatically cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P1DIDIS | 5      | rw   | Port 1 Digital Input DisableThis bit controls the digital input stage for all port 1pins.0Digital input stage (Schmitt-trigger) is enabled1Digital input stage (Schmitt-trigger) is disabled.This is necessary if pins are used as analoginput.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| ΜΤΜ     | [7:6]  | rw   | <ul> <li>Multiplexer Test Mode for Channel 0 This bit enables/disables the Multiplexer Test Mode for the input channel 0. This feature is independent of the current mode of the analog part. If the Multiplexer Test Mode is enabled, the analog input is connected to ADC ground via an internal resistance<sup>1)</sup>. This structure creates a voltage divider to ground, so the measurement result becomes smaller. 00 The Multiplexer Test Mode is disabled. The analog input is not connected to ground and can be used for normal measurements. </li> <li>01 The Multiplexer Test Mode is enabled. The internal resistance to ground is in the range of 300 Ohm.</li> <li>10 The Multiplexer Test Mode is enabled. The internal resistance to ground is in the range of 70 Ohm. </li> <li>11 Reserved, like 00</li> </ul> |  |  |  |
| 1       | [3:2]  | rw   | Reserved;<br>Should be written with 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| 0       | [15:8] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |

1) Please refer to the ACDC chapter for the current capability of the grounding resistor, especially when using RC input filters at the analog inputs.

| _        | SCU_ETCTR<br>SCU External Trigger Control Register(850 <sub>H</sub> ) Reset Value: 0000 0000 <sub>H</sub> |    |    |    |    |      |        |          |          | 0000 <sub>H</sub> |    |    |    |      |    |
|----------|-----------------------------------------------------------------------------------------------------------|----|----|----|----|------|--------|----------|----------|-------------------|----|----|----|------|----|
| 31       | 30                                                                                                        | 29 | 28 | 27 | 26 | 25   | 24     | 23       | 22       | 21                | 20 | 19 | 18 | 17   | 16 |
|          | 1                                                                                                         |    |    | 1  | 1  | 1    | ,<br>, | 0        | 1        |                   | 1  | 1  | 1  | 1    | 1  |
| 15       | 14                                                                                                        | 13 | 12 | 11 | 10 | 9    | 8      | r<br>7   | 6        | 5                 | 4  | 3  | 2  | 1    | 0  |
| REN<br>1 | FEN<br>1                                                                                                  |    | 0  | 1  | I  | NSEL | 1      | REN<br>0 | FEN<br>0 |                   | 0  | 1  | I  | NSEL | 0  |
| rw       | rw                                                                                                        |    | r  |    |    | rw   |        | rw       | rw       |                   | r  |    |    | rw   |    |

| Field  | Bits  | Туре | Description                                                                                                                                                                                                                                                                                |
|--------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INSEL0 | [2:0] | rw   | External Trigger Input 0 SelectionThis bit field defines the source for the externaltrigger input 0.000Input SR0 is selected001Input SR1 is selected010Input SR2 is selected011Input SR3 is selected100Input SR4 is selected101MLI Break Event is selected110Input AIN4 is selected        |
| FEN0   | 6     | rw   | <ul> <li>Falling Edge Enable for External Trigger Input 0 This bit enables/disables the activation of external trigger input 0 upon a falling edge at the selected input. </li> <li>0 The trigger upon a falling edge is disabled 1 The trigger upon a falling edge is enabled </li> </ul> |
| REN0   | 7     | rw   | <ul> <li>Rising Edge Enable for External Trigger Input 0 This bit enables/disables the activation of external trigger input 0 upon a rising edge at the selected input. </li> <li>0 The trigger upon a rising edge is disabled 1 The trigger upon a rising edge is enabled </li> </ul>     |



| Field  | Bits                         | Туре | Description                                                                                                                                                                                                                                                                                                |
|--------|------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INSEL1 | [10:8]                       | rw   | External Trigger Input 1 SelectionThis bit field defines the source for the externaltrigger input 1.000Input SR0 is selected001Input SR1 is selected010Input SR2 is selected011Input SR3 is selected100Input SR4 is selected101MLI Break Event is selected110Input AIN4 is selected                        |
| FEN1   | 14                           | rw   | <ul> <li>Falling Edge Enable for External Trigger Input 1</li> <li>This bit enables/disables the activation of external trigger input 1 upon a falling edge at the selected input.</li> <li>0 The trigger upon a falling edge is disabled</li> <li>1 The trigger upon a falling edge is enabled</li> </ul> |
| REN1   | 15                           | rw   | Rising Edge Enable for External Trigger Input 1This bit enables/disables the activation of externaltrigger input 1 upon a rising edge at the selectedinput.00The trigger upon a rising edge is disabled111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111<         |
| 0      | [5:3],<br>[13:11]<br>[31:16] | r    | Reserved;<br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                          |

#### SCU\_SRCR SCU Service Request Control Register(858<sub>H</sub>) Reset Value: 0000 0000<sub>H</sub> 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 0 r 15 13 12 11 8 7 6 5 3 2 14 10 9 4 1 0 INV3 INV2 INV1 INV0 INSEL3 **INSEL2** INSEL1 **INSEL0** rw rw rw rw rw rw rw rw



| Field  | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                   |
|--------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INSEL0 | [2:0]  | rw   | Input Selection for Event 0000No Event is generated001ADC event 2 is used as source010Doorbell event 2 is used as source011Doorbell event 3 is used as source100ADC event 0 is used as source101ADC event 1 is used as source101Reserved, do not use this combination111Reserved, do not use this combination |
| INV0   | 3      | rw   | Invert Source for Event 00The source is not inverted1The source is inverted                                                                                                                                                                                                                                   |
| INSEL1 | [6:4]  | rw   | Input Selection for Event 1000No Event is generated001ADC event 2 is used as source010Doorbell event 2 is used as source011Doorbell event 3 is used as source100ADC event 0 is used as source101ADC event 1 is used as source101Reserved, do not use this combination111Reserved, do not use this combination |
| INV1   | 7      | rw   | Invert Source for Event 10The source is not inverted1The source is inverted                                                                                                                                                                                                                                   |
| INSEL2 | [10:8] | rw   | Input Selection for Event 2000No Event is generated001ADC event 2 is used as source010Doorbell event 2 is used as source011Doorbell event 3 is used as source100ADC event 0 is used as source101ADC event 1 is used as source101Reserved, do not use this combination111Reserved, do not use this combination |
| INV2   | 11     | rw   | Invert Source for Event 20The source is not inverted1The source is inverted                                                                                                                                                                                                                                   |



| Field  | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                   |
|--------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INSEL3 | [14:12] | rw   | Input Selection for Event 3000No Event is generated001ADC event 2 is used as source010Doorbell event 2 is used as source011Doorbell event 3 is used as source100ADC event 0 is used as source101ADC event 1 is used as source101Reserved, do not use this combination111Reserved, do not use this combination |
| INV3   | 15      | rw   | Invert Source for Event 30The source is not inverted1The source is inverted                                                                                                                                                                                                                                   |
| 0      | [31:16] | r    | Reserved;<br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                             |



| _                              |                                             |                    |          |                      | • .          |                 | (0.0             |                                       |    |         | -             |                    |                          |          |                         |
|--------------------------------|---------------------------------------------|--------------------|----------|----------------------|--------------|-----------------|------------------|---------------------------------------|----|---------|---------------|--------------------|--------------------------|----------|-------------------------|
|                                | SCU Channel Trigger 0 Register<br>SCU_CHTR1 |                    |          |                      |              |                 | (83              | 80 <sub>H</sub> )                     |    |         | Res           | et Va              | lue: (                   | 0000     | 0000 <sub>H</sub>       |
| _                              | Chan                                        |                    | rigge    | er 1 R               | egist        | er              | (83              | 64 <sub>H</sub> )                     |    |         | Res           | et Va              | lue: (                   | 0000     | 0000 <sub>н</sub>       |
|                                | _CHT                                        |                    | '        | - 0 0                |              |                 | (02              |                                       |    |         | Dee           | ~4 \/~             | I                        |          |                         |
|                                | Chan<br>CHT                                 |                    | rigge    | er Z R               | egist        | er              | (83              | 88 <sub>H</sub> )                     |    |         | Res           | et va              | iue: (                   | 0000     | 0000 <sub>H</sub>       |
| SCU                            | Chan                                        | nel T              | rigge    | er 3 R               | egist        | er              | (83              | С <sub>н</sub> )                      |    |         | Res           | et Va              | lue: (                   | 0000     | 0000 <sub>H</sub>       |
| _                              | _CHT                                        |                    | riago    | ~ 1 D                | ogict        | or              | (0/              | 0                                     |    |         | Bac           | of Vo              |                          | 000      | 0000                    |
|                                | Chan<br>CHT                                 |                    | ngge     | 14 K                 | eyist        | er              | (04              | ю <sub>н</sub> )                      |    |         | res           | elva               | iue. (                   |          | 0000 <sub>H</sub>       |
|                                | Chan                                        |                    | rigge    | er 5 R               | egist        | er              | (84              | 4 <sub>H</sub> )                      |    |         | Res           | et Va              | lue: (                   | 0000     | 0000 <sub>Н</sub>       |
| SCU_CHTR6                      |                                             |                    |          |                      |              | (0.4            |                  |                                       |    | _       |               |                    |                          |          |                         |
| SCH                            | SCU Channel Trigger 6 Register<br>SCU_CHTR7 |                    |          |                      |              | (84             |                  |                                       |    | RDC     | ot v a        | 1110.1             |                          | nnnn     |                         |
|                                |                                             |                    | rigge    | er 6 R               | egist        | er              | (84              | 8 <sub>H</sub> )                      |    |         | Res           | et va              | lue: (                   | 0000     | 0000 <sub>H</sub>       |
| SCU                            |                                             | R7                 |          |                      | •            |                 |                  | 8 <sub>н</sub> )<br>С <sub>н</sub> )  |    |         |               |                    |                          |          | 0000 <sub>H</sub>       |
| SCU                            | _CHT                                        | R7                 |          |                      | •            |                 |                  |                                       | 22 | 21      |               |                    |                          |          |                         |
| SCU_<br>SCU                    | _CHT<br>Chan                                | R7<br>Inel T       | rigge    | er 7 R               | egist        | er              | <b>(84</b><br>24 | C <sub>H</sub> )                      | 22 | 21      | Res           | et Va              | lue: (                   | 0000     | 0000 <sub>H</sub>       |
| SCU_<br>SCU                    | _CHT<br>Chan                                | R7<br>Inel T       | rigge    | er 7 R               | egist        | er              | <b>(84</b><br>24 | С <sub>н</sub> )<br>23                | 22 | 21      | Res           | et Va              | lue: (                   | 0000     | 0000 <sub>H</sub>       |
| <b>SCU</b><br><b>SCU</b><br>31 | _CHT<br>Chan<br>30                          | R7<br>inel T<br>29 | 28       | e <b>r 7 R</b><br>27 | egisto<br>26 | <b>er</b><br>25 | <b>(84</b><br>24 | C <sub>H</sub> )<br>23<br>0           | I  | 1       | <b>Res</b> 20 | <b>et Va</b><br>19 | lue: (<br>18             | 0000     | 16                      |
| SCU_<br>SCU                    | _CHT<br>Chan                                | R7<br>Inel T       | 28<br>12 | er 7 R<br>27<br>11   | egist        | er              | <b>(84</b><br>24 | C <sub>H</sub> )<br>23<br>0<br>r<br>7 | 6  | 21<br>5 | <b>Res</b> 20 | et Va              | <b>lue: (</b><br>18<br>2 | 17<br>17 | 16<br>0000 <sub>H</sub> |
| <b>SCU</b><br><b>SCU</b><br>31 | _CHT<br>Chan<br>30                          | R7<br>inel T<br>29 | 28<br>12 | e <b>r 7 R</b><br>27 | egisto<br>26 | <b>er</b><br>25 | <b>(84</b><br>24 | C <sub>H</sub> )<br>23<br>0           | I  | 1       | <b>Res</b> 20 | <b>et Va</b><br>19 | <b>lue: (</b><br>18<br>2 | 17       | 16<br>0000 <sub>H</sub> |



| Field | Bits             | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRSEL | [2:0]            | rw   | <ul> <li>Trigger Selection This bit field defines the trigger source for the DMA channel n. </li> <li>OOO A constant 0 is selected. TF and RF are cleared. </li> <li>OO1 ADC event 0 is selected as trigger source O10 ADC event 1 is selected as trigger source O11 Doorbell event 0 is selected as trigger source IO0 Doorbell event 1 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source IO1 External trigger input 0 is selected as trigger source</li></ul> |
| RF    | 6                | rh   | <ul> <li>Ready Flag</li> <li>This bit indicates if the MLI is ready for the next transfer.</li> <li>0 The MLI is not yet ready for a new transfer (former transfer not yet finished)</li> <li>1 The MLI is ready for a new transfer (former transfer is finished)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| TF    | 7                | rh   | Trigger FlagThis bit indicates that a channel trigger request is<br>pending.0No channel trigger request is pending1A channel trigger request is pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0     | [5:3],<br>[31:8] | r    | Reserved;<br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



|          | DCHIP Chip Identification Register |    |          |    |    | (860 <sub>H</sub> ) |          |    |      | Reset Value: 0000 8EXX |    |    |    |    | EXX <sub>H</sub> |
|----------|------------------------------------|----|----------|----|----|---------------------|----------|----|------|------------------------|----|----|----|----|------------------|
| 31       | 30                                 | 29 | 28       | 27 | 26 | 25                  | 24       | 23 | 22   | 21                     | 20 | 19 | 18 | 17 | 16               |
|          | <b>O</b>                           |    |          |    |    |                     |          |    |      |                        |    |    |    |    |                  |
|          | I                                  | I  | <u> </u> | I  | l  | <u> </u>            | <b> </b> | r  | I    | <u> </u>               | ļ  | l  | I  | l  | I                |
| 15       | 14                                 | 13 | 12       | 11 | 10 | 9                   | 8        | 7  | 6    | 5                      | 4  | 3  | 2  | 1  | 0                |
| CHIPID   |                                    |    |          |    |    |                     | 1        | 1  | REVI | SION                   | 1  | 1  |    |    |                  |
| <u>l</u> | 1                                  | 1  | ı        | r  | 1  | 1                   | 1        | I  | 1    | I                      |    | r  | 1  | 1  | <u> </u>         |

| Field    | Bits    | Туре | Description                                                                         |
|----------|---------|------|-------------------------------------------------------------------------------------|
| REVISION | [7:0]   | r    | Device Revision Code<br>Identifies the device step.                                 |
| CHIPID   | [15:8]  | r    | <b>Device Identification</b><br>The value $8E_{H}$ identifies the device as CIC751. |
| 0        | [31:16] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                            |

# 2.7 SCU Register Overview

#### Table 2-5SCU Registers

| Register Short<br>Name | Register Long Name                    | Address          | Description see |
|------------------------|---------------------------------------|------------------|-----------------|
| SCU_OSCCON             | SCU Oscillator Control Register       | 800 <sub>H</sub> | Page 2-14       |
| SCU_PLLCON             | SCU PLL Control Register              | 804 <sub>H</sub> | Page 2-15       |
| SCU_SYSCON             | SCU System Control Register           | 820 <sub>H</sub> | Page 2-16       |
| SCU_ETCTR              | SCU External Trigger Control Register | 850 <sub>H</sub> | Page 2-18       |
| SCU_SRCR               | SCU Service Request Control Register  | 858 <sub>H</sub> | Page 2-19       |
| SCU_CHTR0              | SCU Channel Trigger 0 Register        | 830 <sub>H</sub> | Page 2-22       |
| SCU_CHTR1              | SCU Channel Trigger 1 Register        | 834 <sub>H</sub> | Page 2-22       |
| SCU_CHTR2              | SCU Channel Trigger 2 Register        | 838 <sub>H</sub> | Page 2-22       |
| SCU_CHTR3              | SCU Channel Trigger 3 Register        | 83C <sub>H</sub> | Page 2-22       |



| Register Short<br>Name | Register Long Name             | Address          | Description see |
|------------------------|--------------------------------|------------------|-----------------|
| SCU_CHTR4              | SCU Channel Trigger 4 Register | 840 <sub>H</sub> | Page 2-22       |
| SCU_CHTR5              | SCU Channel Trigger 5 Register | 844 <sub>H</sub> | Page 2-22       |
| SCU_CHTR6              | SCU Channel Trigger 6 Register | 848 <sub>H</sub> | Page 2-22       |
| SCU_CHTR7              | SCU Channel Trigger 7 Register | 84C <sub>H</sub> | Page 2-22       |
| IDCHIP                 | Chip Identification Register   | 860 <sub>H</sub> | Page 2-24       |

# Table 2-5SCU Registers (cont'd)





# 3 Direct Memory Access Controller

This chapter describes the Direct Memory Access (DMA) Controller of the CIC751.

# 3.1 DMA Request Generation and Control

This section describes how a DMA Move / Transfer / Transaction is requested. The differnet request sources can be controlled to support the adaption for the required application.

# 3.1.1 Request Generation

Requests that trigger a DMA Transaction can be generated in several ways. This flexible request generation mechanism enables the software to configure the hardware to the exact needs of the application. After configuration, the DMA handles all requests without further software requirements. Each of the eight channels can be requested by one of six possible requests. The following request sources can trigger a DMA Transfer of a channel:

- MLI Request 0 (indirect)
- MLI Request 1 (indirect)
- MLI Request 2 (direct)
- MLI Request 3 (direct)
- ADC event 0 (indirect)
- ADC event 1 (indirect)
- Doorbell event 0 (indirect)
- Doorbell event 1 (indirect)
- Channel 0 Request (direct)
- Channel 1 Request (direct)
- Channel 2 Request (direct)
- Channel 3 Request (direct)
- Channel 4 Request (direct)
- Channel 5 Request (direct)
- Channel 6 Request (direct)
- Channel 7 Request (direct)

There are two classes of requests that are connected to the DMA; direct and indirect. Indirect requests need to be preselected on a system level in order to be mapped to the two additional direct requests

- Set Trigger Flag Request (direct)
- Trigger AND Ready Flag Request (direct)



**Direct Memory Access Controller** 



Figure 3-1 DMA Request Principle

# 3.1.1.1 **Preselection of the Indirect Requests**

There are two options for the requests.

# Set Trigger Flag Request

The following requests can be mapped to the Set Trigger Request.

Pins SR0, SR1, SR2, SR3, SR4, AIN4, and AIN14

MLI Break Event

These eight sources are combined into two Pin Trigger Request sources at a first level. These eight sources represent all possible external Request Triggers (for more information about the MLI Break Event see **Chapter 4.2.1.5**). Which of the eight possible trigger sources is used can be configured via SCU\_ETCTR.INSEL0 for the Pin Trigger Request 0 and SCU\_ETCTR.INSEL1 for the Pin Trigger Request 1. An edge detection activates the trigger signal upon a event that is configurable via ETCTR.FENx and ETCTR.RENx.



# **CIC751**

**Direct Memory Access Controller** 



# Figure 3-2 External Trigger Unit

The rising edge and falling edge sensitivity of the selected input can be enabled individually. If edge detection for both edges is enabled, a trigger signal is generated upon each change of the signal level (rising edge or falling edge).



Note: For MLI Mode, only the pins SR0, SR1, and SR2 are available as Request Trigger sources.

### Trigger AND Ready Flag Request

This combined request enables the MLI interface and the ADC to quickly establish communication with the help of the DMA and minimal software requirements.

The Set Trigger Flag part signals that a new ADC conversion result is available. This can be from a standard conversion (indicated via ADC event 0) or from a injected conversion (indicated via ADC event 1). If the ADC conversion result was stored in the ADC extended result registers, the doorbell mechanism can be used (indicated via Doorbell event 0 or Doorbell event 1) for the communication.

Note: The Doorbell mechanism requires the use of at least one additional channel.

Typical Use Case Example:

This is combined with the MLI Request trigger 0 and 1. Both MLI Request triggers can be used to indicate when the MLI interface is ready to send the next data (ADC conversion result) to the host controller. Therefore, the combination indicates that a new ADC conversion result is available and the MLI interface is ready to transmit the result to the host controller.

# 3.1.2 DMA Request Assignment Matrix

The DMA requests input lines of the DMA are assigned as indicated in Table 3-1:

| Table 3-1 | DMA Request Assignment |
|-----------|------------------------|
|-----------|------------------------|

| DMA<br>Channel | DMA Request Input         | Selected by                        |
|----------------|---------------------------|------------------------------------|
| 0              | Channel 7 Request         | DMA_CHCR0.PRSEL = 000 <sub>B</sub> |
|                | Channel 6 Request         | DMA_CHCR0.PRSEL = 001 <sub>B</sub> |
|                | MLI Request 2             | DMA_CHCR0.PRSEL = 010 <sub>B</sub> |
|                | MLI Request 3             | DMA_CHCR0.PRSEL = 011 <sub>B</sub> |
|                | Trigger AND Ready Request | DMA_CHCR0.PRSEL = 100 <sub>B</sub> |
|                | Set Trigger Flag Request  | DMA_CHCR0.PRSEL = 101 <sub>B</sub> |
|                | not used, no Request      | DMA_CHCR0.PRSEL = 110 <sub>B</sub> |
|                |                           | $DMA_CHCR0.PRSEL = 111_B$          |



# **CIC751**

#### **Direct Memory Access Controller**

| Table 3-1      | DMA Request Assignment (cont'd) |                                    |  |  |  |  |  |  |  |
|----------------|---------------------------------|------------------------------------|--|--|--|--|--|--|--|
| DMA<br>Channel | DMA Request Input               | Selected by                        |  |  |  |  |  |  |  |
| 1              | Channel 0 Request               | DMA_CHCR1.PRSEL = 000 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Channel 7 Request               | DMA_CHCR1.PRSEL = 001 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 2                   | DMA_CHCR1.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 3                   | DMA_CHCR1.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Trigger AND Ready Request       | DMA_CHCR1.PRSEL = 100 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Set Trigger Flag Request        | DMA_CHCR1.PRSEL = 101 <sub>B</sub> |  |  |  |  |  |  |  |
|                | not used, no Request            | DMA_CHCR1.PRSEL = 110 <sub>B</sub> |  |  |  |  |  |  |  |
|                |                                 | DMA_CHCR1.PRSEL = 111 <sub>B</sub> |  |  |  |  |  |  |  |
| 2              | Channel 1 Request               | DMA_CHCR2.PRSEL = 000 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Channel 0 Request               | DMA_CHCR2.PRSEL = 001 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 2                   | DMA_CHCR2.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 3                   | DMA_CHCR2.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Trigger AND Ready Request       | DMA_CHCR2.PRSEL = 100 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Set Trigger Flag Request        | DMA_CHCR2.PRSEL = 101 <sub>B</sub> |  |  |  |  |  |  |  |
|                | not used, no Request            | DMA_CHCR2.PRSEL = 110 <sub>B</sub> |  |  |  |  |  |  |  |
|                |                                 | DMA_CHCR2.PRSEL = 111 <sub>B</sub> |  |  |  |  |  |  |  |
| 3              | Channel 2 Request               | DMA_CHCR3.PRSEL = 000 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Channel 1 Request               | DMA_CHCR3.PRSEL = 001 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 2                   | DMA_CHCR3.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 3                   | DMA_CHCR3.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Trigger AND Ready Request       | DMA_CHCR3.PRSEL = 100 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Set Trigger Flag Request        | DMA_CHCR3.PRSEL = 101 <sub>B</sub> |  |  |  |  |  |  |  |
|                | not used, no Request            | DMA_CHCR3.PRSEL = 110 <sub>B</sub> |  |  |  |  |  |  |  |
|                |                                 | DMA_CHCR3.PRSEL = 111 <sub>B</sub> |  |  |  |  |  |  |  |



# **CIC751**

#### **Direct Memory Access Controller**

| Table 3-1      | DMA Request Assignment (cont'd) |                                    |  |  |  |  |  |  |  |
|----------------|---------------------------------|------------------------------------|--|--|--|--|--|--|--|
| DMA<br>Channel | DMA Request Input               | Selected by                        |  |  |  |  |  |  |  |
| 4              | Channel 3 Request               | DMA_CHCR4.PRSEL = 000 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Channel 2 Request               | DMA_CHCR4.PRSEL = 001 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 2                   | DMA_CHCR4.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 3                   | DMA_CHCR4.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Trigger AND Ready Request       | DMA_CHCR4.PRSEL = 100 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Set Trigger Flag Request        | DMA_CHCR4.PRSEL = 101 <sub>B</sub> |  |  |  |  |  |  |  |
|                | not used, no Request            | $DMA_CHCR4.PRSEL = 110_B$          |  |  |  |  |  |  |  |
|                |                                 | DMA_CHCR4.PRSEL = 111 <sub>B</sub> |  |  |  |  |  |  |  |
| 5              | Channel 4 Request               | DMA_CHCR5.PRSEL = 000 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Channel 3 Request               | DMA_CHCR5.PRSEL = 001 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 2                   | DMA_CHCR5.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 3                   | DMA_CHCR5.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Trigger AND Ready Request       | DMA_CHCR5.PRSEL = 100 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Set Trigger Flag Request        | $DMA_CHCR5.PRSEL = 101_B$          |  |  |  |  |  |  |  |
|                | not used, no Request            | $DMA_CHCR5.PRSEL = 110_B$          |  |  |  |  |  |  |  |
|                |                                 | $DMA_CHCR5.PRSEL = 111_B$          |  |  |  |  |  |  |  |
| 6              | Channel 5 Request               | $DMA\_CHCR6.PRSEL = 000_B$         |  |  |  |  |  |  |  |
|                | Channel 4 Request               | $DMA_CHCR6.PRSEL = 001_B$          |  |  |  |  |  |  |  |
|                | MLI Request 2                   | DMA_CHCR6.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |  |  |
|                | MLI Request 3                   | DMA_CHCR6.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Trigger AND Ready Request       | DMA_CHCR6.PRSEL = 100 <sub>B</sub> |  |  |  |  |  |  |  |
|                | Set Trigger Flag Request        | DMA_CHCR6.PRSEL = 101 <sub>B</sub> |  |  |  |  |  |  |  |
|                | not used, no Request            | DMA_CHCR6.PRSEL = 110 <sub>B</sub> |  |  |  |  |  |  |  |
|                |                                 | DMA_CHCR6.PRSEL = 111 <sub>B</sub> |  |  |  |  |  |  |  |



| Table 3-1 | DMA Request Assignment (cont'd) |
|-----------|---------------------------------|
|-----------|---------------------------------|

| DMA<br>Channel | DMA Request Input         | DMA_CHCR7.PRSEL = 000 <sub>B</sub> |  |  |  |  |  |
|----------------|---------------------------|------------------------------------|--|--|--|--|--|
| 7              | Channel 6 Request         |                                    |  |  |  |  |  |
|                | Channel 5 Request         | DMA_CHCR7.PRSEL = 001 <sub>B</sub> |  |  |  |  |  |
|                | MLI Request 2             | DMA_CHCR7.PRSEL = 010 <sub>B</sub> |  |  |  |  |  |
|                | MLI Request 3             | DMA_CHCR7.PRSEL = 011 <sub>B</sub> |  |  |  |  |  |
|                | Trigger AND Ready Request | $DMA\_CHCR7.PRSEL = 100_B$         |  |  |  |  |  |
|                | Set Trigger Flag Request  | DMA_CHCR7.PRSEL = 101 <sub>B</sub> |  |  |  |  |  |
|                | not used, no Request      | DMA_CHCR7.PRSEL = 110 <sub>B</sub> |  |  |  |  |  |
|                |                           | DMA_CHCR7.PRSEL = 111 <sub>B</sub> |  |  |  |  |  |

Note: Not all channel are connected to the exactly same direct channel Request.



# 3.2 DMA Controller Kernel Description

The DMA Controller of the CIC751 transfers data from data source locations to data destination locations without intervention of other on-chip devices. One data move operation is controlled by one DMA channel. Eight DMA channels are provided in one DMA Sub-Block.



Figure 3-3 DMA Block Diagram



# 3.2.1 Features

The DMA controller has the following features:

- 8 independent DMA channels
  - 8 DMA channels in the DMA Sub-Block
  - Up to 8 selectable request inputs per DMA channel
  - 2-level programmable priority of DMA channels within the DMA Sub-Block
  - Software and hardware DMA request
  - Hardware requests by selected on-chip peripherals and external inputs
- Buffer capability for move actions on the buses (at least 1 move per bus is buffered)
- Individually programmable operation modes for each DMA channel
  - Single Mode: stops and disables DMA channel after a predefined number of DMA transfers
  - Continuous Mode: DMA channel remains enabled after a predefined number of DMA transfers; DMA transaction can be repeated
  - Programmable address modification
- Full 32-bit addressing capability of each DMA channel
  - 4 Gbyte address range
  - Support of circular buffer addressing mode
- Programmable data width of DMA transfer/transaction: 8-bit, 16-bit, or 32-bit
- Register set for each DMA channel
  - Source and destination address register
  - Channel control and status register
  - Transfer count register



# 3.2.2 Definition of Terms

Some basic terms must be defined for the functional description of the DMA controller.

#### DMA Move

A DMA move is an operation that always consists of two parts:

- 1. A read move that loads data from a data source into the DMA controller
- 2. A write move that puts data from the DMA controller to a data destination

Within a DMA move, data is always moved from the data source via the DMA controller to the data destination. Data is temporarily stored in the DMA controller. The data widths of read move and write move are always identical (8-bit, 16-bit or 32-bit). Data assembly or disassembly is not supported.



Figure 3-4 DMA Definition of Terms

# **DMA Transfer**

A DMA transfer can be composed of 1, 2, 4, 8 or 16 DMA moves.

#### **DMA Transaction**

A DMA transaction is composed of several (at least one) DMA transfers. The Transfer Count determines the number of DMA transfers within one DMA transaction.

#### Example:

1024 word (32-bit wide) transactions can be composed of 256 transfers of four DMA word moves, or 128 transfers of eight DMA word moves.



# 3.2.3 DMA Principles

The DMA controller supports DMA moves from one address location to another one. DMA moves can be requested either by hardware or by software. DMA hardware requests are triggered by specific request lines from the peripheral modules or from other DMA channels. The number of available DMA request lines from a peripheral module varies depending on the module functionality. Typically, the occurrence of a receive or transmit data interrupts in a peripheral module are able to generate a DMA request.



# 3.2.4 DMA Channel Functionality

Each of the 8 DMA channels has one associated register set containing six 32-bit registers. These registers are numbered by one index to indicate the related DMA channel: Index "n" refers to the channel number (n = 0.7) within the DMA Sub-Block.

Example: CHCR04 is the Control Register of DMA channel 4 in Sub-Block 0.

The register set of a DMA channel register contains the following registers:

- Channel 0n Control Register CHCR0n (for details, see Page 3-39)
- Channel On Status Register CHSROn (for details, see Page 3-42)
- Channel On Address Control Register ADRCROn (for details, see Page 3-43)
- Channel 0n Source Address Register SADR0n (for details, see Page 3-47)
- Channel On Destination Address Register DADROn (for details, see Page 3-48)
- Channel On Shadow Address Register SHADROn (for details, see Page 3-49)

### 3.2.4.1 Shadowed Source or Destination Address

As a typical application, an SSC module that receives data (fixed source address) has to deliver it to a memory buffer using a DMA transaction (variable destination address). After a certain amount of data has been transferred, a new DMA transaction should be initiated to deliver further SSC data into another memory buffer. While the destination address register is updated during a running DMA transaction with the actual destination address, a shadow mechanism allows programming of a new destination address without disturbing the content of the destination address register. In this case, the new destination address is written into a buffer register, i.e. the shadow address register. At the start of the next DMA transaction, the new address is transferred from this shadow address register to the destination address register.

The shadow address register can be used also to store a source address. However, it cannot store source and destination address at the same time. This means that the shadow mechanism makes it possible to automatically update either a new source address, or a new destination address at the start of a DMA transaction. If both address registers (for source and destination address) have to be updated for the next DMA transaction, a running DMA transaction for this channel must be finished. After that, source and destination address registers can be written before the next DMA transaction is started.

**Figure 3-5** shows the actions that take place when a source address register is updated. The update of a destination register happens in an equivalent manner.

When writing a new address to the (address of) the source or destination address register and no DMA transaction is running, the new address value is directly written into the source or destination address register. In this case, no buffering of the address is required. When writing a new address to the (address of) the source or destination address register and a DMA transaction is running, no transfer to an address register can take place and SHADROn holds the new address value that was written. For this



operation, bit field ADRCR0n.SHCT must be set either to  $01_B$  (address is a source address) or  $10_B$  (new address is a destination address). At the start of the next DMA transaction, the shadow transfer takes place and the content of SHADR0n is written either into SADR0n or DADR0n (ADRCR0n.SHCT must be set accordingly). After the shadow transfer, SHADR0n is set to  $0000 \ 0000_H$ . Therefore, the software can check by reading the shadow address register whether or not the shadow transfer has already taken place.

Only one address register can be shadowed while a transaction is running, because the shadow register can only be assigned either to the source or to the destination address register. Note that the shadow address register transfer has the same behavior in Single and Continuous Mode. When the shadow mechanism is disabled  $(ADRCR0n.SHCT = 00_B)$ , SHADR0n is always read as  $0000\ 0000_H$ .



Figure 3-5 Source Address Update

The transfer count of a DMA transaction, stored in bit field CHCR0n.TREL, can also be programmed if the DMA transaction is running. At the start of a DMA transaction, TREL is transferred to bit field CHSR0n.TCOUNT, which is then updated during the DMA transaction.

No reload of address or counter will be done if TCOUNT is not equal to 0.

The reprogramming of channel specific values (except for the selected address shadow register) should be avoided while a DMA channel is active.



Figure 3-6 Shadow Source Address and Transfer Count Update

**Figure 3-6** shows how the contents of the source address register SADR0n and the transfer count CHSR0n.TCOUNT are updated during two DMA transactions with a shadowed source address and transfer count update.

At reference point 2) the DMA transaction 1 is finished and DMA transaction 2 is started. At 1) the DMA channel is reprogrammed with two new parameters for the next DMA transaction: Transfer count tc2 and source address sa2. Source address sa2 is buffered in SADR0n and transferred to SADR0n when the new DMA transaction is started at 2). At this time, transfer count tc2 is also transferred to CHSR0n.TCOUNT.





# 3.2.4.2 DMA Channel Request Control

**Figure 3-7** shows the control logic for DMA requests that is implemented for each DMA channel.



#### Figure 3-7 Channel Request Control

Two different types of DMA requests are possible:

- Hardware DMA requests
- Software DMA requests

The hardware request CH0n\_REQ can be connected to one of eight possible hardware request input lines as selected by bit field CHCR0n.PRSEL. Hardware requests are enabled/disabled by status bit TRSR.HTRE0n. HTRE0n can be set/reset by software or by hardware in Single Mode at the end of a DMA transaction. A software request can be generated by setting bit STREQ.CH0n.

Status flag TRSR.CH0n indicates whether or not a software or hardware generated DMA request for DMA channel 0n is pending. TRSR.CH0n can be reset by software or by



hardware at the end of a DMA transfer (RROAT = 0) or at the end of a DMA transaction (RROAT = 1).

If a software or a hardware DMA request is detected for channel 0n while TRSR.CH0n is set, a request lost event occurs. This error event indicates that the DMA is already processing a transfer and that another transfer has been requested before the end of the previous one. In this case, bit ERRSR.TRL0n will be set.

# 3.2.4.3 DMA Channel Operation Modes

The operation mode of a DMA channel is individually programmable for each DMA channel 0n. Basically, a DMA channel can operate in the following modes:

- Software controlled mode
- Hardware controlled mode, in Single or Continuous Mode

In software-controlled mode, a DMA channel request is generated by setting a control bit. In hardware-controlled mode, a DMA channel request is generated by request signals typically generated by on-chip peripheral units.

In hardware-controlled Single Mode, a DMA channel 0n becomes disabled by hardware after the last DMA transfer of its DMA transaction. In hardware-controlled Continuous Mode, a DMA channel 0n remains enabled after the last DMA transfer of its DMA transaction.

In hardware- and software-controlled mode, a DMA request signal can be configured to trigger a complete DMA transaction or one single transfer.

#### Software-controlled Modes

In software-controlled mode, one software request starts one complete DMA transaction or one single DMA transfer. Software-controlled modes are selected by writing HTREQ.DCH0n = 1. This forces status flag TRSR.HTRE0n = 0 (hardware request of DMA channel 0n is disabled).

The software-controlled mode that initiates one complete DMA transaction to be executed is selected for DMA channel 0n by the following write operations:

- CHCR0n.RROAT = 1
- STREQ.SCH0n = 1

Setting STREQ.SCH0n to 1 (this is the software request) causes the DMA transaction of DMA channel 0n to be started and TRSR.CH0n to be set. At the start of the DMA transaction, the value of CHCR0n.TREL is loaded into CHSR0n.TCOUNT (transfer count or tc) and the DMA transfers are executed. After each DMA transfer, TCOUNT becomes decremented and next source and destination addresses are calculated. When TCOUNT reaches the 0, DMA channel 0n becomes disabled and status flag TRSR.CH0n is reset. Setting STREQ.SCH0n again starts a new DMA transaction of DMA channel 0n with the parameters as actually defined in the channel register set.



The software-controlled mode that initiates a single DMA transfer to be executed is selected for DMA channel 0n by the following write operations:

- CHCR0n.RROAT = 0
- STREQ.SCH0n = 1, repeated for each DMA transfer

When CHCR0n.RROAT = 0, TRSR.CH0n becomes reset after each DMA transfer of the DMA transaction and a new software request (writing STREQ.SCH0n = 1) must be generated for starting the next DMA transfer.



Figure 3-8 Software Controlled Mode Operation



#### Hardware-controlled Modes

In hardware-controlled modes, a hardware request signal starts a DMA transaction or a single DMA transfer. There are two hardware-controlled modes available:

- Single Mode: Hardware requests are disabled by hardware after a DMA transaction
- Continuous Mode: Hardware requests are not disabled by hardware after a DMA transaction

#### Hardware-controlled Single Mode

In hardware-controlled Single Modes, one hardware request starts one complete DMA transaction or one single DMA transfer. The hardware-controlled Single Mode that initiates <u>one complete DMA transaction</u> to be executed for DMA channel 0n is selected by the following operations:

- CHCR0n.CHMODE = 0
- CHCR0n.RROAT = 1
- Selecting one of the eight hardware request inputs via CHCR0n.PRSEL
- HTREQ.ECH0n = 1

Setting HTREQ.ECH0n to 1 causes the hardware request CH0n\_REQ of channel 0n to be enabled (TRSR.HTREOn = 1). Whenever the hardware request CH0n\_REQ becomes active, the value of CHCR0n.TREL is loaded into CHSR0n.TCOUNT and the DMA transaction is started by executing its first DMA transfer. After each DMA transfer, TCOUNT becomes decremented and next source and destination addresses are calculated. When TCOUNT reaches the 0, DMA channel 0n becomes disabled and status flags TRSR.CH0n and TRSR.HTREOn are reset. In order to start a new hardware-controlled DMA transaction, hardware requests must be enabled again by setting TRSR.HTREOn through HTREQ.ECH0n = 1. The hardware request disable function in Single Mode is typically needed when a reprogramming of the DMA channel register set (addresses, transfer count) is required before the next hardware triggered DMA transaction is started.

The hardware-controlled Single Mode in which each <u>single DMA transfer</u> has to be requested by a hardware request signal is selected as described above, with one difference:

• CHCR0n.RROAT = 0

In this operation mode, TRSR.CH0n becomes reset after each DMA transfer of the DMA transaction, and a new hardware request at CH0n\_REQ must be generated for starting the next DMA transfer.





#### Figure 3-9 Hardware-controlled Single Mode Operation

#### Hardware-controlled Continuous Mode

In hardware-controlled Continuous Mode (CHCR0n.CHMODE = 1), the hardware transaction request enable bit HTRE0n is not reset at the end of a DMA transaction. A new transaction of DMA channel 0n with the parameters actually stored in the channel register set of DMA channel 0n is started each time when CHSR0n.TCOUNT reaches  $000_{\rm H}$ . No software re-enable for a hardware request at CH0n\_REQ is required.



#### Combined Software/Hardware-controlled Mode

**Figure 3-10** shows how software- and hardware-controlled modes can be combined. In the example, the first DMA transfer is triggered by software when setting STREQ.SCH0n. Hardware requests are still disabled. After hardware requests have been enabled by setting HTREQ.ECH0n, subsequent DMA transfers are triggered now by hardware request coming from the CH0n\_REQ line.

In the example, DMA channel 0n operates in Single Mode (CHCR0n.CHMODE = 0). In this mode, TRSR.HTRE0n becomes reset by hardware when CHSR0n.TCOUNT reaches 0 at the end of the DMA transaction.



Figure 3-10 Transaction Start by Software, Continuation by Hardware

# 3.2.4.4 Channel Reset Operation

A DMA transaction of DMA channel 0n can be stopped (channel is reset) by setting bit CHRSTR.CH0n.

When CHRST.CH0n is set to 1:

- Bits TRSR.HTRE0n, TRSR.CH0n, ERRSR.TRL0n, INTSR.ICH0n, INTSR.IPM0n, WRPSR.WRPD0n, WRPSR.WRPS0n, CHSR0n.LXO, and bit field CHSR0n.TCOUNT are reset.
- If ADRCR0n.SHCT is 01<sub>B</sub> or 10<sub>B</sub>, either source or destination address register will be loaded with the value buffered in the shadow address register SHADR0n is cleared. SHADR0n will be cleared afterwards.



• All automatic functions are stopped for channel 0n.

A user program should execute the following steps for resetting and restarting a DMA channel:

- 1. Writing a 1 to CHRST.CH0n.
- 2. Waiting (polling) until CHRST.CH0n = 0.
- 3. Optionally (re-)configuring the address and other channel registers.
- 4. Restarting the DMA channel 0n by setting HTREQ.ECH0n = 1 for hardware requests or STREQ.SCH0n = 1 for software requests.

Bit field CHCR0n.TREL is copied to CHSR0n.TCOUNT when a new DMA transaction is requested.



# 3.2.4.5 Transfer Count and Move Count

The move count determines the number of moves (consisting of one read and one write each) to be done in each transfer. It allows the user to indicate to the DMA the number of moves to be done after one request. The number of moves per transfer is selected by the block mode settings (CHCR0n.BLKM).



Figure 3-11 Transfer and Move Count

After a DMA move, the next source and destination addresses are calculated. Source and destination addresses are calculated independently of each other. The following address calculation parameters can be selected:

- The address offset, which is a multiple of the selected data width
- The offset direction: addition, subtraction, or none (unchanged address)

Control bits in address control register ADRCR0n determine how the addresses are incremented/decremented. Further, the data width as defined in CHCR0n.CHDW is taken into account for the address calculation.

**Figure 3-12** and **Figure 3-13** show two examples of address calculation. In both examples, a data width of 16-bit (CHCR0n.CHDW =  $01_B$ ) is assumed.





#### Figure 3-12 Programmable Address Modification - Example 1

In **Figure 3-12**, 16-bit half-words are transferred from a source memory with an incrementing source address offset of  $10_{\rm H}$  to a destination memory with decrementing destination addresses offset of  $08_{\rm H}$ .

In **Figure 3-13**, 16-bit half-words are transferred from a source memory with an incrementing source address offset of  $02_{\rm H}$  to a destination memory with incrementing destination addresses offset of  $04_{\rm H}$ .





Figure 3-13 Programmable Address Modification - Example 2

# 3.2.4.6 Circular Buffer

Destination and source address can be configured to build a circular buffer separately for source and destination data. Within this circular buffer, addresses are updated as defined in **Figure 3-12** and **Figure 3-13** with a wrap-around at the buffer limits. The circular buffer length is determined by bit fields ADRCR0n.CBLS (for the source buffer) and ADRCR0n.CBLD (for the destination buffer). These 4-bit wide bit fields determine which bits of the 32-bit address remain unchanged at an address update. Possible buffer sizes of the circular buffers can be 2<sup>CBLS</sup> or 2 <sup>CBLD</sup> bytes (= 1, 2, 4, 8, 16, ... up to 32k bytes).

When source or destination addresses are updated (incremented or decremented) after a DMA move, all upper bits [31:CBLS] of source address and [31:CBLD] of destination address are frozen and remain unchanged, even if a wrap-around from the lower address bits [CBLS:0] or [CBLD:0] occurred. This address-freezing mechanism always causes the circular buffers to be aligned to a multiple integer value of its size.

If the circular buffer size is less or equal than the selected address offset (see **Table 3-5**), the same circular buffer address will always be accessed.



# 3.2.5 Transaction Control Engine

The Transaction Control Unit in the DMA Sub-Block, as shown in the DMA Controller block diagram in **Figure 3-3**, contains a Channel Arbiter and a Move Engine.

The Channel Arbiter arbitrates the transfer requests of the DMA channels, and submits the transfers parameters of the DMA channel with the highest channel priority that are needed for a DMA transfer to the Move Engine. DMA channels within a DMA Sub-Block have a two-level programmable channel priority as defined by bit CHCR0n.CHPRIO. When two transfer requests of two different DMA channels with identical channel priority become active at the same time, the DMA channel with the lowest channel number (n) is serviced first.

The Move Engine handles the execution of a DMA transfer that has been detected by the Channel Arbiter to be the next one. The Move Engine requests the required buses and loads or stores data according to the parameters of a DMA transfer. It is able to wait if a targeted bus is not available. In the Move Engine, a DMA transfer of a DMA transaction cannot be interrupted and always get finished. This means that a DMA transfer, which can also be composed of several data moves (read move and write move), cannot be interrupted by a transfer of another DMA channel.

After a DMA transfer is finished, the Move Engine will send back the actualized address register information to the related DMA channel. Possible error conditions are also reported.



Figure 3-14 Transaction Control Engine



# 3.3 DMA Module Kernel Registers

**Figure 3-15** and **Table 3-2** show all registers associated with the DMA Controller Kernel. All DMA kernel register names described in this section are also referenced in other parts of the CIC751 User Manual by the module name prefix "DMA\_".

#### DMA Registers Overview



Figure 3-15 DMA Kernel Registers

#### Table 3-2 Registers Address Space - DMA Kernel Registers

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| DMA    | 0000 0400 <sub>H</sub> | 0000 05FF <sub>H</sub> | -    |

#### Table 3-3 Registers Overview - DMA Kernel Registers

| Register Short<br>Name | Register Long Name                           | Address           | Description see |
|------------------------|----------------------------------------------|-------------------|-----------------|
| DMA_CHRSTR             | DMA Channel Reset Request Register           | 0410 <sub>H</sub> | Page 3-29       |
| DMA_TRSR               | DMA Transaction Request State<br>Register    | 0414 <sub>H</sub> | Page 3-31       |
| DMA_STREQ              | DMA Software Transaction Request<br>Register | 0418 <sub>H</sub> | Page 3-32       |



| Table 3-3 | Registers Overview - DMA Kernel Registers (cont'd) |
|-----------|----------------------------------------------------|
|-----------|----------------------------------------------------|

| Register Short<br>Name | Register Long Name                                          | Address                                    | Description see |  |  |
|------------------------|-------------------------------------------------------------|--------------------------------------------|-----------------|--|--|
| DMA_HTREQ              | DMA Hardware Transaction Request<br>Register                | 041C <sub>H</sub>                          | Page 3-33       |  |  |
| DMA_ERRSR              | DMA Error Status Register                                   | 0424 <sub>H</sub>                          | Page 3-34       |  |  |
| DMA_CLRE               | DMA Clear Error Register                                    | 0428 <sub>H</sub>                          | Page 3-36       |  |  |
| DMA_MESR               | DMA Move Engine Status Register                             | 0430 <sub>H</sub>                          | Page 3-37       |  |  |
| DMA_ME0R               | DMA Move Engine 0 Read Register                             | 0434 <sub>H</sub>                          | Page 3-38       |  |  |
| DMA_CHSR0n             | DMA Channel 0n Status Register<br>(n = 0-7)                 | n × 20 <sub>H</sub> +<br>0480 <sub>H</sub> | Page 3-42       |  |  |
| DMA_CHCR0n             | DMA Channel 0n Control Register<br>(n = 0-7)                | n × 20 <sub>H</sub> +<br>0484 <sub>H</sub> | Page 3-39       |  |  |
| DMA_<br>ADRCR0n        | DMA Channel 0n Address Control<br>Register (n = 0-7)        | n × 20 <sub>H</sub> +<br>048C <sub>H</sub> | Page 3-43       |  |  |
| DMA_SADR0n             | DMA Channel 0n Source Address<br>Register (n = 0-7)         | n × 20 <sub>H</sub> +<br>0490 <sub>H</sub> | Page 3-47       |  |  |
| DMA_DADR0n             | DMA Channel 0n Destination Address<br>Register (n = $0-7$ ) | n × 20 <sub>H</sub> +<br>0494 <sub>H</sub> | Page 3-48       |  |  |
| DMA_SHADR0n            | DMA Channel 0n Shadow Address<br>Register (n = 0-7)         | n × 20 <sub>H</sub> +<br>0498 <sub>H</sub> | Page 3-49       |  |  |



# 3.3.1 General Control/Status Registers

The following registers are used to configure and control the request generation of the DMA from the system point of view.

### SCU\_ETCTR

| Exter    | External Trigger Control I |    |    | Regis | ster | 85   | 50 <sub>H</sub> |          |          | Res | et Va | lue: 0 | 0000 ( | 0000 <sub>H</sub> |          |
|----------|----------------------------|----|----|-------|------|------|-----------------|----------|----------|-----|-------|--------|--------|-------------------|----------|
| 31       | 30                         | 29 | 28 | 27    | 26   | 25   | 24              | 23       | 22       | 21  | 20    | 19     | 18     | 17                | 16       |
|          | 1                          |    | 1  | 1     | 1    | 1    | 1               | 0        | 1        |     | 1     |        | 1      | 1                 |          |
| 15       | 14                         | 13 | 12 | 11    | 10   | 9    | 8               | r<br>7   | 6        | 5   | 4     | 3      | 2      | 1                 | 0        |
| REN<br>1 | FEN<br>1                   |    | 0  |       | I    | NSEL | 1               | REN<br>0 | FEN<br>0 |     | 0     |        | I      | NSEL              | 0        |
| rw       | rw                         |    | r  | 1     | 1    | rw   | 1               | rw       | rw       |     | r     |        | 1      | rw                | <u> </u> |

| Field  | Bits  | Туре | Description                                                                                                                                                                                                                                                                                   |
|--------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INSEL0 | [2:0] | rw   | Input Selection for Pin Trigger 0This bit field defines the Trigger Source for PinTrigger 0.000Pin SR0 is selected001Pin SR1 is selected010Pin SR2 is selected011Pin SR3 is selected100Pin SR4 is selected101MLI Break Event is selected110Pin AIN4 is selected111Pin AIN14 is selected       |
| FEN0   | 6     | rw   | <ul> <li>Falling Edge Enable for Pin Trigger 0</li> <li>This bit enables/disables the activation of Pin Trigger</li> <li>0 upon a falling edge at the selected input.</li> <li>0 The trigger upon a falling edge is disabled</li> <li>1 The trigger upon a falling edge is enabled</li> </ul> |
| REN0   | 7     | rw   | <ul> <li>Rising Edge Enable for Pin Trigger 0</li> <li>This bit enables/disables the activation of Pin Trigger</li> <li>0 upon a rising edge at the selected input.</li> <li>0 The trigger upon a rising edge is disabled</li> <li>1 The trigger upon a rising edge is enabled</li> </ul>     |



| Field  | Bits              | Туре | Description                                                                                                                                                                                                                                                                                   |
|--------|-------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INSEL1 | [10:8]            | rw   | Input Selection for Pin Trigger 1This bit field defines the Trigger Source for PinTrigger 1.000Pin SR0 is selected001Pin SR1 is selected010Pin SR2 is selected011Pin SR3 is selected100Pin SR4 is selected101MLI Break Event is selected110Pin AIN4 is selected111Pin AIN14 is selected       |
| FEN1   | 14                | rw   | <ul> <li>Falling Edge Enable for Pin Trigger 1</li> <li>This bit enables/disables the activation of Pin Trigger</li> <li>1 upon a falling edge at the selected input.</li> <li>0 The trigger upon a falling edge is disabled</li> <li>1 The trigger upon a falling edge is enabled</li> </ul> |
| REN1   | 15                | rw   | Rising Edge Enable for Pin Trigger 1This bit enables/disables the activation of Pin Trigger1 upon a rising edge at the selected input.0The trigger upon a rising edge is disabled1The trigger upon a rising edge is enabled                                                                   |
| 0      | [5:3],<br>[13:11] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                       |

The bits in the Channel Reset Request Register are used to reset DMA channel 0n.

# DMA\_CHRSTR DMA Channel Reset Request Register

|    |    |    |    |    |    |    | (41 | 0 <sub>H</sub> ) |          |          | Res      | et Va    | lue: (   | 0000 (   | 0000 <sub>H</sub> |
|----|----|----|----|----|----|----|-----|------------------|----------|----------|----------|----------|----------|----------|-------------------|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23               | 22       | 21       | 20       | 19       | 18       | 17       | 16                |
|    | 1  | 1  | 1  | 1  | 1  | 1  |     | 0                | 1        | 1        | 1        | 1        | 1        | 1        |                   |
| L  | 1  | 1  | I  | 1  |    |    | 1   | r                | I        | 1        | 1        | 1        | I        | I        | II                |
|    | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7                | 6        | 5        | 4        | 3        | 2        | 1        | 0                 |
|    | 1  | 1  | •  | D  | 1  | 1  | 1   | CH<br>07         | CH<br>06 | CH<br>05 | CH<br>04 | CH<br>03 | CH<br>02 | CH<br>01 | CH<br>00          |
| L  | 1  | 1  | 1  | r  | 1  | 1  | 1   | rwh              | rwh      | rwh      | rwh      | rwh      | rwh      | rwh      | rwh               |



| Field             | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CH0n<br>(n = 0-7) | n      | rwh  | <ul> <li>Channel On Reset</li> <li>These bits force the DMA channel On to stop its current</li> <li>DMA transaction. Once set by software, this bit will be</li> <li>automatically cleared when the channel has been reset.</li> <li>Writing a 0 to CHOn has no effect.</li> <li>0 No action (write) or the requested channel reset</li> <li>has been reset (read).</li> <li>1 DMA channel On is stopped. More details see</li> <li>Page 3-20.</li> </ul> |
| 0                 | [31:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                   |



The bits in the Transaction Request State Register indicates which DMA channel is processing a request, and which DMA channel has hardware transaction requests enabled.

#### DMA\_TRSR

#### DMA Transaction Request State Register

|    |    |    |        |    |    |    | (41 | 4 <sub>H</sub> ) |                |                | Res            | et Va          | lue: 0         | 0000 (         | 0000 <sub>H</sub> |
|----|----|----|--------|----|----|----|-----|------------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------|
| 31 | 30 | 29 | 28     | 27 | 26 | 25 | 24  | 23               | 22             | 21             | 20             | 19             | 18             | 17             | 16                |
|    | 1  |    | (      | 0  | 1  |    |     | HT<br>RE<br>07   | HT<br>RE<br>06 | HT<br>RE<br>05 | HT<br>RE<br>04 | HT<br>RE<br>03 | HT<br>RE<br>02 | HT<br>RE<br>01 | HT<br>RE<br>00    |
|    |    |    |        | r  |    |    |     | rh               | rh             | rh             | rh             | rh             | rh             | rh             | rh                |
| 15 | 14 | 13 | 12     | 11 | 10 | 9  | 8   | 7                | 6              | 5              | 4              | 3              | 2              | 1              | 0                 |
|    | 1  | 1  | ,<br>, | D  | 1  | 1  | 1   | CH<br>07         | CH<br>06       | CH<br>05       | CH<br>04       | CH<br>03       | CH<br>02       | CH<br>01       | CH<br>00          |
| ι  | 1  | 1  | 1      | r  | 1  | 1  | 1   | rh               | rh             | rh             | rh             | rh             | rh             | rh             | rh                |

| Field               | Bits               | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|--------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CH0n<br>(n = 0-7)   | n                  | rh   | Transaction Request State of DMA Channel 0n0No DMA request is pending for channel 0n.1A DMA request is pending for channel 0n.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| HTRE0n<br>(n = 0-7) | n+16               | rh   | <ul> <li>Hardware Transaction Request Enable State of DMA<br/>Channel On</li> <li>Hardware transaction request for DMA Channel<br/>On is disabled. An input DMA request will not<br/>trigger the channel On.</li> <li>Hardware transaction request for DMA Channel<br/>On is enabled. The transfers of a DMA transaction<br/>are controlled by the corresponding channel<br/>request line of the DMA requesting source.</li> <li>HTREOn is set to 0 when CHSROn.TCOUNT is<br/>decremented and CHSROn.TCOUNT = 0. HTREOn can<br/>be enabled and disabled with HTREQ.ECHOn or<br/>HTREQ.DCHOn.</li> </ul> |
| 0                   | [31:24],<br>[15:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



The bits in the Software Transaction Request Register are used to generate a DMA transaction request by software.

#### DMA\_STREQ **DMA Software Transaction Request Register** (418<sub>H</sub>) Reset Value: 0000 0000<sub>H</sub> 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 0 r 2 15 14 13 12 11 10 9 8 7 6 5 4 3 1 0 SCH SCH SCH SCH SCH SCH SCH SCH 0 07 06 05 04 03 02 01 00 W W W W W W w W r

| Field              | Bits   | Туре | Description                                                                                                                                                                                                                                                     |
|--------------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCH0n<br>(n = 0-7) | n      | w    | <ul> <li>Set Transaction Request for DMA Channel 0n</li> <li>0 No action.</li> <li>1 A transaction for DMA channel 0n is requested.</li> <li>When setting SCH0n, TRSR.CH0n becomes set to indicate that a DMA request is pending for DMA channel 0n.</li> </ul> |
| 0                  | [31:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                         |



The bits in the Hardware Transaction Request Register enable or disable DMA hardware requests.

# DMA\_HTREQ

| DMA | Hard                | ware | Tran | sacti  | on Re | eques | st Reg | gister |     |     |                                     |     |     |     |     |  |
|-----|---------------------|------|------|--------|-------|-------|--------|--------|-----|-----|-------------------------------------|-----|-----|-----|-----|--|
|     | (41C <sub>H</sub> ) |      |      |        |       |       |        |        |     |     | Reset Value: 0000 0000 <sub>H</sub> |     |     |     |     |  |
| 31  | 30                  | 29   | 28   | 27     | 26    | 25    | 24     | 23     | 22  | 21  | 20                                  | 19  | 18  | 17  | 16  |  |
|     | 1                   | I    |      |        | 1     | 1     | I      | DCH    | DCH | DCH | DCH                                 | DCH | DCH | DCH | DCH |  |
|     |                     | 1    |      | D      | 1     |       | 1      | 07     | 06  | 05  | 04                                  | 03  | 02  | 01  | 00  |  |
|     |                     | I    |      | r      |       |       | I      | W      | W   | W   | W                                   | W   | W   | W   | W   |  |
| 15  | 14                  | 13   | 12   | 11     | 10    | 9     | 8      | 7      | 6   | 5   | 4                                   | 3   | 2   | 1   | 0   |  |
|     | 1                   | Ι    |      | ן<br>ס | T     | 1     | Ι      | ECH    | -   | -   | -                                   | -   | ECH | -   | ECH |  |
|     | 1                   | I    | I    | -      | 1     | 1     | I      | 07     | 06  | 05  | 04                                  | 03  | 02  | 01  | 00  |  |
|     |                     |      |      | r      |       |       |        | W      | W   | W   | W                                   | W   | W   | W   | W   |  |

| Field              | Bits               | Туре | Description                                                                |
|--------------------|--------------------|------|----------------------------------------------------------------------------|
| ECH0n<br>(n = 0-7) | n                  | w    | Enable Hardware Transfer Request<br>for DMA Channel 0n<br>see table below  |
| DCH0n<br>(n = 0-7) | n + 16             | w    | Disable Hardware Transfer Request<br>for DMA Channel 0n<br>see table below |
| 0                  | [31:24],<br>[15:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                    |

#### **Set/Reset Bit Conditions**

#### Table 3-4 Conditions to Set/Reset the Bits TRSR.HTRE0n

| HTREQ.ECH0n | HTREQ.DCH0n | Transaction<br>Finishes <sup>1)</sup> for<br>Channel 0n | Modification of TRSR.HTRE0n |
|-------------|-------------|---------------------------------------------------------|-----------------------------|
| 0           | 0           | 0                                                       | unchanged                   |
| 1           | 0           | 0                                                       | set                         |
| X           | 1           | Х                                                       | reset                       |
| X           | Х           | 1                                                       | reset                       |

<sup>1)</sup> In Single Mode only. In Continuous Mode, the end of a transaction has no impact.



The Error Status Register indicates if the DMA controller could not answer to a request because the previous request was not terminated.

|    | ERR<br>Erro |    | us Ro  | egiste   | er | (424 <sub>H</sub> ) |    |           |           | Reset Value: 000 |           |           |           |            | 0000 <sub>H</sub> |
|----|-------------|----|--------|----------|----|---------------------|----|-----------|-----------|------------------|-----------|-----------|-----------|------------|-------------------|
| 31 | 30          | 29 | 28     | 27       | 26 | 25                  | 24 | 23        | 22        | 21               | 20        | 19        | 18        | 17         | 16                |
|    |             | D  | 1      | MLI<br>0 |    | LEC<br>ME0          |    |           | 1         | (                | )<br>)    |           | 1         | ME0<br>DER | ME0<br>SER        |
|    | 1           | r  | 1      | rh       |    | rh                  |    | 1         | <u> </u>  |                  | r         |           | <u> </u>  | rh         | rh                |
| 15 | 14          | 13 | 12     | 11       | 10 | 9                   | 8  | 7         | 6         | 5                | 4         | 3         | 2         | 1          | 0                 |
|    | 1           | 1  | ı<br>( | 0        |    |                     |    | TRL<br>07 | TRL<br>06 | TRL<br>05        | TRL<br>04 | TRL<br>03 | TRL<br>02 | TRL<br>01  | TRL<br>00         |
|    |             |    |        | r        |    |                     |    | rh        | rh        | rh               | rh        | rh        | rh        | rh         | rh                |

| Field              | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                                                         |
|--------------------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRL0n<br>(n = 0-7) | n    | rh   | <ul> <li>Transaction/Transfer Request Lost of DMA</li> <li>Channel 0n</li> <li>0 No request lost event has been detected for channel 0n.</li> <li>1 A new DMA request was detected while TRSR.CH0n=1 (request lost event).</li> <li>This bit is reset by software when writing a 1 to CLRE.CTL0n, or by a channel reset (writing CHRSTR.CH0n = 1).</li> </ul>       |
| <b>ME0SER</b>      | 16   | rh   | <ul> <li>Move Engine 0 Source Error</li> <li>This bit is set whenever a Move Engine 0 error occurred during a source (read) move of a DMA transfer, or a request could not been serviced due to the access protection.</li> <li>0 No Move Engine 0 source error has occurred.</li> <li>1 A Move Engine 0 source error has occurred.</li> </ul>                      |
| <b>ME0DER</b>      | 17   | rh   | <ul> <li>Move Engine 0 Destination Error</li> <li>This bit is set whenever a Move Engine 0 error occurred during a destination (write) move of a DMA transfer, or a request could not been serviced due to the access protection.</li> <li>0 No Move Engine 0 destination error has occurred.</li> <li>1 A Move Engine 0 destination error has occurred.</li> </ul> |



| Field  | Bits                           | Туре | Description                                                                                                                                                           |
|--------|--------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LECME0 | [26:24]                        | rh   | Last Error Channel Move Engine 0<br>This bit field indicates the channel number of the last<br>channel of Move Engine 0 leading to an Bus error that<br>has occurred. |
| MLIO   | 27                             | rh   | MLI0 Error SourceThis bit is set whenever an Bus error occurred due to an<br>action of MLI0.0No bus error occurred due to MLI0.1An bus error occurred due to MLI0.    |
| 0      | [15:8],<br>[23:18],<br>[31:28] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                               |



The Clear Error contains bits that make it possible to clear the Transaction Request Lost flags or the Move Engine error flags.

# DMA\_CLRE

| DMA | OMA Clear Error Register |    |    |             |    |    | (428 <sub>H</sub> ) |           |           |           |           | Reset Value: 0000 0000 |           |                 |                 |  |
|-----|--------------------------|----|----|-------------|----|----|---------------------|-----------|-----------|-----------|-----------|------------------------|-----------|-----------------|-----------------|--|
| 31  | 30                       | 29 | 28 | 27          | 26 | 25 | 24                  | 23        | 22        | 21        | 20        | 19                     | 18        | 17              | 16              |  |
|     | (                        | )  | 1  | CLR<br>MLI0 |    |    |                     | 1         | 0         |           |           |                        |           | C<br>ME0<br>DER | C<br>ME0<br>SER |  |
|     |                          | r  | 1  | W           |    |    |                     |           | r         | 1         | 1         |                        | 1         | w               | W               |  |
| 15  | 14                       | 13 | 12 | 11          | 10 | 9  | 8                   | 7         | 6         | 5         | 4         | 3                      | 2         | 1               | 0               |  |
|     | 1                        | 1  |    | 0           |    | 1  | 1                   | CTL<br>07 | CTL<br>06 | CTL<br>05 | CTL<br>04 | CTL<br>03              | CTL<br>02 | CTL<br>01       | CTL<br>00       |  |
|     | 1                        |    | 1  | r           |    | 1  | 1                   | W         | W         | W         | W         | W                      | W         | W               | W               |  |

| Field              | Bits                           | Туре | Description                                                                                                          |
|--------------------|--------------------------------|------|----------------------------------------------------------------------------------------------------------------------|
| CTL0n<br>(n = 0-7) | n                              | W    | Clear Transaction Request Lost for DMA ChannelOn001Clear DMA channel On transaction request lost<br>flag ERRSR.TRLOn |
| CME0SER            | 16                             | W    | Clear Move Engine 0 Source Error0No action1Clear source error flag ERRSR.ME0SER.                                     |
| CME0DER            | 17                             | W    | Clear Move Engine 0 Destination Error0No action1Clear destination error flag ERRSR.ME0DER.                           |
| CLRMLI0            | 27                             | W    | Clear MLI0 Error0No action1Clear error flag ERRSR.MLI0.                                                              |
| 0                  | [15:8],<br>[26:18],<br>[31:28] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                              |



#### 3.3.2 Move Engine Registers

The Move Engine Status Register is a read-only register that holds status information about the transaction handled by the Move Engines.

#### DMA\_MESR

| DMA | MA Move Engine Status Register |    |    |    |    |    | (43 | 60 <sub>H</sub> ) |    |    | Res       | et Va | lue: 0 | 000 | 0000 <sub>H</sub> |
|-----|--------------------------------|----|----|----|----|----|-----|-------------------|----|----|-----------|-------|--------|-----|-------------------|
| 31  | 30                             | 29 | 28 | 27 | 26 | 25 | 24  | 23                | 22 | 21 | 20        | 19    | 18     | 17  | 16                |
|     |                                |    |    |    |    |    | (   | )                 |    |    |           |       |        |     |                   |
|     |                                |    |    |    |    |    |     | r                 |    |    |           |       |        |     |                   |
| 15  | 14                             | 13 | 12 | 11 | 10 | 9  | 8   | 7                 | 6  | 5  | 4         | 3     | 2      | 1   | 0                 |
|     | 1                              | 1  | 1  | 1  | 0  | 1  | 1   | 1                 | 1  | 1  | ME0<br>WS |       | CH0    |     | ME0<br>RS         |
| L   | 1                              | 1  | 1  | I. | r  | 1  | 1   | 1                 | I. | 1  | rh        |       | rh     |     | rh                |

| Field | Bits   | Туре | Description                                                                                                                                    |
|-------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------|
| MEORS | 0      | rh   | <ul> <li>Move Engine 0 Read Status</li> <li>Move Engine 0 is not performing a read.</li> <li>Move Engine 0 is performing a read.</li> </ul>    |
| CH0   | [3:1]  | rh   | <b>Reading Channel in Move Engine 0</b><br>This bit field indicates which channel number is<br>currently being processed by the Move Engine 0. |
| MEOWS | 4      | rh   | <ul> <li>Move Engine 0 Write Status</li> <li>Move Engine 0 is not performing a write.</li> <li>Move Engine 0 is performing a write.</li> </ul> |
| 0     | [31:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                        |



The Move Engine 0 Read Register indicates the value that has just been read by Move Engine 0.

#### DMA\_ME0R

| DMA Move Engin | e 0 Read Register | (434 <sub>H</sub> ) | Reset Value: 0000 0000 |      |  |  |  |  |
|----------------|-------------------|---------------------|------------------------|------|--|--|--|--|
| 31             | 24 23             | 16 15               | 8                      | 7 0  |  |  |  |  |
| RD03           | RD02              |                     | RD01                   | RD00 |  |  |  |  |
| rh             | <u> </u>          |                     | rh                     | rh   |  |  |  |  |

| Field          | Bits              | Туре | Description                                                                                                      |
|----------------|-------------------|------|------------------------------------------------------------------------------------------------------------------|
| RD00,<br>RD01, | [7:0],<br>[15:8], | rh   | <b>Read Value for Move Engine 0</b><br>Contains the 32-bit read data (four bytes RD0[3:0])                       |
| RD02,          | [23:16],          |      | that is stored in the Move Engine 0 after each read                                                              |
| RD03           | [31:24]           |      | move. The content of ME0R is overwritten after each read move of a DMA channel belonging to DMA Sub-<br>block 0. |



# 3.3.3 Channel Control/Status Registers

The Channel Control Register for DMA channel 0n contains its configuration and its control bits and bit fields.

# DMA\_CHCR0n (n = 0-7)

DMA Channel 0n Control Register (484<sub>H</sub>+n\*20<sub>H</sub>)

Reset Value: 0000 0000<sub>H</sub>

| 31 | 30    | 29      | 28         | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20             | 19        | 18 | 17   | 16 |
|----|-------|---------|------------|----|----|----|----|----|----|----|----------------|-----------|----|------|----|
| 0  | 0     | 0       | CH<br>PRIO | (  | )  | 0  | L  | 0  | СН | DW | CH<br>MO<br>DE | RRO<br>AT |    | BLKM |    |
| r  | rw    | r       | rw         | I  | r  | r  | W  | r  | r  | w  | rw             | rw        |    | rw   | 1  |
| 15 | 14    | 13      | 12         | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4              | 3         | 2  | 1    | 0  |
| I  | PRSEI | <u></u> |            | (  | )  |    |    |    |    |    | TREL           | •         |    |      |    |
| L  | rw    | 1       | 1 1        | l  | r  | 1  | 1  | 1  | I  | 1  | rw             | 1         |    | 1    |    |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TREL  | [8:0] | rw   | Transfer Reload Value<br>This bit field contains the number of DMA transfers for s<br>DMA transaction of DMA channel 0n. This 9-bit transfer<br>count value is loaded into CHSR0n.TCOUNT at the start<br>of a DMA transaction (when TRSR.CH00n becomes set<br>and CHSR0n.TCOUNT = 0). TREL can be written<br>during a running DMA transaction because TCOUNT<br>will be updated (decremented) during the DMA<br>transaction.<br>If TREL = 0 or if TREL = 1, TCOUNT will be loaded with<br>1 when a new transaction is started (at least one DMA<br>transfer must be executed per DMA transaction). |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRSEL | [15:13] | rw   | Peripheral Request Select<br>This bit field controls the hardware request input<br>multiplexer of DMA channel 0n (see Figure 3-7 on<br>Page 3-15).<br>000 <sub>B</sub> Input CH0n_REQI0 selected<br>001 <sub>B</sub> Input CH0n_REQI1 selected<br>010 <sub>B</sub> Input CH0n_REQI2 selected<br>011 <sub>B</sub> Input CH0n_REQI3 selected<br>100 <sub>B</sub> Input CH0n_REQI4 selected<br>101 <sub>B</sub> Input CH0n_REQI5 selected<br>110 <sub>B</sub> Input CH0n_REQI6 selected<br>111 <sub>B</sub> Input CH0n_REQI7 selected |
| BLKM  | [18:16] | rw   | <b>Block Mode</b><br>BLKM determines the number of DMA moves executed<br>during one DMA transfer.<br>$000_BOne$ DMA transfer has 1 DMA move<br>$001_BOne$ DMA transfer has 2 DMA moves<br>$010_BOne$ DMA transfer has 4 DMA moves<br>$011_BOne$ DMA transfer has 8 DMA moves<br>$100_BOne$ DMA transfer has 16 DMA moves<br>$100_BOne$ DMA transfer has 16 DMA moves<br>OthersReserved; do not use these combinations.<br>See also Figure 3-11 on Page 3-22.                                                                       |
| RROAT | 19      | rw   | <ul> <li>Reset Request Only After Transaction         RROAT determines whether or not the TRSR.CH0n             transfer request state flag is reset after each transfer.      </li> <li>TRSR.CH0n is reset after each transfer. A             transfer request is required for each transfer.      </li> <li>TRSR.CH0n is reset when TCOUNT = 0 after a             transfer. One transfer request starts a complete         DMA transaction.     </li> </ul>                                                                     |



| Field  | Bits                                 | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|--------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHMODE | 20                                   | rw   | <ul> <li>Channel Operation Mode</li> <li>CHMODE determines the reset condition for control bit</li> <li>TRSR.HTRE0n of DMA channel 0n.</li> <li>0 Single Mode operation is selected for DMA channel 0n. After a transaction, DMA channel 0n is disabled for further hardware requests (TRSR.HTRE0n is reset by hardware).</li> <li>TRSR.HTRE0n must be set again by software for starting a new transaction.</li> <li>1 Continuous Mode operation is selected for DMA channel 0n. After a transaction, bit</li> <li>TRSR.HTRE0n remains set.</li> </ul> |
| CHDW   | [22:21]                              | rw   | <ul> <li>Channel Data Width</li> <li>CHDW determines the data width for the read and write moves of DMA channel 0n.</li> <li>8-bit (byte) data width for moves selected</li> <li>16-bit (half-word) data width for moves selected</li> <li>32-bit (word) data width for moves selected</li> <li>Reserved</li> </ul>                                                                                                                                                                                                                                     |
| CHPRIO | 28                                   | rw   | <ul> <li>Channel Priority</li> <li>CHPRIO determines the priority of DMA channel 0n for the channel arbitration of Move Engine 0.</li> <li>0 DMA channel 0n has a low channel priority.</li> <li>1 DMA channel 0n has a high channel priority.</li> </ul>                                                                                                                                                                                                                                                                                               |
| 0      | [25:24],<br>30                       | rw   | <b>Reserved</b><br>Read as 0; have to be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0      | [12:9],<br>23,<br>[27:26],<br>29, 31 | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



The Channel Status Register contains the current transfer count and a pattern detection compare result.

| DMA<br>DMA |    |    | -  | -  | Regis | ter (4 | 480 <sub>H</sub> + | •n*20 <sub>l</sub> | н) |    | Res  | et Va | lue: ( | 0000 ( | 0000 <sub>H</sub> |
|------------|----|----|----|----|-------|--------|--------------------|--------------------|----|----|------|-------|--------|--------|-------------------|
| 31         | 30 | 29 | 28 | 27 | 26    | 25     | 24                 | 23                 | 22 | 21 | 20   | 19    | 18     | 17     | 16                |
|            | 1  | 1  | 1  | 1  | 1     | 1      |                    | D                  | 1  | 1  | 1    | 1     | 1      | 1      |                   |
|            | 1  | 1  | 1  | 1  | 1     | 1      |                    | r                  | 1  | 1  | 1    | 1     | I      | 1      | <u> </u>          |
| 15         | 14 | 13 | 12 | 11 | 10    | 9      | 8                  | 7                  | 6  | 5  | 4    | 3     | 2      | 1      | 0                 |
|            | 1  | 1  | 0  | 1  | 1     | 1      |                    | 1                  | 1  | T  | COUN | IT    | 1      | 1      | 1                 |
| L          | 1  | 1  | r  | 1  | 1     | 1      | 1                  | 1                  | 1  | 1  | rh   | 1     | 1      | 1      | 11                |

| Field  | Bits   | Туре | Description                                                                                                                                                                                                                                                              |
|--------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TCOUNT | [8:0]  | rh   | <b>Transfer Count Status</b><br>TCOUNT holds the actual value of the DMA transfer<br>count for DMA channel 0n. TCOUNT is loaded with<br>the value of CHCR0n.TREL when TRSR.CH0n<br>becomes set (and TCOUNT = 0). After each DMA<br>transfer, TCOUNT is decremented by 1. |
| 0      | [31:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                  |



The Address Control Register controls how source and destination addresses are updated after a DMA move. Furthermore, it determines whether or not a source or destination address register update is shadowed.

|    | _ADR<br>Char |    | •  |    | s Con |    | -        | ter<br>⊦n*20 <sub>⊦</sub> | -) |     | Res | et Va | lue: ( | 0000 0 | 0000 <sub>H</sub> |
|----|--------------|----|----|----|-------|----|----------|---------------------------|----|-----|-----|-------|--------|--------|-------------------|
| 31 | 30           | 29 | 28 | 27 | 26    | 25 | 24       | 23                        | 22 | 21  | 20  | 19    | 18     | 17     | 16                |
|    |              |    |    | 1  | 1     | (  | <b>)</b> |                           |    |     |     |       |        | SH     | ст                |
|    |              |    |    |    |       |    | r        |                           |    |     |     |       |        | rv     | V                 |
| 15 | 14           | 13 | 12 | 11 | 10    | 9  | 8        | 7                         | 6  | 5   | 4   | 3     | 2      | 1      | 0                 |
|    | СВ           | LD | 1  |    | СВ    | LS | 1        | INCD                      |    | DMF |     | INCS  |        | SMF    |                   |
| L  | ٢١           | N  | L  | 1  | rv    | N  | 1        | rw                        |    | rw  |     | rw    |        | rw     | I                 |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SMF   | [2:0] | rw   | Source Address Modification Factor<br>This bit field and the data width as defined in<br>CHCR0n.CHDW determine an address offset value by<br>which the source address is modified after each DMA<br>move. See also Table 3-5.<br>$000_B$ Address offset is 1 × CHCR0n.CHDW.<br>$001_B$ Address offset is 2 × CHCR0n.CHDW.<br>$010_B$ Address offset is 4 × CHCR0n.CHDW.<br>$011_B$ Address offset is 8 × CHCR0n.CHDW.<br>$100_B$ Address offset is 16 × CHCR0n.CHDW.<br>$101_B$ Address offset is 32 × CHCR0n.CHDW.<br>$101_B$ Address offset is 32 × CHCR0n.CHDW.<br>$101_B$ Address offset is 32 × CHCR0n.CHDW.<br>$111_B$ Address offset is 64 × CHCR0n.CHDW.<br>$111_B$ Address offset is 128 × CHCR0n.CHDW. |
| INCS  | 3     | rw   | Increment of Source AddressThis bit determines whether the address offset as<br>selected by SMF will be added to or subtracted from the<br>source address after each DMA move. The source<br>address is not modified if CBLS = $0000_B$ .0Address offset will be subtracted.1Address offset will be added.                                                                                                                                                                                                                                                                                                                                                                                                       |



| Field | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMF   | [6:4]  | rw   | <b>Destination Address Modification Factor</b><br>This bit field and the data width as defined in<br>CHCR0n.CHDW determines an address offset value by<br>which the destination address is modified after each<br>DMA move. The destination address is not modified if<br>CBLD = $0000_B$ . See also <b>Table 3-5</b> .<br>$000_B$ Address offset is 1 × CHDW.<br>$001_B$ Address offset is 2 × CHDW.<br>$010_B$ Address offset is 4 × CHDW.<br>$011_B$ Address offset is 8 × CHDW.<br>$100_B$ Address offset is 16 × CHDW.<br>$101_B$ Address offset is 32 × CHDW.<br>$101_B$ Address offset is 32 × CHDW.<br>$111_B$ Address offset is 32 × CHDW. |
| INCD  | 7      | rw   | Increment of Destination AddressThis bit determines whether the address offset as<br>selected by DMF will be added to or subtracted from the<br>destination address after each DMA move. The<br>destination address is not modified if $CBLD = 0000_B$ .0Address offset will be subtracted.1Address offset will be added.                                                                                                                                                                                                                                                                                                                           |
| CBLS  | [11:8] | rw   | <b>Circular Buffer Length Source</b><br>This bit field determines which part of the 32-bit source<br>address register remains unchanged and is not updated<br>after a DMA move operation (see also <b>Section 3.2.4.6</b> ).<br>Therefore, CBLS also determines the size of the circular<br>source buffer.<br>$0000_B$ Source address SADR[31:0] is not updated.<br>$0001_B$ Source address SADR[31:1] is not updated.<br>$0010_B$ Source address SADR[31:2] is not updated.<br>$0011_B$ Source address SADR[31:3] is not updated.<br>$0011_B$ Source address SADR[31:3] is not updated.<br>$1110_B$ Source address SADR[31:14] is not updated.     |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CBLD  | [15:12] | rw   | <b>Circular Buffer Length Destination</b><br>This bit field determines which part of the 32-bit<br>destination address register remains unchanged and is<br>not updated after a DMA move operation (see also<br><b>Page 3-24</b> ). Therefore, CBLD also determines the size<br>of the circular destination buffer.<br>$0000_B$ Destination address DADR[31:0] is not updated.<br>$0001_B$ Destination address DADR[31:1] is not updated.<br>$0010_B$ Destination address DADR[31:2] is not updated.<br>$0011_B$ Destination address DADR[31:3] is not updated.<br>$0011_B$ Destination address DADR[31:3] is not updated.<br>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SHCT  | [17:16] | rw   | <ul> <li>1111<sub>B</sub>Destination address DADR[31:15] is not updated.</li> <li>Shadow Control This bit field determines whether an address is transferred into the shadow address register when writing to source or destination address register. Shadow address register not used. Source and destination address register are written directly. Shadow address register used for source address buffering. When writing to SADR0n, the address is buffered in SHADR0n and transferred to SADR0n with the start of the next DMA transaction. Shadow address register used for destination address buffering. When writing to DADR0n, the address is buffered in SHADR0n and transferred to SADR0n with the start of the next DMA transaction. Shadow address register used for destination address buffering. When writing to DADR0n, the address is buffered in SHADR0n and transferred to DADR0n, the address of SHCT = 01<sub>B</sub> or 10<sub>B</sub>, SHCT must not be changed until the next DMA transaction has been started.</li></ul> |
| 0     | [31:18] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**Table 3-5** shows the offset values that are added or subtracted to/from a source or destination address register after a DMA move. Bit field SMF and bit INCS determine the offset value for the source address. Bit field DMF and bit INCD determine the offset value for the destination address.



| Table            | 3-3 A                 | udress Ons                     | et Calci         |              | apie                             |                  |              |                                |
|------------------|-----------------------|--------------------------------|------------------|--------------|----------------------------------|------------------|--------------|--------------------------------|
|                  | CR0n.CH<br>3-bit Data | DW = 00 <sub>B</sub><br>Width) |                  | CR0n.CH      | DW = 01 <sub>B</sub><br>a Width) |                  | R0n.CHI      | DW = 10 <sub>B</sub><br>Width) |
| SMF<br>DMF       | INCS<br>INCD          | Address<br>Offset              | SMF<br>DMF       | INCS<br>INCD | Address<br>Offset                | SMF<br>DMF       | INCS<br>INCD | Address<br>Offset              |
| 000 <sub>B</sub> | 0                     | -1                             | 000 <sub>B</sub> | 0            | -2                               | 000 <sub>B</sub> | 0            | -4                             |
|                  | 1                     | +1                             |                  | 1            | +2                               |                  | 1            | +4                             |
| 001 <sub>B</sub> | 0                     | -2                             | 001 <sub>B</sub> | 0            | -4                               | 001 <sub>B</sub> | 0            | -8                             |
|                  | 1                     | +2                             |                  | 1            | +4                               |                  | 1            | +8                             |
| 010 <sub>B</sub> | 0                     | -4                             | 010 <sub>B</sub> | 0            | -8                               | 010 <sub>B</sub> | 0            | -16                            |
|                  | 1                     | +4                             |                  | 1            | +8                               |                  | 1            | +16                            |
| 011 <sub>B</sub> | 0                     | -8                             | 011 <sub>B</sub> | 0            | -16                              | 011 <sub>B</sub> | 0            | -32                            |
|                  | 1                     | +8                             |                  | 1            | +16                              |                  | 1            | +32                            |
| 100 <sub>B</sub> | 0                     | -16                            | 100 <sub>B</sub> | 0            | -32                              | 100 <sub>B</sub> | 0            | -64                            |
|                  | 1                     | +16                            |                  | 1            | +32                              |                  | 1            | +64                            |
| 101 <sub>B</sub> | 0                     | -32                            | 101 <sub>B</sub> | 0            | -64                              | 101 <sub>B</sub> | 0            | -128                           |
|                  | 1                     | +32                            |                  | 1            | +64                              |                  | 1            | +128                           |
| 110 <sub>B</sub> | 0                     | -64                            | 110 <sub>B</sub> | 0            | -128                             | 110 <sub>B</sub> | 0            | -256                           |
|                  | 1                     | +64                            |                  | 1            | +128                             |                  | 1            | +256                           |
| 111 <sub>B</sub> | 0                     | -128                           | 111 <sub>B</sub> | 0            | -256                             | 111 <sub>B</sub> | 0            | -512                           |
|                  | 1                     | +128                           |                  | 1            | +256                             |                  | 1            | +512                           |
|                  |                       |                                |                  |              |                                  |                  |              | 1                              |

#### Table 3-5 Address Offset Calculation Table

*Note:* CHCR0*n*.CHDW =  $11_B$  is reserved and should not be used.



Recet Values 0000 0000

# 3.3.4 Channel Address Registers

The Source Address Register contains the 32-bit source address. If a DMA channel 0n is active, SADR0n is updated continuously (if programmed) and shows the actual source address that is used for read moves within DMA transfers.

#### DMA\_SADR0n (n = 0-7) DMA Channel 0n Source Address Register (490 +n\*20 )

|    | (490 <sub>H</sub> +n°20 <sub>H</sub> ) | Reset value: 0000 0000 <sub>H</sub> |
|----|----------------------------------------|-------------------------------------|
| 31 |                                        | 0                                   |
|    |                                        |                                     |
|    | SADR                                   |                                     |
|    |                                        |                                     |
|    | rwh                                    |                                     |

| Field | Bits   | Туре | Description                                                                                                                     |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------------|
| SADR  | [31:0] | rwh  | Source Start Address<br>This bit field holds the actual 32-bit source address of<br>DMA channel 0n that is used for read moves. |

A write to SADR0n is executed directly only when the DMA channel 0n is inactive (CHSR0n.TCOUNT = 0 and TRSR.CH0n = 0). If DMA channel 0n is active when writing to SADR0n, the source address will not be written into SADR0n directly but will be buffered in the shadow register SADR0n until the start of the next DMA transaction. During this shadowed address register operation, bit field ADRCR0n.SHCT must be set to  $01_{B}$ .



The Destination Address Register contains the 32-bit destination address. If a DMA channel is active, DADR0n is updated continuously (if programmed) and shows the actual destination address that is used for write moves within DMA transfers.

#### DMA\_DADR0n (n = 0-7) DMA Channel 0n Destination Address Register $(494_{\mu}+n^{*}20_{\mu})$

Reset Value: 0000 0000<sub>H</sub>

| 3 | 1 |   |   |   |   |   |   |   |   |   |   |  |   |   |   |    |    |   |   |   |   |   |   |   |   |   |   |  |   |   |   |   | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|---|----|----|---|---|---|---|---|---|---|---|---|---|--|---|---|---|---|---|
|   | 1 | I | 1 | 1 | 1 | l | 1 | 1 | I | 1 | 1 |  | 1 | I | 1 | 1  |    | l | 1 | 1 | 1 | 1 | I | 1 | 1 | I | I |  | 1 | 1 | 1 | 1 |   |
|   |   |   |   |   |   |   |   |   |   |   |   |  |   |   | [ | DA | DR | 2 |   |   |   |   |   |   |   |   |   |  |   |   |   |   |   |
|   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  | 1 | 1 | 1 |    |    | 1 | 1 | 1 | 1 | 1 | 1 |   | 1 | 1 | 1 |  | 1 | 1 | 1 | 1 |   |
|   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |   | rw | /h |   |   |   |   |   |   |   |   |   |   |  |   |   |   |   |   |

| Field | Bits   | Туре | Description                                                                                                                                 |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| DADR  | [31:0] | rwh  | <b>Destination Address</b><br>This bit field holds the actual 32-bit destination address<br>of DMA channel 0n that is used for write moves. |

A write to DADR0n is executed directly only when the DMA channel 0n is inactive (CHSR0n.TCOUNT = 0 and TRSR.CH0n = 0). If DMA channel 0n is active when writing to DADR0n, the source address will not be written into DADR0n directly but will be buffered in the shadow register SADR0n until the start of the next DMA transaction. During this shadowed address register operation, bit field ADRCR0n.SHCT must be set to  $10_{B}$ .



The Shadow Address Register holds the shadowed source or destination address before it is written into the source or destination address register. SHADROn can be read only.

#### DMA\_SHADR0n (n = 0-7) DMA Channel 0n Shadow Address Register $(498_{H}+n^{*}20_{H})$ Res

Reset Value: 0000 0000<sub>H</sub>

| 3 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|   | l | 1 |   | 1 |   | 1 | 1 | 1 |   |   | 1 | 1 |   | 1 | 1 |   | 1  | 1 |   | 1 | 1 | 1 | I | 1 | 1 |   |   | 1 | 1 | 1 | 1 | 1 |
|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | S | H | ٩D | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|   | 1 |   | 1 | 1 | 1 | 1 |   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | r | h  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

| Field | Bits   | Туре | Description                                                                                                             |
|-------|--------|------|-------------------------------------------------------------------------------------------------------------------------|
| SHADR | [31:0] | rh   | <b>Shadowed Address</b><br>This bit field holds the shadowed 32-bit source or<br>destination address of DMA channel 0n. |

SHADROn is written when source or destination address buffering is selected (ADRCROn.SHCT =  $01_B$  or ADRCROn.SHCT =  $10_B$ ) and a transaction is running. While the shadow mechanism is disabled, SHADR is set to  $0000\ 0000_H$ .

The value stored in the SHADR is automatically set to  $0000 \ 0000_{H}$  when the shadow transfer takes place. The user can read the shadow register in order to detect if the shadow transfer has already taken place. If the value in SHADR is  $0000 \ 0000_{H}$ , no shadow transfer can take place and the corresponding address register is modified according to the circular buffer rules.



# 4 Micro Link Interface (MLI)

This chapter describes the Micro Link Interface (MLI) module and the MLI protocol.

# 4.1 MLI Protocol

This section describes the MLI protocol and its general usage, and defines the terms specific to the MLI.

## 4.1.1 Overview

The Micro Link Interface (MLI) is a fast synchronous serial interface that makes it possible to exchange data between microcontrollers or other devices. Figure 4-1 shows how two microcontrollers are typically connected via their MLI interfaces. In this example, the MLI modules operate in both microcontrollers as bus masters on the internal system bus.



Figure 4-1 Typical Micro Link Interface Connection

## Features:

- Synchronous serial communication between an MLI transmitter and an MLI receiver
- Different system clock speeds supported in MLI transmitter and MLI receiver due to full handshake protocol (4 lines between a transmitter and a receiver)
- Fully transparent read/write access supported (= remote programming)
- Complete address range of target device (Remote Controller) available
- Specific frame protocol to transfer commands, addresses and data
- Error detection by parity bit
- 32-bit, 16-bit, or 8-bit data transfers supported



- Programmable baud rate:  $f_{MLI}/2$  (max.:  $f_{MLI} = f_{SYS}$ )
- Multiple receiving devices supported

# 4.1.2 MLI Specific Terms

#### Local and Remote Controller

The terms "local" and "remote" controller are assigned to the two partners (microcontrollers or other devices with MLI modules) in a serial MLI connection. The controller with an MLI module that operates as a transmitter in the serial MLI connection is defined as a Local Controller. A Local Controller handles data operations with Transfer Windows and also initiates all control tasks (control, address, and data transmissions) that are required for the data transfer/request between the Local Controller and the Remote Controller.

The controller with an MLI module that operates as a receiver in the serial MLI connection is defined as a Remote Controller. A Remote Controller handles data operations with Remote Windows and executes the tasks that have been assigned/ requested by the Local Controller.

Due to the full duplex operation capability of an MLI module, two serial MLI connections can be installed simultaneously. This means that each microcontroller with an MLI module is able to operate as a Local Controller (for transmission) as well as a Remote Controller (for reception) at the same time.

#### **Transfer Window**

A Transfer Window is an address space in the address map of the Local Controller. Transfer Windows are typically assigned to a fixed address space (base address and size) in a specific microcontroller. The transfers windows are the logical data inputs for the MLI transmitter. Data write actions are initiated by a write access to a Transfer Window, whereas data read actions are started by a read access from a Transfer Window.

Each MLI module supports up to eight independent Transfer Windows. Each Transfer Window can be accessed at two different address ranges with two different window sizes, leading to:

- Four small Transfer Windows, each with an 8 KByte address range
- Four large Transfer Windows, each with an 64 KByte address range

#### **Remote Window**

A Remote Window defines an area in the address space of the Remote Controller. Remote Window parameters (base address and window size) of the Remote Controller are programmable by the local microcontroller by MLI transfers. Each Remote Window of a Remote Controller is related to specific pair of small and large Transfer Windows of the Local Controller via one Pipe.



The Remote Windows are the logical data outputs of the MLI receiver. If enabled, the MLI module can automatically execute the requested data transfer to/from the defined address location in the Remote Window. If the automatic data handling is disabled, the offset and the data are available in the MLI receiver.

#### Pipe

A Pipe defines the logical connection between a Transfer Window in the Local Controller and the associated Remote Window in the Remote Controller. The MLI module supports up to four Pipes.

#### Frame

A frame is a contiguous set of bits forming a message sent by an MLI transmitter to an MLI receiver.

#### **Normal Frame**

A Normal Frame is the collective term for the following frame types:

- Write Offset and Data Frame
- Optimized Write Frame
- Discrete Read Frame
- Optimized Read Frame
- Answer Frame
- Copy Base Address Frame

## Offset

The offset is defined by the accessed address location relative to the base address of the Transfer Window in the Local Controller. The access is transferred to the Remote Controller, where it is executed at the address location defined by the base address of the Remote Window plus the offset. For example, a write access to the 10th byte of the Transfer Window is transferred to a write to the 10th byte of the Remote Window.

The offset of a write action to a Transfer Window is also called a write offset, whereas a read offset is related to a read action.

## 4.1.3 MLI Communication Principles

The communication principle of the MLI allows data to be transferred between a local and a Remote Controller without intervention by a CPU in the Remote Controller. Data transfers are always triggered in the Local Controller by read or write operations to an address location in a Transfer Window. All control tasks (control, address, and data transmissions) that are required for the data transfer/request between local and Remote Controller are handled autonomously by the two connected MLI modules.





#### Figure 4-2 MLI Communication Principles

#### Transfer Window Organization

**Figure 4-3** shows the organization of Transfer Windows and Remote Windows with a possible assignment in the Local and Remote Controller. Each of the four Pipes assigns one Transfer Window to one Remote Window with its base address and window size.





#### Figure 4-3 Transfer/Remote Window Assignment Example

During initialization of the Pipes, the base addresses and sizes of the Remote Windows are transmitted from the Local Controller to the Remote Controller. In the example of **Figure 4-3**, two large Transfer Windows and two small Transfer Windows are assigned to Remote Windows. Pipe 1 and Pipe 2 cover the full range of their transfer and Remote Windows. Pipe 0 and Pipe 3 address only sub-areas of the related Transfer Windows.

Remote Windows can be freely moved and located within the complete address space of the Remote Controller. They are used to overlay address ranges of peripheral modules or internal memories.

#### Remote Window Address Definition

A Remote Window is defined for each Pipe. Each Remote Window is defined by a programmable base address and a size for each Pipe. Frames transfer only the address offset information to define an address within a Remote Window if no prediction is possible. A Remote Window can have a size of up to 64 KBytes.



# 4.1.4 MLI Frame Types

A frame is a message sent by an MLI transmitter to an MLI receiver. The fame type depends on the desired behavior:

The MLI protocol offers seven different frame types for communication.

- Copy Base Address Frame—defines the base address and size of a Remote Window
- Write Offset and Data Frame—transmits the write offset and the write data
- Discrete Read Frame—transmits read request with the read offset
- Command Frame—transmits a command (e.g. setup information or MLI Request generation)
- Optimized Write Frame—transmits write data without a write offset (in case of an address prediction match)
- Optimized Read Frame—transmits the read request without a read offset (in case of an address prediction match)
- Answer Frame—transmits the data previously requested by a read frame

The local/remote structure of an MLI connection between two microcontrollers requires a transmitter unit and a receiver unit in both MLI modules (local and remote) for communication. Physically, the communication is performed via two separate serial MLI buses. Logically, the information flow of each MLI frame can be assigned to one of the MLI-Buses (see Figure 4-4).

| Local Controller |                             | Remote Controller |
|------------------|-----------------------------|-------------------|
| MLI Module       |                             | MLI Module        |
|                  | Copy Base Address Frame     |                   |
|                  | Write Offset and Data Frame |                   |
|                  | Discrete Read Frame         |                   |
| Transmitter      | Command Frame               | Receiver          |
|                  | Optimized Write Frame       |                   |
|                  | Optimized Read Frame        |                   |
| Receiver         | Answer Frame                | Transmitter       |

## Figure 4-4 Logic Frame Assignment to Local/Remote Controller

The general layout of a frame is shown in **Figure 4-5**. It contains the following parts:



- A frame starts with a 4-bit header field that contains a 2-bit Frame Code (FC) and a 2-bit Pipe Number (PN).
- The data field can contain address, data, or control information. The length of the data field depends on the frame type.
- The frame is terminated by a parity bit (P) with even parity (see Page 4-17), which is calculated over header and data field bits.



# Figure 4-5 General Frame Layout

The Frame Code (FC) and the length of the data field determines the frame type of the transmitted frame.

The Pipe Number (PN) indicates the Pipe that is related to the frame content (the value of PN is defined as  $00_B$  for Pipe 0,  $01_B$  for Pipe 1,  $10_B$  for Pipe 2, and  $11_B$  for Pipe 3).

The FC parameter is coded according to Table 4-1.

| Table 4-1 | Frame Code Definition |
|-----------|-----------------------|
|-----------|-----------------------|

| Frame Code FC   | Data Field Length                | Frame Type                  | Description |
|-----------------|----------------------------------|-----------------------------|-------------|
| 00 <sub>B</sub> | 32 Bits                          | Copy Base Address Frame     | Page 4-8    |
| 01 <sub>B</sub> | 8 + m, 16 + m, or<br>32 + m Bits | Write Offset and Data Frame | Page 4-9    |
|                 | 6 + m Bits                       | Discrete Read Frame         | Page 4-11   |
| 10 <sub>B</sub> | 4 Bits                           | Command Frame               | Page 4-13   |
|                 | 8, 16, or 32 Bits                | Answer Frame                | Page 4-14   |
| 11 <sub>B</sub> | 8, 16, or 32 Bits                | Optimized Write Frame       | Page 4-10   |
|                 | 2 Bits                           | Optimized Read Frame        | Page 4-12   |



# 4.1.4.1 Copy Base Address Frame

With a Copy Base Address Frame, the two parameters (base address and size) of a Remote Window are transferred from the Local Controller to the Remote Controller to initialize or to update the Remote Window.

The Copy Base Address Frame contains the following parts:

- Header: The header starts with Frame Code FC = 00<sub>B</sub> followed by the Pipe number PN of the Pipe to which the transmitted base address bits and the size are assigned.
- Remote Window base address: The 28 most significant bits of the 32 bit base address bits can be programmed by the Local Controller (the four LSBs are considered as 0). The base address of a Remote Window must be aligned to its size, e.g. a window of 1 KByte to start at 1 KByte address boundaries.
- Remote Window size: The size is defined by the 4-bit coded size BS. The maximum size is 64 KBytes.
- Parity bit P



Figure 4-6 Copy Base Address Frame

| BS                | Remote Window Size | Number of Offset Bits |  |
|-------------------|--------------------|-----------------------|--|
| 0000 <sub>B</sub> | 2 bytes            | 1                     |  |
| 0001 <sub>B</sub> | 4 bytes            | 2                     |  |
|                   |                    |                       |  |
| 1110 <sub>B</sub> | 32 KBytes          | 15                    |  |
| 1111 <sub>B</sub> | 64 KBytes          | 16                    |  |

#### Table 4-2 Size Coding

Details about the Copy Base Address Frame handling of the CIC751 are provided in **Chapter 4.2.1.1**.



# 4.1.4.2 Write Offset and Data Frame

A Write Offset and Data Frame are used by the Local Controller to send an address offset and data to the Remote Controller.

The Write Offset and Data Frame contains the following parts:

• Header:

The header starts with Frame Code  $FC = 00_B$  followed by the Pipe number PN of the Transfer Window that has been the target of the write operation.

- m-Bits of write offset: These bits define the write offset. The value of m depends on the size of the Remote Window, defined by the Copy Base Address Frame (m = 1-16).
- Write data field: The write data field can be 8, 16, or 32 bit wide, depending on the data width of the write access to the Transfer Window.
- Parity bit P.



## Figure 4-7 Write Offset and Data Frame

Details about the Write Offset and Data Frame handling of the CIC751 are provided in Chapter 4.2.1.2.



# 4.1.4.3 Optimized Write Frame

An Optimized Write Frame is used by the Local Controller to send 8-bit, 16-bit, or 32-bit wide data to the Remote Controller. In contrast to a Write Offset and Data Frame, no write offset is transmitted because the offset address for the write data is predicted and calculated by the MLI receiver of the Remote Controller. An Optimized Write Frame allows a higher data bandwidth than Write Offset and Data Frames. An optimized frame is only send if the predicted address matches with the actually written address within the Local Controller. Otherwise, an Write Offset and Data Frame is generated.

The Write Offset and Data Frame contains the following parts:

• Header:

The header starts with Frame Code  $FC = 11_B$  followed by the Pipe number PN of the Transfer Window that has been the target of the write operation.

• Write data field:

The write data field can be 8, 16, or 32 bit wide, depending on the data width of the write access to the Transfer Window.

• Parity bit P.



#### Figure 4-8 Optimized Write Frame

Details about the Optimized Write Frame handling of the CIC751 are provided in **Chapter 4.2.1.2**.



# 4.1.4.4 Discrete Read Frame

A Discrete Read Frame is used by the Local Controller to request data to be read from the Remote Window in the Remote Controller. If the read data is available, the Remote Controller responds to this request by sending an Answer Frame with the requested read data back to the Local Controller.

The Discrete Read Frame contains the following parts:

• Header:

The header starts with Frame Code  $FC = 01_B$  followed by the Pipe number PN of the Transfer Window that has been the target of the read operation.

• m-Bits of read offset:

These bits define the read offset. The value of m depends on the size of the Remote Window, defined by the Copy Base Address Frame (m = 1-16).

• Data Width DW:

The data width DW indicates if the read from the Remote Window was an 8-, 16-, or 32-bit read action. It defines how many bytes must be delivered to the Local Controller by the Answer Frame.

• Parity bit P.



Figure 4-9 Discrete Read Frame

#### Table 4-3Data Width DW Coding

| Data Width DW   | Number of Data Bits to be transferred |
|-----------------|---------------------------------------|
| 00 <sub>B</sub> | 8-bit read access                     |
| 01 <sub>B</sub> | 16-bit read access                    |
| 10 <sub>B</sub> | 32-bit read access                    |
| 11 <sub>B</sub> | Reserved                              |

Details about the Discrete Read Frame handling of the CIC751 are provided in Chapter 4.2.1.3.



# 4.1.4.5 Optimized Read Frame

An Optimized Read Frame is used by the Local Controller to request 8-bit, 16-bit, or 32-bit wide data from the Remote Controller without sending any offset address. The address for the requested data is predicted and calculated by the MLI receiver of the Remote Controller.

The Optimized Read Frame contains the following parts:

• Header:

The header starts with Frame Code  $FC = 11_B$  followed by the Pipe number PN of the Transfer Window that has been the target of the read operation.

• Data Width DW:

The data width DW indicates if the read from the Transfer Window was an 8-, 16-, or 32-bit read action. It defines how many bytes must be delivered to the Local Controller by the Answer Frame. Same coding as for the Discrete Read Frame.

• Parity bit P.



#### Figure 4-10 Optimized Read Frame

#### Table 4-4 Data Width DW Coding

| Data Width DW   | Number of Data Bits to be transferred |
|-----------------|---------------------------------------|
| 00 <sub>B</sub> | 8-bit read access                     |
| 01 <sub>B</sub> | 16-bit read access                    |
| 10 <sub>B</sub> | 32-bit read access                    |
| 11 <sub>B</sub> | Reserved                              |

Details about the Optimized Read Frame handling of the CIC751 are provided in Chapter 4.2.1.2.



# 4.1.4.6 Command Frame

The Local Controller is able to initiate control actions to be executed by the Remote Controller by sending a Command Frame.

The Command Frame contains the following parts:

• Header:

The header starts with Frame Code  $FC = 10_B$  followed by the Pipe number PN. The Pipe number defines the type of command to be executed.

- Command Code CMD: Pipe number PN and a 4-bit CMD field are used for command coding. The command coding of some control actions is fixed, but free programmable software commands can also be defined (with PN = 11<sub>B</sub>). The coding of the command bit field is Pipespecific and depends on the transmitted Pipe Number n.
- Parity bit P.



#### Figure 4-11 Command Frame

#### Table 4-5 PN for Command Coding

| Pipe Number PN  | Command Type                                                                                                                                                                                                |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00 <sub>B</sub> | Activate MLI Request generation or other control signal(s) of the<br>Remote Controller. The identity of which signal becomes activated<br>is defined by CMD. The use of these lines depends on the product. |
| 01 <sub>B</sub> | Define delay for parity error indication in the Remote Controller.<br>The delay in RCLK cycles is defined by the value of CMD.                                                                              |
| 10 <sub>B</sub> | Control of internal functions of the Remote Controller.<br>The value of CMD indicates which function is controlled. The coding<br>of CMD and the control mechanisms depend on the product.                  |
| 11 <sub>B</sub> | Freely programmable software command.                                                                                                                                                                       |

Details about the Command Frame handling of the CIC751 are provided in Chapter 4.2.1.5.



# 4.1.4.7 Answer Frame

An Answer Frame is used by the Remote Controller to send 8-bit, 16-bit, or 32-bit wide data to the Local Controller. The Answer Frame is the only frame that is transmitted within a logic Local/Remote Controller assignment from the Remote Controller to the Local Controller. It is the answer to a Discrete Read Frame or an Optimized Read Frame that has been sent by the Local Controller to request data from the Remote Controller.

The Answer Frame contains the following parts:

• Header:

The header starts with Frame Code  $FC = 10_B$  followed by the Pipe number PN. The value of PN is taken from the read frame that has triggered the Answer Frame.

- Read data field: The read data field can be 8, 16, or 32bits wide, depending on the data width requested by the read frame that triggered the Answer Frame.
- Parity bit P.



#### Figure 4-12 Answer Frame

Details about the Answer Frame handling of the CIC751 are provided in **Chapter 4.2.1.4**.



# 4.1.5 Naming Conventions

MLI module transmitter I/O signals are indicated with the prefix "T" and MLI receiver I/O signals are indicated with the prefix "R".

The 4-line MLI-Bus between a transmitter and a receiver outside the controllers uses signal names without any prefix, as referred to in the timing diagrams of this section.

In order to emphasize where a signal is generated or sampled, actions taken by the transmitter are described by referring to signals with the prefix "T", whereas receiver actions are referred to by signals with the prefix "R".



Figure 4-13 Transmitter/Receiver Signal Definitions

# 4.1.6 MLI Communication Examples

The following section provides some basic example of the MLI communication from the point of view of the transmitter.





Figure 4-14 MLI Communication without Error (Transmitter View)

A transmission can be started by an MLI transmitter when the MLI receiver is ready to receive frames, which is indicated by TREADY = 1. When the MLI transmitter detects TREADY = 1 and starts its transmission, TVALID is asserted and is held as long as frame data is sent out. When the MLI receiver has detected the falling edge of the RVALID signal, it will de-assert RREADY (transmission start acknowledged by receiver). At the end of the frame transmission, the MLI transmitter de-asserts the TVALID signal and checks if the TREADY signal is also de-asserted. This check is used as the life-sign of the receiver and the MLI transmitter can detect whether the receiver is able to react in-time to the transmitter actions.

## 4.1.6.1 Ready Delay Time

In order to support significant propagation delays, the signal TREADY is evaluated with respect to TVALID and TCLK in a time interval called Ready Delay Time (see Figure 4-14).

When a transmission is finished (RVALID becomes 0), the MLI receiver checks the received frame for correct reception (parity error). In the case of correct reception, it asserts RREADY to indicate the correct reception with the next falling edge of RCLK. The MLI transmitter checks TREADY with respect to TVALID becoming 0 by counting TCLK periods with a ready delay counter. The ready delay counter is started from 0 at the end of a frame transmission (TVALID becomes 0). If the TREADY = 1 is detected and the ready delay counter value is less than a programmed value, it is assumed that the MLI receiver has received the frame without a parity error and a new frame can be transmitted by the MLI transmitter. An MLI transfer without a parity error condition is shown in Figure 4-14.

**Figure 4-23** shows a transfer with a parity error detected by the MLI receiver. In this case, the receiver waits a programmed number of RCLK clock cycles before setting RREADY to 1. If TREADY = 1 is detected by the transmitter and the ready delay counter



value is greater than the programmed value, an reception error condition has been signalled. For this case, it is assumed that the MLI receiver has received the frame with a parity error and has discarded the frame. In this case, the transmitter automatically sends the last frame again.

## 4.1.6.2 Non-Acknowledge Error

The transmitter of the Local Controller is able to detect an inoperable receiver in the Remote Controller. Such a non-acknowledge error condition is detected by the transmitter when at the end of a frame transmission the TREADY signal is still at high level (TREADY = 1 when TVALID becomes 0). Figure 4-15 shows the non-acknowledge error case. In this case, the transmitter automatically sends the last frame again.



Figure 4-15 Non-Acknowledge Error

## 4.1.7 Parity Generation

For parity generation, the number of transmitted bits with the value of 1 is counted over the header and the complete data field of a frame. For even parity, the parity bit is set if the result of a modulo-2 division of the elaborated number is 1. For error-free MLI traffic, even parity generation and checking is defined.

Details about the parity handling of the CIC751 are provided in Chapter 4.2.2.1.

## 4.1.8 Address Prediction

An address prediction mechanism supports communication between the MLI transmitter and the MLI receiver without sending address offset information in the frames. This feature reduces the required bandwidth for MLI communication. Both of the communication partners, the MLI transmitter and the receiver, are able to detect regular offset differences of consecutive window accesses to the same window. The address prediction mechanism operates independently for each Pipe; different prediction values can be handled in parallel for the different Pipes.

The MLI transmitter can compare the offset of each Transfer Window read or write access with the offset of the previous access to the same Transfer Window. Between



accesses to a specific window, other windows can be accessed without disturbing the prediction. Offset differences larger than 512 bytes are not supported by the address prediction.

If, in at least two accesses, the offset differences are identical, an address prediction is possible and Optimized Write Frames or Optimized Read Frames can be sent to the receiver in the Remote Controller for this Pipe. If the offset difference of the next access to this Transfer Window does not match the previous ones (predicted offset), address prediction is not possible. In this case, a Normal Frame for writing or reading (Write Offset and Data Frame or Discrete Read Frame) is started.

Identical address prediction mechanisms are used by both the transmitter and the receiver. As a result, the receiver can elaborate on the original offset value in the transmitter when receiving an optimized frame for any Pipe.

Details about the prediction mechanism of the CIC751 are provided in Chapter 4.2.2.3.





## 4.2 Functional Description

This chapter describes the functionality of the MLI interface and how frame handling can be done by software.

- Frame handling (see Page 4-19)
- MLI features (see Page 4-34)
- MLI Request structure (see Page 4-41)
- MLI transmitter interrupts (see Page 4-41)
- MLI receiver interrupts (see Page 4-43)
- Baud rate generation (see Page 4-45)

### 4.2.1 Frame Handling

Frame handling is based on receiver and transmitter registers and the Transfer Windows. Depending on the type of access to the Transfer Windows, different actions take place inside the MLI interface. Please refer to the following sections for the handling of specific frame types, see the pages indicated:

- Copy Base Address Frame (see Page 4-19)
- Data frames (see Page 4-22)
- Read frames (see Page 4-26)
- Answer Frame (see Page 4-29)
- Command Frame (see Page 4-30)

### 4.2.1.1 Copy Base Address Frame

A Copy Base Address Frame defines the base address and the size of a Remote Window.





Figure 4-16 Copy Base Address Frame Transaction Flow

### Local Controller

The transmission of a Copy Base Address Frame is started, each time a transmitter Pipe x base address register MLI\_TPxBAR (x = 0-3) is written, triggering the following actions for Pipe x.

- Bit field MLI\_TPxBAR.BS (x = 0.3) is written to bit field MLI\_TPxSTATR.BS (x = 0.3)
- Bit field MLI\_TPxBAR.ADDR (x = 0.3) is written to bit field MLI\_TCBAR.ADDR.
- Status bit field MLI\_TRSTATR.PN is updated with Pipe Number x (for example x = 2 when MLI\_TP2BAR has been written).
- Status flag MLI\_TRSTATR.BAV (base address valid) is set.
- The transmission of a Copy Base Address Frame with the two parameters MLI\_TCBAR.ADDR and MLI\_TPxSTATR.BS is started for Pipe x.

- Status flag MLI\_TRSTATR.BAV (in the Local Controller) is cleared after the Copy Base Address Frame has been finished and correctly acknowledged by the MLI receiver of the Remote Controller.
- Interrupt status flag MLI\_TISR.NFSIx is set and an MLI Request is generated if enabled by MLI\_TIER.NFSIEx = 1.

Note: After the transfer of a Copy Base Address Frame, the optimized mode will be suppressed automatically for the next two data frames. This ensures a correct offset prediction afterwards.

### **Remote Controller**

When a Copy Base Address Frame for Pipe x has been received correctly and acknowledged, the following actions are executed in the MLI receiver of the Remote Controller.

- The received address bits are stored in the receiver Pipe x base address register bit field MLI\_RPOBAR.ADDR. This bit field determines the base address of the Pipe x Remote Window.
- The received size is stored in the receiver Pipe x status register bit field MLI\_RPOSTATR.BS. This bit field determines the number of offset address bits of the Pipe x Remote Window.
- The information about the received frame type (= 00<sub>B</sub> for Copy Base Address Frame) is stored in the receiver control register bit field MLI\_RCR.TF.
- Interrupt status flag MLI\_RISR.NFRI (Normal Frame received) is set and an MLI Request is generated if enabled by MLI\_RIER.NFRIE = 01<sub>B</sub> or 10<sub>B</sub>.



# 4.2.1.2 Data Frames

Data frames transmit the write data and (optionally) the write offset.



Figure 4-17 Write Frame Transaction Flow



#### Local Controller

In the Local Controller, a write operation to a Transfer Window address defines the address, the data, and the data size and triggers the following actions in the MLI transmitter.

- The 16 least significant address bits of the Transfer Window write access are stored in MLI\_TPxAOFR.AOFF (x = 0-3) as write offset address.
- The data of the write access is stored in MLI\_TPxDATAR.DATA (x = 0-3).
- The data width of the Transfer Window write access (8-bit, 16-bit, or 32-bit) is stored in bit field MLI\_TPxSTATR.DW (x = 0-3).
- Status flag MLI\_TRSTATR.DVx is set, indicating that the Pipe contains valid data for transmission.
- If the address prediction is disabled (MLI\_TCR.NO = 1), the transmission of a Write Offset and Data Frame is started as soon as the MLI transmitter is idle.
   If the address prediction is enabled (MLI\_TCR.NO = 0), a Write Offset and Data

Frame is started only if an address prediction is not possible (indicated by **MLI\_TPOSTATR**.OP = 0). If **MLI\_TPOSTATR**.OP = 1, an address prediction is possible in the MLI transmitter and an Optimized Write Frame is started. The address prediction is described in **Chapter 4.2.2.3**.

- Status flag MLI\_TRSTATR.DVx is cleared after the Write Offset and Data Frame or the Optimized Write Frame has been finished and correctly acknowledged by the MLI receiver of the Remote Controller.
- Interrupt status flag MLI\_TISR.NFSIx is set and an MLI Request is generated if enabled by MLI\_TIER.NFSIEx = 1.

The number of offset address bits that are transmitted at a Write Offset and Data Frame is determined by the size of the Remote Window that has been previously initialized by the transmission of a Copy Base Address Frame.

#### **Remote Controller**

After a data frame has been received correctly and acknowledged, the following actions are executed in the MLI receiver of the Remote Controller:

• In the case of a Write Offset and Data Frame:

The result of the internal address prediction is not taken into account. The received offset address is added to the base address of the Pipe x Transfer Window and the result is stored in MLI\_RPxBAR.ADDR (x = 0-3) and MLI\_RADRR.ADDR. In the case of an Optimized Write Frame:

The result of the internal address prediction is taken into account. The next address in the Remote Controller to that data are written is calculated by adding the detected receiver address prediction value MLI\_RPxSTATR.AP (x = 0.3) to the actual address (MLI\_RPxBAR.ADDR (x = 0.3)) and the result is stored in MLI\_RPxBAR.ADDR (x = 0.3) and in MLI\_RADRR.ADDR.

• The received data is stored in the receiver data register MLI\_RDATAR (right aligned, unused bits are 0).



- The data width of the received data is stored in bit field MLI\_RCR.DW.
- The information about the received frame type (= 10<sub>B</sub> for a write frame) is stored into bit field MLI\_RCR.TF.
- Interrupt status flag MLI\_RISR.NFRI is set and an MLI Request is generated if enabled by MLI\_RIER.NFRIE = 01<sub>B</sub> or 10<sub>B</sub>.

After all these actions related to the reception of a write frame by the remote receiver are performed, the data that has been received from the Local Controller is ready to be written into the Remote Window related to the receiving Pipe.

This write operation can be executed in two ways:

- MLI\_RCR.MOD = 0: Automatic Data Mode is disabled.
  - In this mode, the DMA is request by an MLI Request generated for the Normal Frame received interrupt MLI\_RISR.NFRI (if enabled by MLI\_RIER.NFRIE = 10) to transfer the received write data from the MLI receiver to the Remote Window address. Therefore, it must read the data from MLI\_RDATAR, together with width MLI\_RCR.DW and the address stored in MLI\_RADRR and write it to the indicated address location.
- MLI\_RCR.MOD = 1: Automatic Data Mode is selected.

In this mode, the MLI automatically writes the received write data to the Remote Window address and sets interrupt status flag MLI\_RISR.MEI when the access is terminated. An MLI Request is generated if enabled by MLI\_RIER.MEIE = 1.



#### Figure 4-18 Write Frame Handling on Remote Side

Note: In Automatic Data Mode, write frames lead to a write action executed by the MLI. During the move operation, only one new MLI frame can be received (stored in a waiting position to be executed). Then the reception of more frames is blocked by



non-acknowledge errors. If the move operation is finished, frame execution and reception continue normally.

If Automatic Data Mode is no selected, no blocking mechanism is present.



## 4.2.1.3 Read Frames

Read frames transmit the read request and (optionally) the read offset.



Figure 4-19 Read Frame Transaction Flow



#### Local Controller

A read operation from a location within a Transfer Window delivers a dummy value as result of the read action and triggers the transmission of a read frame from the Local to the Remote Controller.

- The 16 least significant address bits of the Transfer Window read access are stored in MLI\_TPxAOFR.AOFF (x = 0-3) as read offset address.
- The data width of the Transfer Window read access (8-bit, 16-bit, or 32-bit) is stored in bit field MLI\_TPxSTATR.DW (x = 0-3).
- Status flag MLI\_TRSTATR.DVx is set.
- Status flag MLI\_TRSTATR.RPx is set. This bit is cleared when an Answer Frame has been received correctly.
- If the address prediction is not enabled (MLI\_TCR.NO = 1), transmission of a Discrete Read Frame is started. If the address prediction is enabled (MLI\_TCR.NO = 0), a Discrete Read Frame is started only if an address prediction is not possible (indicated by MLI\_TPxSTATR.OP = 0). If MLI\_TPxSTATR.OP = 1, an address prediction is possible and an Optimized Read Frame is started.
- Status flag MLI\_TRSTATR.DVx is cleared after the read frame has been finished and correctly acknowledged by the MLI receiver of the Remote Controller.

The number of offset address bits that are transmitted by a Discrete Read Frame is determined by the size of the Remote Window in the Remote Controller that has been previously initialized.

After the transmission of a read frame, the MLI expects the reception of an Answer Frame.

The Answer Frame is introduced, with the highest priority, into the data flow of the transmitter of the Remote Controller.

#### **Remote Controller**

After a read frame has been correctly received and acknowledged, the following actions are executed in the MLI receiver of the Remote Controller:

• In the case of a Discrete Read Frame:

The result of the address prediction is not taken into account. The received offset address is added to the base address of the Pipe x (stored in MLI\_RPxBAR.ADDR (x = 0-3)). The result of this addition is stored in both MLI\_RADRR.ADDR and MLI\_RPxBAR.ADDR and represents the source address of the Remote Controller where data should be read.

In the case of an Optimized Read Frame:

The result of the address prediction is taken into account. The next address in the Remote Controller where data is read is calculated by adding the detected receiver address prediction value MLI\_RPxSTATR.AP (x = 0-3) to the actual address stored in MLI\_RPxBAR.ADDR (x = 0-3). The result of this addition is stored in MLI\_RADRR.ADDR and MLI\_RPxBAR.ADDR and represents the destination address in the Remote Controller.



- The transmitted data width DW is stored in bit field MLI\_RCR.DW.
- The information about the received frame type is stored in bit field MLI\_RCR.TF.
- Interrupt status flag MLI\_RISR.NFRI is set and an MLI Request is generated if enabled by MLI\_RIER.NFRIE = 01<sub>B</sub> or 10<sub>B</sub>.

After correct reception of a read frame by the Remote Controller, the data requested by the Local Controller can be read by the Remote Controller and sent back to the Local Controller by an Answer Frame.

This read operation can be executed in two ways:

• **MLI\_RCR**.MOD = 0:

Automatic Data Mode is disabled. The DMA is requested by an MLI Request generated by the Normal Frame received interrupt to read the requested read data and transfer it to the MLI receiver. Therefore, it must read data with width MLI\_RCR.DW from the address stored in MLI\_RADRR and write the data into MLI\_TDRAR.DATA.

- MLI\_RCR.MOD = 1: Automatic Data Mode is enabled. In this mode, the MLI automatically reads the read data from the Remote Window and sets interrupt status flag MLI\_RISR.MEI. An MLI Request is generated if enabled by MLI\_RIER.MEIE = 1.
- After MLI\_TDRAR.DATA has been updated, status flag MLI\_TRSTATR.AV of the Remote Controller is set and the transmission of an Answer Frame is started.



Figure 4-20 Read Frame Handling on Remote Side

Note: In Automatic Data Mode, read frames lead to a read action executed by the MLI. During the move operation, only one more MLI frame can be received (stored in a waiting position to be executed). Then, the reception of more frames is blocked by



non-acknowledge error. If the move operation is finished, frame execution and reception continue normally. If Automatic Data Mode is disabled, no blocking mechanism is present.

## 4.2.1.4 Answer Frame

Please note that only one Answer Frame can be handled at a time. No additional Read Frame should be requested while any MLI\_TRSTATR.RPx bit is set. To ensure this a certain time-out criterion has to be defined and handled by Local Controller software. The Remote Controller should take care that no Answer Frame is delivered after the time-out criterion has been detected (e.g. by a software triggered Command Frame). The length of the time-out depends on the application and has to be defined accordingly on a case by case base (e.g. the transfer rates between Local Controller and Remote Controller etc. have to be considered). In the case a time-out has been detected, the Local Controller has to clear the MLI\_TRSTATR.RPx bit by writing 1 to MLI\_SCR.CDVx a new Read Frame can be started. If no time-out handling is supported Answer Frame data can be lost or corrupted.

#### Remote Controller

The Answer Frame is the only frame sent from the Remote Controller to the Local Controller. The transmitter part of the Remote Controller is used to generate the Answer Frame.

Every time the transmitter data read answer register **MLI\_TDRAR** is updated in the Remote Controller, the transmission of an Answer Frame is started and the following actions are triggered.

- Status flag MLI\_TRSTATR.AV is set to trigger the transmission of an Answer Frame.
- Status flag MLI\_TRSTATR.AV is cleared after the Answer Frame has been finished and correctly acknowledged by the MLI receiver of the Local Controller.

An Answer Frame is sent through the same Pipe that was used by the read frame.

#### Local Controller

If an Answer Frame has been received correctly and acknowledged, the following actions are executed in the MLI receiver of the Local Controller:

- The MLI\_TRSTATR.RPx flag is cleared.
- The received data is stored into the receiver data register MLI\_RDATAR.
   If 8 data bits are received, they are duplicated to all 4 bytes in MLI\_RDATAR.
   If 16 data bits are received, they are duplicated to both half-words in MLI\_RDATAR.
- The data width of the received data is written to bit field **MLI\_RCR**.DW.
- The received Pipe Number x represents the answer Pipe Number and is stored in bit field MLI\_TSTATR.APN.
- The information about the received frame type (= 11<sub>B</sub> for an Answer Frame) is stored in bit field MLI\_RCR.TF.



- Interrupt status flag MLI\_RISR.NFRI is set and an MLI Request is generated if enabled by MLI\_RIER.NFRIE = 01<sub>B</sub> or 10<sub>B</sub>.
- The data that has been previously requested from the Remote Controller by a read frame is available in **MLI\_RDATAR**.
- If an Answer Frame is received while the corresponding MLI\_TRSTATR.RPx bit is cleared, the reception is declared as unintended and a discarded read answer event is generated (see Page 4-43).
- Note: If an Answer Frame has been correctly received in the Local Controller, the software must read it. As long as at least one byte of this data has not yet been read out, only one more MLI frame can be received (stored in a waiting position to be executed). Then, the reception of more frames is blocked by a non-acknowledge error. If the received data has been read out, frame execution and reception continue normally.

## 4.2.1.5 Command Frame

Command Frames transmit a command (e.g. setup information).





Figure 4-21 Command Frame Transaction Flow



#### Local Controller

The transmission of a Command Frame is initiated by writing one of the four Pipe x related command code bit fields in register MLI\_TCMDR.CMDPx, triggering the following actions:

- Status flag MLI\_TRSTATR.CVx is set and the Command Frame transmission is started using x as Pipe number PN and the command code stored in MLI\_TCMDR.CMDPx as parameter.
- MLI\_TRSTATR.CVx is cleared after the Command Frame has been finished and correctly acknowledged by the Remote Controller.
- Interrupt status flag MLI\_TISR.CFSIx is set and an MLI Request is generated if enabled by MLI\_TIER.CFSIEx = 1.

#### **Remote Controller**

Depending on the Pipe x related command code that is transmitted by a Command Frame, different actions are triggered in the Remote Controller. **Table 4-6** describes the actions that are triggered by a Command Frame.

- The received PN value is checked and the corresponding control actions are executed according to Table 4-6.
- Independent of the received Pipe Number, interrupt status flag MLI\_RISR.CFRIx is set and an MLI Request is generated if enabled by MLI\_RIER.CFRIEx = 1.

If a Command Frame is received for Pipe 2 with command code  $1111_B$ , the MLI Break Event is generated if enabled (MLI\_RCR.BEN = 1).

| PN              | CMD               | Command Description                  |  |  |  |  |  |
|-----------------|-------------------|--------------------------------------|--|--|--|--|--|
| 00 <sub>B</sub> | 0001 <sub>B</sub> | Generate an MLI Request 0            |  |  |  |  |  |
|                 | 0010 <sub>B</sub> | Generate an MLI Request 1            |  |  |  |  |  |
|                 | 0011 <sub>B</sub> | Generate an MLI Request 2            |  |  |  |  |  |
|                 | 0100 <sub>B</sub> | enerate an MLI Request 3             |  |  |  |  |  |
|                 | Others            | No effect                            |  |  |  |  |  |
| 01 <sub>B</sub> | 0000 <sub>B</sub> | Set MLI_RCR.DPE to 0000 <sub>B</sub> |  |  |  |  |  |
|                 | 0001 <sub>B</sub> | Set MLI_RCR.DPE to 0001 <sub>B</sub> |  |  |  |  |  |
|                 | 0010 <sub>B</sub> | Set MLI_RCR.DPE to 0010 <sub>B</sub> |  |  |  |  |  |
|                 |                   |                                      |  |  |  |  |  |
|                 | 1111 <sub>B</sub> | Set MLI_RCR.DPE to 1111 <sub>B</sub> |  |  |  |  |  |

 Table 4-6
 Command Frame Actions for the Remote Controller



| Table 4-6 | <b>Command Frame Actions for the Remote Controller</b> (cont'd) |
|-----------|-----------------------------------------------------------------|
|-----------|-----------------------------------------------------------------|

| PN              | CMD               | Command Description                                                                  |  |  |  |
|-----------------|-------------------|--------------------------------------------------------------------------------------|--|--|--|
| 10 <sub>B</sub> | 0001 <sub>B</sub> | Select Automatic Data Mode (set MLI_RCR.MOD = 1)                                     |  |  |  |
|                 | 0010 <sub>B</sub> | Select Manual Remote Data Transfer Mode (set MLI_RCR.MOD = 0)                        |  |  |  |
|                 | 0100 <sub>B</sub> | Clear bit MLI_TRSTATR.RP0                                                            |  |  |  |
|                 | 0101 <sub>B</sub> | Clear bit MLI_TRSTATR.RP1                                                            |  |  |  |
|                 | 0110 <sub>B</sub> | Clear bit MLI_TRSTATR.RP2                                                            |  |  |  |
|                 | 0111 <sub>B</sub> | Clear bit MLI_TRSTATR.RP3                                                            |  |  |  |
|                 | 1111 <sub>B</sub> | Generate MLI Break Event; (if enabled by MLI_RCR.BEN = 1)                            |  |  |  |
|                 | others            | No effect                                                                            |  |  |  |
| 11 <sub>B</sub> | Any               | Free programmable command, stored in the remote MLI receiver bit field MLI_RCR.CMDP3 |  |  |  |





## 4.2.2 General MLI Features

The following general features comprise the MLI:

- Parity generation and checking (see Page 4-34)
- Non-acknowledge error (see Page 4-37)
- Address prediction (see Page 4-38)
- Automatic data transfers (see Page 4-39)
- Transmit priority (see Page 4-39)

# 4.2.2.1 Parity Generation and Checking

For parity generation, the number of transmitted bits with the value of 1 is counted over the header and the complete data field of a frame. For even parity, the parity bit is set if the result of a modulo-2 division of the elaborated number is 1. For odd parity, the parity bit is set if the result of a modulo-2 division of the elaborated number is 0.

For a parity error-free MLI connection, even parity must be selected in the transmitter because the receiver operates only with even parity detection. The capability to select odd parity can be used by the transmitter to force a parity error reply from the receiver during the startup procedure of the MLI connection. This can be used to measure the propagation delay and to optimize the ready delay time.

Note: There is no protection against frames where more than one bit is corrupted (e.g. shortened frames). In such a case, unpredicted behavior of the MLI module may occur.

### Local Controller

The MLI transmitter is able to count parity errors and to generate a parity error interrupt when a programmable number (max. 16) of parity errors has occurred. A parity error condition is indicated by Remote Controller after the transmission of a frame (see **Figure 4-23**). The transmitter parity error condition is detected when the TREADY signal is sampled at low level during a programmable number (MLI\_TCR.MDP = maximum delay for parity errors) of TCLK clock cycles after TVALID is de-asserted.

When a transmitter parity error condition is detected, the MLI transmitter sets the parity error flag MLI\_TSTATR.PE and also decreases the maximum parity error counter MLI\_TCR.MPE by 1. The maximum parity error counter of the transmitter MLI\_TCR.MPE determines the number of transmit parity error conditions that can be still detected until a transmitter parity error interrupt event is generated. If a transmitter parity error condition is detected and MLI\_TCR.MPE is becoming 0 or while it is 0, a transmitter parity error interrupt event is generated by setting bit MLI\_TISR.PEI and an interrupt is generated if enabled by MLI\_TIER.PEIE = 1. After a transmitter parity error event occurred, MLI\_TCR.MPE can be set again by software to a value greater  $0001_{B}$ . Otherwise, each additional transmitter parity error condition will generate an MLI Request.



The transmitter parity error flag MLI\_TSTATR.PE is cleared when a correct frame transmission and TREADY has been sampled with 1 within the ready delay time. It can be cleared by software by writing a 1 to bit MLI\_SCR.CTPE. If for example, each transmitter parity error condition should generate a transmitter parity error event, MLI\_TCR.MPE should be set to 0001<sub>B</sub>. The software can check for accumulated parity error conditions by reading MLI\_TCR.MPE or MLI\_TISR.PEI, for the status of the latest received frame, it can check MLI\_TSTATR.PE.



Figure 4-22 MLI Communication without Parity Error Indicator (Transmitter View)



Figure 4-23 MLI Communication with Parity Error Indicator (Transmitter View)

#### **Remote Controller**



The receiver always checks the parity bit of a received frame for even parity. A receiver parity condition is detected if the received parity bit does not match with the internally calculated one. If no receiver parity error condition is found after the reception of a frame, RREADY is immediately set to 1; otherwise, RREADY is kept at 0 until a defined number of RCLK cycles (as determined by bit field MLI\_RCR.DPE = delay for parity error) has been elapsed. Then, RREADY is asserted high.

If a receiver parity condition is found, the MLI receiver sets the parity error flag MLI\_RCR.PE and additionally decreases the maximum parity error counter of the receiver MLI\_RCR.MPE by 1. The maximum parity error counter MLI\_RCR.MPE determines the number of receiver parity error conditions that can be still detected until the next receiver parity error event is generated. If a receiver parity error condition is detected and MLI\_RCR.MPE is becoming 0 or while it is already 0, a receiver parity error interrupt event is generated by setting bit MLI\_RISR.PEI and an interrupt is generated if enabled by MLI\_RIER.PEIE = 1. After a receiver parity error event has occurred, MLI\_RCR.MPE can set again by software to a value greater  $0001_B$ . If, for example, each receiver parity error condition should generate a receiver parity error interrupt, MLI\_RCR.MPE can be set to  $0001_B$  after a receiver parity error interrupt has occurred.

The receiver parity error flag MLI\_RCR.PE is cleared when a correct frame transmission has occurred. MLI\_RCR.PE can be cleared by software when writing a 1 to bit MLI\_SCR.CRPE.

The receiver parity error flag MLI\_RCR.PE is cleared when a correct frame transmission and TREADY has been sampled with 1 within the ready delay time. It can be cleared by software by writing a 1 to bit MLI\_SCR.CRPE. If for example, each receiver parity error condition should generate a receiver parity error event, MLI\_RCR.MPE should be set to 0001<sub>B</sub>. The software can check for accumulated parity error conditions by reading MLI\_RCR.MPE or MLI\_RISR.PEI, for the status of the latest received frame, it can check MLI\_RCR.PE.

The delay for parity error bit field **MLI\_RCR**.DPE is a read-only bit field in the receiver that can be written only by hardware if a Command Frame for Pipe 1 is received. With this frame type, the transmitter in the Local Controller transfers a value for **MLI\_RCR**.DPE to the receiver in the Remote Controller.





Figure 4-24 MLI Communication without Parity Error Indicator (Receiver View)



Figure 4-25 MLI Communication with Parity Error Indicator (Receiver View)

# 4.2.2.2 Non-Acknowledge Error

A non-acknowledge error condition is detected by the transmitter when, at the end of a frame transmission, the TREADY signal is still at high level (TREADY = 1 when TVALID becomes 0). In this case, the error flag MLI\_TSTATR.NAE is set and the maximum non-acknowledge error counter MLI\_TCR.MNAE is decremented by 1. If a non-acknowledge error condition is detected and MLI\_TCR.MNAE is becoming 0 or while it is already 0, a time-out interrupt event is generated by setting bit MLI\_TISR.TEI and an MLI Request is generated if enabled by MLI\_TIRR.TEIE = 1. The non-acknowledge error flag



**MLI\_TSTATR**.NAE is cleared when a frame transmission has been acknowledged correctly. It can also be cleared by software when writing a 1 to bit **MLI\_SCR**.CNAE.

The non-acknowledge error counter **MLI\_TCR**.MNAE is automatically set to  $11_B$  when a frame has been acknowledged correctly. It can be read and written by software, allowing a limited number of consecutive non-acknowledge errors to be defined that can be detected until a non-acknowledge error interrupt event is generated. If, for example, the first occurrence of a non-acknowledge error should lead to an non-acknowledge interrupt, bit **MLI\_TCR**.MNAE has to be written by software with  $01_B$  after each correctly received frame.

## 4.2.2.3 Address Prediction

Address prediction can be enabled to support communication between the MLI transmitter and MLI receiver without sending address offset information in the frames. This feature reduces the required bandwidth for MLI communication. Both of the communication partners, the MLI transmitter and the receiver, are able to detect regular offset differences of consecutive window accesses to the same window. The address prediction mechanism operates independently for each Pipe, so different prediction values can be handled in parallel for the different Pipes.

#### Local Controller

If the address prediction mechanism is enabled (MLI\_TCR.NO = 0), the MLI transmitter compares the offset of each Transfer Window read or write access with the offset of the previous access to the same Transfer Window (stored in MLI\_TPxAOFR.AOFF). The result of this comparison is stored in two's complement representation in MLI\_TPxSTATR.AP (limited to 9 bits, otherwise prediction is not possible). Between the accesses to a specific window, other windows can be accessed without disturbing the prediction.

If the offset differences in at least two accesses are identical to the same Transfer Window, an address prediction is possible (flag MLI\_TPxSTATR.OP is set) and optimized frames can be sent to the receiver in the Remote Controller for this Pipe. If the offset difference of the next access to the same Transfer Window does not match the calculated value in MLI\_TPxSTATR.AP, flag MLI\_TPxSTATR.OP is cleared and address prediction is not possible. In this case, a Normal Frame for writing or reading (Write Offset and Data Frame or Discrete Read Frame) is started.

### Remote Controller

The MLI receiver operates with the same address prediction as the MLI transmitter. This means that after receiving at least two consecutive Write Offset and Data Frames and/ or Discrete Read Frames that include address information, the MLI receiver is able to follow the address prediction used by the MLI transmitter.

Each received offset is compared in the MLI receiver with the offset of the previously received frame of the same Pipe. The result of this comparison is stored in two's



complement representation in MLI\_RPxSTATR.AP (limited 9 bits).

If an optimized frame is received by the MLI receiver, it calculates the next address by adding the value stored in MLI\_RPxSTATR.AP to the contents of the receiver address register MLI\_RADRR.

In case of a Write Offset and Data Frame or a Discrete Read Frame, the receiver address registers **MLI\_RADRR** and MLI\_RPxBAR are always updated with an address. This address is calculated by replacing the offset bit positions in MLI\_RPxBAR with the received offset value. In this case, the address delta value stored in MLI\_RPxSTATR.AP is not taken into account. The programmed size of the Remote Window and the number of offset bits are given by MLI\_RPxSTATR.BS. The non-offset bit positions in register MLI\_RPxBAR are kept constant, whereas the offset bit positions are replaced.

## 4.2.2.4 Automatic Data Mode

The MLI module supports automatic data transfer for read or write frames in the Remote Controller. The Automatic Data Mode in the Remote Controller can be enabled either via setting bit MLI\_RCR.MOD or by a Command Frame sent by the Local Controller. The Automatic Data Mode in the Remote Controller can be disabled by clearing bit MLI\_RCR.MOD.

If the Automatic Data Mode is disabled, the DMA has to execute the requested data transfers.

Note: For the CIC751 the Automatic Data Mode should also be used.

## 4.2.2.5 Transmit Priority

In the case that several requests for frame transmission are pending at the same time in the MLI transmitter of the Local Controller, the following priority scheme is applied, starting with the highest priority:

- Answer Frame
- Software driven Command Frames (CCV0 before CCV1 before CCV2 before CCV3)
- Read or Write Frames (DV0 before DV1 before DV2 before DV3)
- Base Address Copy Frame (BAV0 before BAV1 before BAV2 before BAV3)



## 4.2.3 MLI Interface Control

Each of the MLI transmitter and MLI receiver communicate with other MLI receivers and MLI transmitters via a four-line serial connection. Each input/output signal used for MLI communication between a transmitter and a receiver can be disabled and inverted in its polarity. The control is achieved via register MLI\_OICR.



## 4.2.4 MLI Request Generation

MLI Request generation is based on the interrupt event cases that can be created by the different interrupt sources.

Each interrupt source is provided with a status flag and an enable bit with software clear capability. Several interrupt sources can be combined into one MLI Request using a common interrupt node pointer. An interrupt event, generated by an interrupt source, is always stored in an interrupt status flag that is located in the interrupt status registers **MLI\_TISR** (for transmitter interrupts) or **MLI\_RISR** (for receiver interrupts). All interrupt event flags can be cleared individually by write actions to bits located in the interrupt enable registers **MLI\_TIER** (for transmitter interrupts) or **MLI\_RISR** (for receiver interrupts). These two registers also contain the enable control bits that allow each interrupt source to be enabled/disabled individually. Some interrupt events are combined to one common interrupt. Each interrupt is connected to exactly one of the four MLI interrupt node pointer.

One additional register, the Global Interrupt Set Register MLI\_GINTR, allows each MLI Request to be activated separately without setting the request flags of the interrupt sources. This feature is sometimes helpful for software test purposes.

#### Interrupt Registers

MLI interrupt sources are controlled by several registers (see **Table 4-7** and **Page 4-83**). The register name prefixes "T" and "R" indicate whether an interrupt register is assigned to the MLI transmitter or to the MLI receiver.

| Unit            | Registers with |                                      |              |  |  |  |  |
|-----------------|----------------|--------------------------------------|--------------|--|--|--|--|
|                 | Request Flags  | Enable Bits/<br>Req. Flag Clear Bits | Node Pointer |  |  |  |  |
| MLI Transmitter | MLI_TISR       | MLI_TIER                             | MLI_TINPR    |  |  |  |  |
| MLI Receiver    | MLI_RISR       | MLI_RIER                             | MLI_RINPR    |  |  |  |  |

### Table 4-7 Interrupt Registers

#### Interrupt Request Compressor

Interrupt control of the MLI uses an interrupt compressing scheme that allows great flexibility in interrupt processing. Eleven interrupts (six transmitter interrupts and four of the five receiver interrupts) are directed via a interrupt node pointer to one of the four MLI Request. One receiver interrupt, the interrupt Command Frame interrupt, has a special characteristic: its node pointer is controlled by the received CMD value directly.

## 4.2.5 Transmitter Interrupts

The MLI transmitter can generate the following interrupts:



# **CIC751**

## Micro Link Interface (MLI)

| Interrupt Events             | Interrupt                   | See       |  |
|------------------------------|-----------------------------|-----------|--|
| Parity Error                 | Parity/Time-out Error       | Page 4-43 |  |
| Time-out Error               |                             |           |  |
| Normal Frame Sent in Pipe 0  | Normal Frame Sent in Pipe 0 | Page 4-43 |  |
| Normal Frame Sent in Pipe 1  | Normal Frame Sent in Pipe 1 |           |  |
| Normal Frame Sent in Pipe 2  | Normal Frame Sent in Pipe 2 |           |  |
| Normal Frame Sent in Pipe 3  | Normal Frame Sent in Pipe 3 |           |  |
| Command Frame Sent in Pipe 0 | Command Frame Sent          | Page 4-43 |  |
| Command Frame Sent in Pipe 1 |                             |           |  |
| Command Frame Sent in Pipe 2 |                             |           |  |
| Command Frame Sent in Pipe 3 |                             |           |  |

## Table 4-8 MLI Transmitter Interrupts



# 4.2.5.1 Parity/Time-out Error Interrupt

A parity/time-out error interrupt is generated when a programmable maximum number of parity errors or a programmable maximum number of non-acknowledge errors has been reached. Both interrupt events have separate status/control bits but are concatenated to one common error interrupt.

# 4.2.5.2 Normal Frame Sent x Interrupt

A Normal Frame sent x (x = 0-3) interrupt is generated when a Normal Frame has been sent and correctly received in Pipe x.

## 4.2.5.3 Command Frame Sent Interrupt

A Command Frame sent interrupt is generated when the MLI transmitter has sent a Command Frame through Pipe x (x = 0-3) that has been correctly received. Separate status/control bits are assigned to each Pipe. All four Pipe related Command Frame sent interrupt events are concatenated to one common Command Frame sent interrupt.

## 4.2.6 Receiver Interrupts

The MLI receiver can generate the following interrupts:

| Interrupt Events                 | Interrupt               | See       |  |
|----------------------------------|-------------------------|-----------|--|
| Discarded Read Answer            | Discarded Read Answer   | Page 4-43 |  |
| Parity Error                     | Parity Error            | Page 4-44 |  |
| Normal Frame Correctly Received  | Normal Frame Received   | Page 4-44 |  |
| Move Engine Access Terminated    |                         |           |  |
| Interrupt Command Frame          | Interrupt Command Frame | Page 4-44 |  |
| Command Frame Received on Pipe 0 | Command Frame Received  | Page 4-44 |  |
| Command Frame Received on Pipe 1 |                         |           |  |
| Command Frame Received on Pipe 2 |                         |           |  |
| Command Frame Received on Pipe 3 |                         |           |  |
|                                  |                         |           |  |

## 4.2.6.1 Discarded Read Answer Interrupt

A discarded read answer received interrupt is generated when an Answer Frame has been received and the read pending flag **MLI\_TRSTATR**.RPx of its correspondent Pipe is 0. Although named "discarded", the received data is available in the receiver data register until it is overwritten by the next incoming data.



# 4.2.6.2 Parity Error Interrupt

A parity error interrupt is generated when a programmable maximum number of receiver parity errors is reached.

## 4.2.6.3 Normal Frame Received/Move Engine Terminated Interrupt

A Normal Frame received interrupt is generated when the MLI receiver has correctly received a Normal Frame (a read or a write frame, not a Command Frame or Copy Base Address Frame) correctly or when the MLI has terminated its read or write access. Both interrupt sources have separate status/control bits but are concatenated to one common frame receive interrupt.

## 4.2.6.4 Interrupt Command Frame Interrupt

An interrupt command frame interrupt is generated when a Command Frame is received correctly on Pipe 0 with a valid command code for remote interrupt generation  $(CMD = 0000_B \text{ to } 0011_B)$ . The received command code determines which of the service request output lines SR[3:0] should be activated.

## 4.2.6.5 Command Frame Received Interrupt

A command frame received interrupt is generated when the MLI receiver has correctly received a Command Frame through Pipe Number x (x = 0-3). Separate interrupt status/ control bits are assigned to each Pipe. All four Pipe related Command Frame received in Pipe x interrupt events are concatenated to one common Command Frame received interrupt.



# **CIC751**

### Micro Link Interface (MLI)

## 4.2.7 Baud Rate Generation

The MLI transmitter baud rate is given by  $f_{MLI}/2$ . The MLI shift clock output signal TCLK of the transmitter toggles with each clock cycle of  $f_{MLI}$  in order to obtain a 50% duty cycle (the 50% duty cycle can vary up to one clock cycle of  $f_{SYS}$  in Fractional Divider Mode). The MLI receiver automatically adapts to the incoming receive shift clock signal RCLK. The received baud rate is determined by the connected transmitter and has no direct relation to  $f_{SYS}$  except that it should not exceed  $f_{SYS}$ .

The frequency f<sub>MLI</sub> is generated by the fractional divider FDIV, programmable by register MLI\_FDR.



Figure 4-26 MLI Baud Rate Generation

#### **Normal Divider Mode**

In Normal Divider Mode (MLI\_FDR.DM = 01<sub>B</sub>) the fractional divider behaves like a reload counter (addition of +1) that generates a clock  $f_{MLI}$  on the transition from 3FF<sub>H</sub> to 000<sub>H</sub>. MLI\_FDR.RESULT represents the counter value and MLI\_FDR.STEP defines the reload value. In order to achieve  $f_{MLI} = f_{SYS}$ , MLI\_FDR.STEP must be programmed with 3FF<sub>H</sub>. The output frequency in Normal Divider Mode is defined according the following equation:

$$f_{MLI} = f_{SYS} \times \frac{1}{1024 - STEP}$$

(4.1)

#### **Fractional Divider Mode**

If the Fractional Divider Mode is selected (**MLI\_FDR**.DM =  $10_B$ ), the clock  $f_{MLI}$  is derived from the input clock  $f_{SYS}$  by division of a fraction of STEP/1024 for any value of STEP from 0 to 1023. In general, the Fractional Divider Mode allows to program the average clock frequency with a higher accuracy than in Normal Divider Mode. In Fractional Divider Mode, a clock pulse  $f_{MLI}$  is generated based on the result of the addition **MLI\_FDR**.RESULT + **MLI\_FDR**.STEP. The frequency  $f_{MLI}$  corresponds to the overflows



over  $3FF_H$ . Note that in Fractional Divider Mode, the clock  $f_{MLI}$  can have a maximum period jitter of one  $f_{SYS}$  clock period. This jitter is not accumulated over several cycles and does not exceed one cycle of  $f_{SYS}$ .

The frequency in Fractional Divider Mode is defined according to the following equation:

$$f_{MLI} = f_{SYS} \times \frac{STEP}{1024}$$

(4.2)

The baud rate of MLI transmissions equals  $f_{TCLK}$ , which is defined by the frequency of clock signal  $f_{MLI}$  divided by 2 to create the 50% duty cycle of the shift clock signal TCLK. The signal TCLK toggling with each period of  $f_{MLI}$ , a jitter due to fractional dividing is propagated to TCLK.

$$f_{TCLK} = \frac{f_{MLI}}{2}$$

(4.3)



### 4.3 MLI Kernel Registers

Table 4-10 lists all of the registers associated with the MLI.

All registers can be accessed with 8-bit, 16-bit or 32-bit write or read operations. Accesses to address locations inside the MLI address range not targeting the indicated registers are not allowed.

The base address of the MLI is 0000 0200. A register address is computed by adding the base address to the register offset address.

| Register<br>Short Name | Register Long Name                            | Offset<br>Address              | Description see |
|------------------------|-----------------------------------------------|--------------------------------|-----------------|
| MLI_FDR                | 000C <sub>H</sub>                             | Page 4-49                      |                 |
| MLI_TCR                | Transmitter Control Register                  | 0010 <sub>H</sub>              | Page 4-59       |
| MLI_TSTATR             | Transmitter Status Register                   | 0014 <sub>H</sub>              | Page 4-62       |
| MLI_TP0STATR           | Transmitter Pipe x Status Register            | 0018 <sub>H</sub> +<br>(x * 4) | Page 4-64       |
| MLI_TCMDR              | Transmitter Command Register                  | 0028 <sub>H</sub>              | Page 4-66       |
| MLI_TRSTATR            | Transmitter Receiver Status Register          | 002C <sub>H</sub>              | Page 4-68       |
| MLI_TP0AOFR            | Transmitter Pipe x Address Offset<br>Register | 0030 <sub>H</sub> +<br>(x * 4) | Page 4-70       |
| MLI_TP0DATAR           | Transmitter Pipe x Data Register              | 0040 <sub>H</sub> +<br>(x * 4) | Page 4-71       |
| MLI_TDRAR              | Transmitter Data Read Answer Register         | 0050 <sub>H</sub>              | Page 4-72       |
| MLI_TP0BAR             | Transmitter Pipe x Base Address<br>Register   | 0054 <sub>H</sub> +<br>(x * 4) | Page 4-73       |
| MLI_TCBAR              | Transmitter Copy Base Address<br>Register     | 0064 <sub>H</sub>              | Page 4-74       |
| MLI_RCR                | Receiver Control Register                     | 0068 <sub>H</sub>              | Page 4-75       |
| MLI_RP0BAR             | Receiver Pipe x Base Address Register         | 006C <sub>H</sub> +<br>(x * 4) | Page 4-78       |
| MLI_RP0STATR           | Receiver Pipe x Status Register               | 007C <sub>H</sub> +<br>(x * 4) | Page 4-74       |
| MLI_RADRR              | Receiver Address Register                     | 008C <sub>H</sub>              | Page 4-81       |
| MLI_RDATAR             | Receiver Data Register                        | 0090 <sub>H</sub>              | Page 4-82       |
| MLI_SCR                | Set Clear Register                            | 0094 <sub>H</sub>              | Page 4-51       |

#### Table 4-10 MLI Kernel Registers



# **CIC751**

### Micro Link Interface (MLI)

| Register<br>Short Name | Register Long Name                    | Offset<br>Address                                         | Description see |  |  |  |
|------------------------|---------------------------------------|-----------------------------------------------------------|-----------------|--|--|--|
| MLI_TIER               | 0098 <sub>H</sub>                     | Page 4-83                                                 |                 |  |  |  |
| MLI_TISR               | Transmitter Interrupt Status Register | Transmitter Interrupt Status Register 009C <sub>H</sub> F |                 |  |  |  |
| MLI_TINPR              | 00A0 <sub>H</sub>                     | Page 4-86                                                 |                 |  |  |  |
| MLI_RIER               | 00A4 <sub>H</sub>                     | Page 4-88                                                 |                 |  |  |  |
| MLI_RISR               | 00A8 <sub>H</sub>                     | Page 4-90                                                 |                 |  |  |  |
| MLI_RINPR              | 00AC <sub>H</sub>                     | Page 4-92                                                 |                 |  |  |  |
| MLI_GINTR              | 00B0 <sub>H</sub>                     | Page 4-53                                                 |                 |  |  |  |
| MLI_OICR               | 00B4 <sub>H</sub>                     | Page 4-54                                                 |                 |  |  |  |

#### Table 4-10 MLI Kernel Registers (cont'd)



### 4.3.1 General Registers

### 4.3.1.1 Fractional Divider Register

The fractional divider register allows programming of the frequency  $f_{MLI}$  to generate the baud rate of the 50% duty cycle transmitter shift clock TCLK.

# MLI\_FDR

| MLI Fractional Divider Register |    |    |    |    | (20 | C <sub>H</sub> ) |    |    | Rese | et Val | ue: 0 | 3FF 4 | 3FF <sub>H</sub> |    |          |
|---------------------------------|----|----|----|----|-----|------------------|----|----|------|--------|-------|-------|------------------|----|----------|
| 31                              | 30 | 29 | 28 | 27 | 26  | 25               | 24 | 23 | 22   | 21     | 20    | 19    | 18               | 17 | 16       |
| DIS<br>CLK                      |    | 1  | 0  | 1  | 1   |                  | 1  | 1  | 1    | RES    | ULT   | 1     | 1                | 1  |          |
| rwh                             |    |    | r  |    |     |                  |    |    |      | r      | h     |       |                  |    | <u> </u> |
| 15                              | 14 | 13 | 12 | 11 | 10  | 9                | 8  | 7  | 6    | 5      | 4     | 3     | 2                | 1  | 0        |
| D                               | М  |    |    | D  | 1   |                  | 1  | 1  | 1    | ST     | ΈP    | 1     | 1                | 1  |          |
| r١                              | N  | 1  |    | r  |     | 1                |    | 1  | 1    | r      | W     | 1     | 1                | 1  | 11       |

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|-------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| STEP  | [9:0]   | rw   | Step Value<br>In Normal Divider Mode, STEP contains the reload<br>value for RESULT.<br>In Fractional Divider Mode, this bit field defines the<br>10-bit value that is added to the RESULT with ear<br>input clock cycle.                                                                                                                                                                                              |  |  |
| DM    | [15:14] | rw   | <ul> <li>Divider Mode</li> <li>This bit field defines the functionality of the fractional divider block.</li> <li>00 Fractional divider is switched off; no output clock is generated. RESULT is not updated.</li> <li>01 Normal Divider Mode selected.</li> <li>10 Fractional Divider Mode selected.</li> <li>11 Fractional divider is switched off; no output clock is generated. RESULT is not updated.</li> </ul> |  |  |



| Field  | Bits               | Туре | Description                                                                                                                                                                                                                                                               |  |  |
|--------|--------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RESULT | [25:16]            | rh   | <b>Result Value</b><br>In Normal Divider Mode, RESULT acts as reload<br>counter (addition +1).<br>In Fractional Divider Mode, this bit field contains<br>result of the addition RESULT+STEP.<br>If DM is written with $01_B$ or $10_B$ , RESULT is load<br>with $3FF_H$ . |  |  |
| DISCLK | 31                 | rwh  | <ul> <li>Disable Clock</li> <li>Clock generation of f<sub>MLI</sub> is enabled according to the setting of bit field DM.</li> <li>Fractional divider is stopped. Signal f<sub>MLI</sub> becomes inactive. No change except when writing bit field DM.</li> </ul>          |  |  |
| 0      | [13:10]<br>[30:26] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                   |  |  |



### 4.3.1.2 Set Clear Register

The Set Clear Register MLI\_SCR is a write-only register that makes it possible to set or clear several status flags located in registers MLI\_TSTATR, MLI\_TRSTATR and MLI\_RCR under software control. Reading register MLI\_SCR always returns zero.

| MLI_SCR<br>MLI Set Clear Register |          |          |          | (294 <sub>H</sub> ) |          |          |          | Reset Value: 0000 0000 <sub>H</sub> |    |    |          |          |          |          |          |
|-----------------------------------|----------|----------|----------|---------------------|----------|----------|----------|-------------------------------------|----|----|----------|----------|----------|----------|----------|
| 31                                | 30       | 29       | 28       | 27                  | 26       | 25       | 24       | 23                                  | 22 | 21 | 20       | 19       | 18       | 17       | 16       |
|                                   |          | )        | 1        | C<br>NAE            | C<br>TPE | C<br>RPE | C<br>AV  |                                     | 1  | •  | 0        |          |          | C<br>BAV | C<br>MOD |
| L                                 | V        | V        |          | W                   | W        | W        | W        |                                     |    | ١  | N        |          |          | W        | W        |
| 15                                | 14       | 13       | 12       | 11                  | 10       | 9        | 8        | 7                                   | 6  | 5  | 4        | 3        | 2        | 1        | 0        |
| C<br>CV3                          | C<br>CV2 | C<br>CV1 | C<br>CV0 | C<br>DV3            | C<br>DV2 | C<br>DV1 | C<br>DV0 |                                     | 0  | 1  | S<br>MOD | S<br>CV3 | S<br>CV2 | S<br>CV1 | S<br>CV0 |
| w                                 | W        | W        | W        | W                   | W        | W        | W        |                                     | W  | 1  | W        | W        | W        | W        | W        |

| Field                           | Bits                    | Туре | Description                                                                                                                                                                         |
|---------------------------------|-------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCV0,<br>SCV1,<br>SCV2,<br>SCV3 | 0,<br>1,<br>2,<br>3     | w    | Set Command Valid0No effect1Bit MLI_TRSTATR.CVx is set                                                                                                                              |
| SMOD                            | 4                       | w    | Set MOD Flag0No effect1If CMOD = 0, MLI_RCR is set.If CMOD = 1, MLI_RCR.MOD is cleared.                                                                                             |
| CDV0,<br>CDV1,<br>CDV2,<br>CDV3 | 8,<br>9,<br>10,<br>11   | w    | Clear Data Valid x Flag         0       No effect         1       If SCVx = 0, bits MLI_TRSTATR.DVx and<br>MLI_TRSTATR.RPx are cleared.<br>If SCVx = 1, bit MLI_TRSTATR.DVx is set. |
| CCV0,<br>CCV1,<br>CCV2,<br>CCV3 | 12,<br>13,<br>14,<br>15 | w    | Clear Command Valid x Flag0No effect1Bit MLI_TRSTATR.CVx is cleared                                                                                                                 |
| CMOD                            | 16                      | w    | Clear MOD Flag         0       No effect         1       Bit MLI_RCR.MOD is cleared                                                                                                 |



| Field | Bits                          | Туре | Description                                                                                      |
|-------|-------------------------------|------|--------------------------------------------------------------------------------------------------|
| CBAV  | 17                            | W    | Clear BAV Flag         0       No effect         1       Bit MLI_TRSTATR.BAV is cleared          |
| CAV   | 24                            | W    | Clear AV Flag<br>0 No effect<br>1 Bit MLI_TRSTATR.AV is cleared                                  |
| CRPE  | 25                            | W    | Clear Receiver PE Flag         0       No effect         1       Bit MLI_RCR.PE is cleared       |
| CTPE  | 26                            | W    | Clear Transmitter PE Flag         0       No effect         1       Bit MLI_TSTATR.PE is cleared |
| CNAE  | 27                            | W    | Clear NAE Flag         0       No effect         1       Bit MLI_TSTATR.NAE is cleared           |
| 0     | [7:5],<br>[23:18],<br>[31:28] | W    | <b>Reserved</b><br>Read as 0; should be written with 0.                                          |



## 4.3.1.3 Global Interrupt Set Register

The Global Interrupt Set Register **MLI\_GINTR** is a write-only register (always reads 0) that allows each of the MLI Requests to be activated under software control.

| MLI_<br>MLI ( |    |    | rrupt | Set F | Regis  | ter | (2B | 0 <sub>H</sub> ) |    |    | Res | et Va      | lue: 0     | 0000       | 0000 <sub>H</sub> |
|---------------|----|----|-------|-------|--------|-----|-----|------------------|----|----|-----|------------|------------|------------|-------------------|
| 31            | 30 | 29 | 28    | 27    | 26     | 25  | 24  | 23               | 22 | 21 | 20  | 19         | 18         | 17         | 16                |
|               | 1  | 1  | 1     | 1     | 1      | 1   |     | )                | 1  | 1  | 1   | 1          | 1          | 1          | 1                 |
| L             |    | 1  | 1     |       | 1      | I   |     | r                | 1  |    |     |            | I          | 1          | <u> </u>          |
| 15            | 14 | 13 | 12    | 11    | 10     | 9   | 8   | 7                | 6  | 5  | 4   | 3          | 2          | 1          | 0                 |
|               | 1  | 1  | I     | 1     | ,<br>, | )   | I   | 1                | I  | 1  | 1   | SI<br>MLI3 | SI<br>MLI2 | SI<br>MLI1 | SI<br>MLIO        |
| L             |    | 1  | 1     |       | l      | r   | 1   | 1                | 1  | 1  | 1   | W          | W          | W          | W                 |

| Field               | Bits   | Туре | Description                                                                |
|---------------------|--------|------|----------------------------------------------------------------------------|
| SIMLIx<br>(x = 0-3) | x      | W    | Set MLI Service Request Output Line x0No action1MLI Request x is activated |
| 0                   | [31:4] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                    |



## 4.3.1.4 Output Input Control Register

The Output Input Control Register **MLI\_OICR** determines the functionality of the MLI transmitter and MLI receiver I/O control logic.

## MLI\_OICR

| MLIC | ILI Output Input Control Register |     |     |     | ster | (2B | 4 <sub>H</sub> ) |    |          | Res      | et Val | ue: 1    | 000 8 | 000 <sub>H</sub> |    |
|------|-----------------------------------|-----|-----|-----|------|-----|------------------|----|----------|----------|--------|----------|-------|------------------|----|
| 31   | 30                                | 29  | 28  | 27  | 26   | 25  | 24               | 23 | 22       | 21       | 20     | 19       | 18    | 17               | 16 |
| RDP  | RI                                | DS  | RCE | RCP | RC   | s   | RVP              | R  | VS       | (        | )      | RRP<br>B | 0     | RF               | RS |
| rw   | r                                 | W   | rw  | rw  | r١   | V   | rw               | r  | W        | r        | N      | rw       | rw    | r١               | N  |
| 15   | 14                                | 13  | 12  | 11  | 10   | 9   | 8                | 7  | 6        | 5        | 4      | 3        | 2     | 1                | 0  |
| RVE  | TDP                               | ТСР | TCE | TRE | TRP  | ТІ  | RS               | (  | <b>D</b> | TVP<br>B |        | 0        |       | TVE<br>B         | 0  |
| rw   | rw                                | rw  | rw  | rw  | rw   | r   | w                | r  | W        | rw       | 1      | rw       |       | rw               | rw |

| Field | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TVEB  | 1    | rw   | <ul> <li>Transmitter Valid Enable</li> <li>This bit enables the MLI transmitter output signal</li> <li>TVALID.</li> <li>TVALID is disabled and remains at passive level (as selected by TVPB)</li> <li>Transmitter output signal TVALID is enabled and driven</li> </ul>                                                                                                       |
| TVPB  | 5    | rw   | <ul> <li>Transmitter Valid Polarity This bit determines the polarity of the transmitter output signals TVALID. </li> <li>Non-inverted polarity for TVALID selected: TVALID is passive when driving a 0. TVALID is active when driving a 1. </li> <li>Inverted polarity for TVALID selected: TVALID is passive when driving a 1. TVALID is active when driving a 0. </li> </ul> |



| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                       |
|-------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRS   | [9:8] | rw   | Transmitter Ready SelectionThis bit field determines the input TREADY that is usedas MLI transmitter input. $00_B$ TREADY is not connected to the MLI $01_B$ TREADY is selected $10_B$ TREADY is not connected to the MLI $11_B$ TREADY is not connected to the MLI                                                                               |
| TRP   | 10    | rw   | <ul> <li>Transmitter Ready Polarity         This bit determines the polarity of TREADY.         0 Non-inverted polarity for TREADY selected:             TREADY is passive if 0. TREADY is active if 1.         1 Inverted polarity for TREADY selected:             TREADY is passive if 1. TREADY is passive if 1. TREADY if 0.     </li> </ul> |
| TRE   | 11    | rw   | <ul> <li>Transmitter Ready Enable</li> <li>This bit enables the MLI transmitter input signal</li> <li>TREADY.</li> <li>0 TREADY signal is disabled (always at 0 level)</li> <li>1 TREADY signal is enabled and driven by</li> <li>TREADY according to the settings of TRS and</li> <li>TRP</li> </ul>                                             |
| TCE   | 12    | rw   | <ul> <li>Transmitter Clock Enable</li> <li>This bit enables the module output signal TCLK.</li> <li>0 TCLK is disabled and remains at passive level (as selected by TCP)</li> <li>1 TCLK is enabled and driven according to the setting of TCP</li> </ul>                                                                                         |
| ТСР   | 13    | rw   | <ul> <li>Transmitter Clock Polarity This bit determines the polarity of the module output clock signal TCLK. </li> <li>Non-inverted polarity for TCLK selected: TCLK is driving a 0 when it is passive. </li> <li>Inverted polarity for TCLK selected: TCLK is driving a 1 when it is passive. </li> </ul>                                        |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|-------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| TDP   | 14      | rw   | <ul> <li>Transmitter Data Polarity</li> <li>This bit determines the polarity of the module output clock signal TDATA.</li> <li>0 TDATA is directly driven by MLI transmitter output signal TDATA (non-inverted)</li> <li>1 TDATA is directly driven by the inverted MLI transmitter output signal TDATA</li> </ul> |  |  |  |  |  |
| RVE   | 15      | rw   | Receiver Valid EnableThis bit enables the MLI receiver input signal RVALID.0RVALID signal is disabled (always at 0 level)1RVALID signal is enabled and driven by RVALID<br>according to the settings of RVS and RVPReceiver Ready Selector                                                                         |  |  |  |  |  |
| RRS   | [17:16] | rw   | Receiver Ready SelectorThis bit field determines whether RREADY is driven bythe MLI receiver or is tied to passive level according tothe setting of RRP.00RREADY is at passive level01RREADY is selected10RREADY is at passive level11RREADY is at passive level                                                   |  |  |  |  |  |
| RRPB  | 19      | rw   | Receiver Ready PolarityThis bit determines the polarity of the receiver outputRREADY.0Non-inverted polarity for RREADY selected:<br>RREADY is passive if 0. RREADY is active if 1.1Inverted polarity for RREADY selected:<br>RREADY is passive if 1. RREADY is active if 0.                                        |  |  |  |  |  |
| RVS   | [23:22] | rw   | Receiver Valid SelectorThis bit field determines whether the MLI is connectedto pin RVALID or not. $00_B$ RREADY is not connected to the MLI $01_B$ RREADY is connected to the MLI $10_B$ RREADY is not connected to the MLI $10_B$ RREADY is not connected to the MLI $11_B$ RREADY is not connected to the MLI   |  |  |  |  |  |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                           |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RVP   | 24      | rw   | Receiver Valid PolarityThis bit determines the polarity of RVALID.0Non-inverted polarity for RVALID selected:<br>RVALID is passive if 0. RVALID is active if 1.1Inverted polarity for RVALID selected:<br>RVALID is passive if 1. RVALID is active if 0.                                                                                              |
| RCS   | [26:25] | rw   | $\begin{array}{c} \textbf{Receiver Clock Selector} \\ This bit field determines whether the MLI is connected to pin RCLK or not. \\ 00_{B}  \text{RCLK is not connected to the MLI} \\ 01_{B}  \text{RCLK is connected to the MLI} \\ 10_{B}  \text{RCLK is not connected to the MLI} \\ 11_{B}  \text{RCLK is not connected to the MLI} \end{array}$ |
| RCP   | 27      | rw   | Receiver Clock PolarityThis bit determines the polarity of RCLK.0Non-inverted polarity for RCLK selected:<br>RCLK is at 0 level in passive state.1Inverted polarity for TCLK selected:<br>RCLK is at 1 level in passive state.                                                                                                                        |
| RCE   | 28      | rw   | Receiver Clock EnableThis bit enables the MLI receiver input clock RCLK.0RCLK signal is disabled (always at 0 level).1RCLK signal is enabled and driven by RCLK<br>according to the settings of RCS and RCP.                                                                                                                                          |
| RDS   | [30:29] | rw   | Receiver Data SelectorThis bit field determines whether the MLI is connectedto pin RDATA or not. $00_B$ RDATA is not connected to the MLI $01_B$ RDATA is connected to the MLI $10_B$ RDATA is not connected to the MLI $10_B$ RDATA is not connected to the MLI $11_B$ RDATA is not connected to the MLI                                             |
| RDP   | 31      | rw   | <ul> <li>Receiver Data Polarity</li> <li>This bit determines the polarity of RDATA.</li> <li>0 Non-inverted polarity for RDATA selected:<br/>RDATA is passive if 0. RDATA is active if 1.</li> <li>1 Inverted polarity for RDATA selected:<br/>RDATA is passive if 1. RDATA is active if 0.</li> </ul>                                                |



| Field | Bits                               | Туре | Description                           |
|-------|------------------------------------|------|---------------------------------------|
| 0     | [4:2],<br>[7:6],<br>18,<br>[21:20] | rw   | Reserved<br>Should be written with 0. |



## 4.3.2 MLI Transmitter Registers

#### 4.3.2.1 Transmitter Control Register

The Transmitter Control Register **MLI\_TCR** includes transmitter related control bits and bit fields that are used for parity/acknowledge, address optimization, TDATA idle polarity, retry, and transmitter enable/disable control.

#### MLI\_TCR

| MLI | Frans | mitte | r Cor | trol F | Regis | ter | (21 | 0 <sub>H</sub> ) |    |    | Res | et Va | lue: 0 | 000 0 | 0110 <sub>H</sub> |
|-----|-------|-------|-------|--------|-------|-----|-----|------------------|----|----|-----|-------|--------|-------|-------------------|
| 31  | 30    | 29    | 28    | 27     | 26    | 25  | 24  | 23               | 22 | 21 | 20  | 19    | 18     | 17    | 16                |
|     | 1     |       | 1     |        |       | 1   |     | D                |    | 1  |     |       | 1      |       |                   |
|     |       |       | 1     | 1      | 1     | I   | 1   | r                |    | 1  |     |       |        | 1     | I                 |
| 15  | 14    | 13    | 12    | 11     | 10    | 9   | 8   | 7                | 6  | 5  | 4   | 3     | 2      | 1     | 0                 |
| ТР  | NO    |       | M     | DP     | 1     | MN  | IAE |                  | MI | PE | 1   | 0     | RTY    | DNT   | MOD               |
| rw  | rw    |       | r     | w      | 1     | rv  | vh  | 1                | rv | vh | 1   | r     | rw     | rw    | rw                |

| Field | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOD   | 0    | rw   | Mode of OperationThis bit enables the MLI transmitter.0The MLI transmitter is disabled1The MLI transmitter is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DNT   | 1    | rw   | <ul> <li>Data in Not Transmission         This bit determines the level of the transmitter data line         TDATA when no transmission is in progress.         0 TDATA is at low level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         running         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is         1 TDATA is at high level if no transmission is&lt;</li></ul> |



| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTY   | 2     | rw   | <ul> <li>Retry This bit enables the retry mechanism for the Transfer Windows. This bit is only relevant for system bus architectures supporting a retry mechanism, otherwise it is ignored. 0 The retry mechanism is disabled. Any access while the transmitter is busy is discarded without additional action. 1 The retry mechanism is enabled. Any access while the transmitter is busy is discarded without additional action. 1 The retry mechanism is enabled. Any access while the transmitter is busy is acknowledged with a retry. In this case, the requesting bus master sends the requested access again until the request is accepted.</li></ul>                                                                                                                                                                                                                                            |
| MPE   | [7:4] | rwh  | <ul> <li>Maximum Parity Errors</li> <li>This bit field determines the maximum number of transmitter parity error conditions that can be still detected until a transmitter parity error event is generated (see Page 4-34). With each condition detected, MPE is decremented down to 0.</li> <li>0000 A parity error interrupt event can be generated if a transmitter parity error condition is detected.</li> <li>0001 A parity error interrupt event can be generated if a transmitter parity error condition is detected.</li> <li>0010 A parity error interrupt event can be generated if 2 transmitter parity error conditions are detected.</li> <li>0011 A parity error interrupt event can be generated if 3 transmitter parity error conditions are detected.</li> <li>1111 A parity error interrupt event can be generated if 15 transmitter parity error conditions are detected.</li> </ul> |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|-------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| MNAE  | [9:8]   | rwh  | <ul> <li>Maximum Non Acknowledge Errors</li> <li>This bit field determines the maximum number of consecutive non-acknowledge error conditions that can be still detected in the transmitter until a time-out interrupt is generated. MNAE is decremented down to 0 at each non-acknowledge error condition. When MNAE = 0 or becoming 0, a time-out interrupt event is generated. MNAE is automatically set to 11<sub>B</sub> after a successful frame transmission (see Page 4-37).</li> <li>O A time-out interrupt can be generated if a non-ack condition is detected.</li> <li>A time-out interrupt can be generated if a non-ack condition is detected.</li> <li>A time-out interrupt can be generated if 2 consecutive non-ack conditions are detected.</li> <li>A time-out interrupt can be generated if 3 consecutive non-ack conditions are detected.</li> </ul> |  |  |  |  |  |  |
| MDP   | [13:10] | rw   | Maximum Delay for Parity Error<br>This bit field determines a window for the transmitter in<br>number of TCLK clock periods in which a TREADY<br>low-to-high signal transition signal is considered as<br>"correctly received" condition.<br>0000 Zero clock periods selected (not useful)<br>0001 1 clock period selected<br><br>1110 14 clock periods selected<br>1111 15 clock periods selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| NO    | 14      | rw   | No Address PredictionThis bit field enables/disables the address predictionfor read or write frames (see Page 4-38).0Address prediction is enabled1Address prediction is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| ТР    | 15      | rw   | Type of ParityThis bit determines the type of parity used in frametransmissions. For correct data transfers, TP = 0 mustbe programmed. The value TP = 1 can be selected toforce parity errors to analyze the propagation delay(see Page 4-17).00Even parity is selected1Odd parity selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |



| Field | Bits    | Туре | Description                          |
|-------|---------|------|--------------------------------------|
| 0     | 3,      | r    | Reserved                             |
|       | [31:16] |      | Read as 0; should be written with 0. |

#### 4.3.2.2 Transmitter Status Register

The Transmitter Status Register **MLI\_TSTATR** contains transmitter specific status information.

#### MLI\_TSTATR

| MLI Transmitter Status Register |    |    |    |          |          |    | (21 | 4 <sub>H</sub> ) |    |    | Res | et Va | lue: 0 | 000 ( | 0000 <sub>H</sub> |
|---------------------------------|----|----|----|----------|----------|----|-----|------------------|----|----|-----|-------|--------|-------|-------------------|
| 31                              | 30 | 29 | 28 | 27       | 26       | 25 | 24  | 23               | 22 | 21 | 20  | 19    | 18     | 17    | 16                |
|                                 | T  | T  | I  | T        | I        | I  | Ċ   | )                | I  | Į  | T   | I     | , ,    |       |                   |
|                                 | I  | I  | I  | <u> </u> | <u> </u> | I  | ľ   | •                | I  | I  | I   | I     | II     |       | <u> </u>          |
| 15                              | 14 | 13 | 12 | 11       | 10       | 9  | 8   | 7                | 6  | 5  | 4   | 3     | 2      | 1     | 0                 |
|                                 |    |    | 0  |          |          |    | NAE | PE               | AI | PN |     |       | RDC    |       |                   |
| <u> </u>                        | 1  | 1  | r  | 1        | 1        | 1  | rh  | rh               | r  | h  | 1   | 1     | rh     |       | 1]                |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                   |
|-------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RDC   | [4:0] | rh   | <b>Ready Delay Counter</b><br>This bit field counts TCLK periods after the end of a<br>frame transmission. When the TVALID signal goes to<br>low level, RDC is cleared to zero and starts counting up<br>the TCLK clock periods until a TREADY high level is<br>detected.                                                     |
| APN   | [6:5] | rh   | Answer Pipe NumberThis bit field is written by the MLI receiver with the PipeNumber of a received read frame. APN is used by anAnswer Frame that is transmitted as response to theread frame.00Pipe 0 is used in Answer Frame01Pipe 1 is used in Answer Frame10Pipe 2 is used in Answer Frame11Pipe 3 is used in Answer Frame |



| Field | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|-------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| PE    | 7      | rh   | Parity Error Flag<br>This bit is set if a transmitter parity error condition is<br>detected by the transmitter after a frame transmission.<br>PE is cleared by hardware when a frame has been<br>transmitted without a parity error (see Page 4-34). Bit<br>PE can be cleared via bit MLI_SCR.CTPE.                |  |  |  |  |  |  |  |
| NAE   | 8      | rh   | Non Acknowledge Error Flag<br>This bit is set when a non-acknowledge error condition<br>is detected by the MLI transmitter after a frame<br>transmission (see Page 4-37). NAE is cleared by<br>hardware if a transmitted frame has been acknowledged<br>correctly. Bit NAE can be cleared via bit<br>MLI_SCR.CNAE. |  |  |  |  |  |  |  |
| 0     | [31:9] | r    | Reserved<br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |



## 4.3.2.3 Transmitter Pipe x Status Registers

The Transmitter Pipe x Status Registers MLI\_TPxSTATR contain Pipe-specific status information related to address optimization and prediction, data width for transmit data, and Remote Window size.

#### MLI\_TP0STATR

| MLI_<br>MLI 1<br>MLI_<br>MLI 1<br>MLI_ | MLI Transmitter Pipe 0 Status Register (218 <sub>H</sub> )Reset Value: 0000 0000 <sub>H</sub> MLI_TP1STATRMLI Transmitter Pipe 1 Status Register (21C <sub>H</sub> )Reset Value: 0000 0000 <sub>H</sub> MLI_TP2STATRMLI Transmitter Pipe 2 Status Register (220 <sub>H</sub> )Reset Value: 0000 0000 <sub>H</sub> MLI_TP3STATRMLI_TP3STATRReset Value: 0000 0000 <sub>H</sub> |          |          |          |          |          |    |          |          |          |          |          |          |          |    |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|----------|----|----------|----------|----------|----------|----------|----------|----------|----|
| 31                                     | 30                                                                                                                                                                                                                                                                                                                                                                            | 29       | 28       | 27       | 26       | 25       | 24 | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16 |
|                                        | I                                                                                                                                                                                                                                                                                                                                                                             | I        | I        | 1        | I        | I        | 0  | I        | I        | I        | I        | I        | I        | I        | OP |
|                                        | <u> </u>                                                                                                                                                                                                                                                                                                                                                                      | <u>I</u> | <u> </u> | <u> </u> | <u> </u> | <u>I</u> | r  | <u> </u> | <u> </u> | <u> </u> | <u>I</u> | <u> </u> | <u> </u> | <u> </u> | rh |
| 15                                     | 14                                                                                                                                                                                                                                                                                                                                                                            | 13       | 12       | 11       | 10       | 9        | 8  | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0  |
|                                        | I.                                                                                                                                                                                                                                                                                                                                                                            |          | I        | Α        | D        | DW BS    |    |          |          |          |          |          |          |          |    |
| <u> </u>                               | I                                                                                                                                                                                                                                                                                                                                                                             | I        | I        | r        | h        | I        | I  | I        | I        | r        | h        |          | r        | h        |    |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BS    | [3:0] | rh   | Size<br>This bit field indicates the coded size of the Pipe x<br>Remote Window in the Remote Controller. BS further<br>determines how many address offset bits are<br>transmitted in a Write Offset and Data Frame or in a<br>Discrete Read Frame. When register MLI_TPxBAR is<br>written for generation of a Copy Base Address Frame,<br>BS is updated by the Copy Base Address Frame (see<br>Page 4-19).<br>0000 1-bit offset address of Remote Window<br>0001 2-bit offset address of Remote Window<br>0010 3-bit offset address of Remote Window<br><br>1111 16-bit offset address of Remote Window |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| DW    | [5:4]   | rh   | Data WidthThis bit field indicates the data width that has beendetected for a read or write access to a Transfer Windowof Pipe x (see Page 4-22 and Page 4-26).008-bit data width detected0116-bit data width detected1032-bit data width detected11Reserved                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| AP    | [15:6]  | rh   | Address Prediction Factor<br>This bit field indicates the delta value (positive or<br>negative number) of offset address used by the MLI<br>transmitter for the next address prediction. AP is a<br>signed 9-bit number (10th bit is the sign bit) that is written<br>with each transmitter address prediction calculation (see<br>Page 4-17 and Page 4-38).                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| OP    | 16      | rh   | <ul> <li>Use Optimized Frame</li> <li>When address optimization is enabled with</li> <li>MLI_TCR.NO = 0, this bit indicates if address prediction is possible in the transmitter. OP is written with each transmitter address prediction calculation (see</li> <li>Page 4-17 and Page 4-38).</li> <li>0 No address prediction is possible. A Write Offset and Data Frame or a Discrete Read Frame are used for transmission.</li> <li>1 Address prediction is possible. An Optimized Write Frame or an Optimized Read Frame are used for transmission.</li> </ul> |  |  |  |  |  |  |  |
| 0     | [31:17] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |



## 4.3.2.4 Transmitter Command Register

The Transmitter Command Register MLI\_TCMDR contains the command codes that are used during Command Frame transmission (see Page 4-30). Each time one of the MLI\_TCMDR.CMDPx bit fields is written, a Command Frame transmission is triggered. Therefore, only byte write accesses may be used when writing to MLI\_TCMDR (only one Command Frame can be sent at a time).

## MLI\_TCMDR

| MLI 1 | MLI Transmitter Command Register (228 <sub>H</sub> ) Reset Value: 0000 0000 <sub>H</sub> |          |    |       |    |    |    |    |                                       |          |    |    |    |     |    |
|-------|------------------------------------------------------------------------------------------|----------|----|-------|----|----|----|----|---------------------------------------|----------|----|----|----|-----|----|
| 31    | 30                                                                                       | 29       | 28 | 27    | 26 | 25 | 24 | 23 | 22                                    | 21       | 20 | 19 | 18 | 17  | 16 |
|       | 0 CMDP3                                                                                  |          |    |       |    |    |    |    | 0 CMDP2                               |          |    |    |    | DP2 |    |
|       |                                                                                          | r        |    | 1     | r١ | N  | 1  |    | r                                     |          |    |    | r  | W   | 11 |
| 15    | 14                                                                                       | 13       | 12 | 11    | 10 | 9  | 8  | 7  | 6                                     | 5        | 4  | 3  | 2  | 1   | 0  |
|       | ,<br>,                                                                                   | <b>)</b> | 1  | CMDP1 |    |    |    |    | (                                     | <b>)</b> |    |    | СМ | DP0 | 1  |
| L     |                                                                                          | r        | 1  | 1     | r  | N  | 1  | 1  | ۱ــــــــــــــــــــــــــــــــــــ | r        | 1  | 1  | n  | w   |    |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                           |
|-------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMDP0 | [3:0] | rw   | Command Code for Pipe 0<br>This bit field contains the command code related to<br>Pipe 0. The Pipe 0 command codes allow an activation<br>(pulse) of one of the MLI Requests in the Remote<br>Controller.<br>0001 Activate MLI Request 0<br>0010 Activate MLI Request 1<br>0011 Activate MLI Request 2<br>0100 Activate MLI Request 3 |
|       |       |      | else no action                                                                                                                                                                                                                                                                                                                        |



| Field | Bits                                    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|-------|-----------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| CMDP1 | [11:8]                                  | rw   | Command Code for Pipe 1<br>This bit field contains the command code related to<br>Pipe 1. The Pipe 1 command codes allow to adjust the<br>receiver delay for the parity error condition (see<br>MLI_RCR.DPE) in the MLI receiver of the Remote<br>Controller.<br>0000 Set MLI_RCR.DPE = 0000 <sub>B</sub><br>0001 Set MLI_RCR.DPE = 0001 <sub>B</sub><br><br>1111 Set MLI_RCR.DPE = 1111 <sub>B</sub>                                                                                                     |  |  |  |  |  |  |
| CMDP2 | [19:16]                                 | rw   | Command Code for Pipe 2<br>This bit field contains the command code related to<br>Pipe 2. The Pipe 2 command codes allow to control the<br>MLI receiver in the Remote Controller.<br>0001 Select Automatic Data Mode<br>(set MLI_RCR.MOD = 1)<br>0010 Automatic Data Mode is disabled<br>(set MLI_RCR.MOD = 0)<br>0100 Clear bit MLI_TRSTATR.RP0<br>0101 Clear bit MLI_TRSTATR.RP1<br>0110 Clear bit MLI_TRSTATR.RP2<br>0111 Clear bit MLI_TRSTATR.RP3<br>1111 Activate MLI break event<br>else No action |  |  |  |  |  |  |
| CMDP3 | [27:24]                                 | rw   | <b>Command Code for Pipe 3</b><br>This bit field contains the command code related to<br>Pipe 3. The command codes for Pipe 3 are free<br>programmable.                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| 0     | [7:4],<br>[15:12]<br>[23:20]<br>[31:28] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |



## 4.3.2.5 Transmitter-Receiver Status Register

The Transmitter-Receiver Status Register **MLI\_TRSTATR** contains read-only flags that indicate the status of MLI operations.

## MLI\_TRSTATR

MLI Transmitter-Receiver Status Register (22C<sub>H</sub>) Re

Reset Value: 0000 0000<sub>H</sub>

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18       | 17  | 16  |
|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|----------|-----|-----|
|    | 0  |    |    |    |    |    | N  | RP3 | RP2 | RP1 | RP0 | DV3 | DV2      | DV1 | DV0 |
|    | r  |    |    |    |    |    | า  | rh  | rh  | rh  | rh  | rh  | rh       | rh  | rh  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2        | 1   | 0   |
|    | 0  |    |    |    |    |    | AV | CV3 | CV2 | CV1 | CV0 |     |          | D   | T   |
|    | r  |    |    |    |    | rh | rh | rh  | rh  | rh  | rh  |     | <u> </u> | r   | 1   |

| Field                       | Bits                    | Туре | Description                                                                                                                                                                                                                                                                                           |
|-----------------------------|-------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CV0,<br>CV1,<br>CV2,<br>CV3 | 4,<br>5,<br>6,<br>7     | rh   | <b>Command Valid</b><br>Bit is set when a MLI_TCMDR.CMDPx bit field is<br>written. It is cleared when the Command Frame has<br>been correctly transmitted. CVx can be set or cleared<br>via bits MLI_SCR.SCVx or MLI_SCR.CCVx.                                                                        |
| AV                          | 8                       | rh   | Answer Valid<br>Bit is set when the MLI_TDRAR register in the MLI<br>transmitter (in the Remote Controller) is written. AV is<br>cleared when the Answer Frame has been correctly<br>sent. AV can be cleared via bit MLI_SCR.CAV.                                                                     |
| BAV                         | 9                       | rh   | Base Address Valid<br>Bit is set when the MLI_TCBAR register in the MLI<br>transmitter is written. BAV is cleared when the Copy<br>Base Address Frame has been correctly sent. BAV can<br>be cleared via bit MLI_SCR.CBAV.                                                                            |
| DV0,<br>DV1,<br>DV2,<br>DV3 | 16,<br>17,<br>18,<br>19 | rh   | Data Valid<br>Bit is set when the MLI_TPODATAR and/or the<br>MLI_TPOAOFR registers of the MLI transmitter are<br>updated after an access to a Transfer Window of Pipe<br>x. DVx is cleared again when the read or write frame<br>has been correctly sent. DVx can be cleared via bit<br>MLI_SCR.CDVx. |



# **CIC751**

| Field                       | Bits                          | Туре | Description                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|-------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RP0,<br>RP1,<br>RP2,<br>RP3 | 20,<br>21,<br>22,<br>23       | rh   | <b>Read Pending</b><br>Bit is set when the MLI_TP0AOFR register of the MLI<br>transmitter is updated after a read access to a Transfer<br>Window of Pipe x. RPx is cleared when the MLI<br>receiver in the Local Controller receives an Answer<br>Frame for Pipe x from the Remote Controller. RPx can<br>be cleared via bit MLI_SCR.CDVx.     |
| PN                          | [25:24]                       | rh   | Pipe NumberThis bit field indicates the Pipe Number x of the baseaddress that has been written into registerMLI_TPxBAR.00Register MLI_TP0BAR has been written last01Register MLI_TP1BAR has been written last01Register MLI_TP2BAR has been written last01Register MLI_TP2BAR has been written last01Register MLI_TP3BAR has been written last |
| 0                           | [3:0],<br>[15:10],<br>[31:26] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                        |



## 4.3.2.6 Transmitter Pipe x Address Offset Register

The Transmitter Pipe x Address Offset Register MLI\_TPxAOFR (x = 0-3) is a read-only register that stores the offset address that has been used by the last read or write access to a Transfer Window of Pipe x.

#### MLI\_TP0AOFR

|               | rans  | mitte | r Pipe | e 0 A | ddres | s Off | set R | eg. (2 | 230 <sub>H</sub> ) |    | Res | et Va | lue: 0 | 0000 ( | 0000 <sub>H</sub>     |
|---------------|-------|-------|--------|-------|-------|-------|-------|--------|--------------------|----|-----|-------|--------|--------|-----------------------|
| MLI_<br>MLI T |       |       | r Pipe | e 1 A | ddres | s Off | set R | eg. (2 | 234 <sub>H</sub> ) |    | Res | et Va | lue: 0 | 0000 ( | 0000 <sub>H</sub>     |
| MLI_<br>MLI T |       |       | r Pipe | e 2 A | ddres | s Off | set R | eq. (2 | 238 <sub>1</sub> ) |    | Res | et Va | lue: 0 | 0000 ( | )000 <sub>н</sub>     |
| MLI_          | TP3A  | OFR   | -      |       | ddres |       |       | • •    |                    |    |     |       |        |        | <br>0000 <sub>н</sub> |
|               | 10115 | mille |        | = 3 A | uures | 5 011 | Sel R | ey. (4 | -30H)              |    | res | elva  | iue. u |        | HOOOH                 |
| 31            | 30    | 29    | 28     | 27    | 26    | 25    | 24    | 23     | 22                 | 21 | 20  | 19    | 18     | 17     | 16                    |
|               | I     | Ι     | I      | Ι     | Ι     | I     | •     | 0      | Ι                  | I  | Ι   | Ι     | Ι      | Ι      |                       |
|               |       |       |        |       |       |       |       | r      |                    |    |     |       |        |        |                       |
| 15            | 14    | 13    | 12     | 11    | 10    | 9     | 8     | 7      | 6                  | 5  | 4   | 3     | 2      | 1      | 0                     |
|               | 1     | 1     | I      | 1     | 1     | I     |       | OFF    | 1                  | 1  | 1   | 1     | 1      | 1      |                       |

rh

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                             |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AOFF  | [15:0]  | rh   | Address Offset<br>Whenever a location within a Transfer Window is<br>accessed (read or written) AOFF is loaded with the<br>lowest 16 address bits of the access. Also in the case<br>of a small Transfer Window access, all AOFF bits are<br>loaded, but AOFF[15:13] are not taken into account for<br>further actions. |
| 0     | [31:16] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                 |



## 4.3.2.7 Transmitter Pipe x Data Register

The Transmitter Pipe x Data Register MLI\_TPxDATAR (x = 0-3) is a read-only register that stores the data that has been written during the last write access to a Transfer Window of Pipe x.

#### MLI\_TP0DATAR

| MLI 1<br>MLI_<br>MLI 1<br>MLI_<br>MLI_<br>MLI 1 | TP1D<br>Frans<br>TP2D<br>Frans<br>TP3D | mitte<br>ATAI<br>mitte<br>ATAI<br>mitte<br>ATAI | r Pipo<br>R<br>r Pipo<br>R<br>r Pipo<br>R | e 0 Da<br>e 1 Da<br>e 2 Da<br>e 3 Da | ata Ro<br>ata Ro | egiste<br>egiste | er (24<br>er (24 | .4 <sub>H</sub> )<br>.8 <sub>H</sub> ) |    |    | Res<br>Res | et Va<br>et Va | lue: 0<br>lue: 0 | 0000 (<br>0000 ( | 0000 <sub>H</sub><br>0000 <sub>H</sub><br>0000 <sub>H</sub> |
|-------------------------------------------------|----------------------------------------|-------------------------------------------------|-------------------------------------------|--------------------------------------|------------------|------------------|------------------|----------------------------------------|----|----|------------|----------------|------------------|------------------|-------------------------------------------------------------|
| 31                                              | 30                                     | 29                                              | 28                                        | 27                                   | 26               | 25               | 24               | <b>2</b> 3                             | 22 | 21 | 20         | 19             | 18               | 17               | 16                                                          |
|                                                 |                                        |                                                 |                                           |                                      |                  |                  | DATA             | [31:16                                 | ]  |    |            |                |                  |                  |                                                             |
|                                                 | 1                                      | 1                                               |                                           |                                      | 1                | I                | r                | h                                      | 1  | 1  |            |                | I                | I                | 1                                                           |
| 15                                              | 14                                     | 13                                              | 12                                        | 11                                   | 10               | 9                | 8                | 7                                      | 6  | 5  | 4          | 3              | 2                | 1                | 0                                                           |
|                                                 |                                        |                                                 |                                           |                                      |                  |                  | DATA             | [15:0]                                 |    |    |            |                |                  |                  |                                                             |
|                                                 | 1                                      | 1                                               | 1                                         | 1                                    | 1                | 1                | r                | h                                      | 1  | 1  | 1          |                | 1                | 1                | ]                                                           |

| Field | Bits   | Туре | Description                                                                                                      |
|-------|--------|------|------------------------------------------------------------------------------------------------------------------|
| DATA  | [31:0] | rh   | <b>Data</b><br>Whenever a location within a Transfer Window is written,<br>the data is loaded in this bit field. |



## 4.3.2.8 Transmitter Data Read Answer Register

The Transmitter Data Read Answer Register **MLI\_TDRAR** contains the read data for the transmission of an Answer Frame.

#### MLI\_TDRAR

| MLIT | Frans | mitte | r Data | a Rea | d An | swer | Regi | ster ( | 250 <sub>H</sub> ) |    | Res | et Va | lue: 0 | 000 ( | 0000 <sub>H</sub> |
|------|-------|-------|--------|-------|------|------|------|--------|--------------------|----|-----|-------|--------|-------|-------------------|
| 31   | 30    | 29    | 28     | 27    | 26   | 25   | 24   | 23     | 22                 | 21 | 20  | 19    | 18     | 17    | 16                |
|      |       |       |        |       |      | '    | DATA | [31:16 | ]                  |    |     |       |        |       |                   |
|      |       |       |        |       |      |      | rv   | vh     |                    |    |     |       |        |       | <u> </u> ]        |
| 15   | 14    | 13    | 12     | 11    | 10   | 9    | 8    | 7      | 6                  | 5  | 4   | 3     | 2      | 1     | 0                 |
|      |       |       |        |       |      |      | DATA | [15:0] |                    | 1  |     |       | 1      | 1     |                   |
| L    | 1     | 1     | 1      | 1     | 1    | 1    | rv   | vh     | 1                  | 1  | 1   | 1     | 1      | 1     |                   |

| Field | Bits   | Туре | Description                                                                                                                                                                                                                          |
|-------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA  | [31:0] | rwh  | <b>Data</b><br>This bit field is loaded with data that is read from the<br>address requested by a read frame. An update of this bit<br>field triggers the start of an Answer Frame with DATA<br>used as content of the Answer Frame. |



## 4.3.2.9 Transmitter Pipe x Base Address Register

The write-only Transmitter Pipe x Base Address Register MLI\_TPxBAR (x = 0-3) represents the 28-bit Pipe x Remote Window base address that is transmitted to the Remote Controller via a Copy Base Address Frame.

#### MLI\_TP0BAR

| MLI_<br>MLI 1<br>MLI_<br>MLI 1<br>MLI_ | TP1B<br>Frans<br>TP2B<br>Frans<br>TP3B | AR<br>mitte<br>AR<br>mitte<br>AR | r Pipo<br>r Pipo | e x Ba<br>e x Ba | ase A<br>ase A<br>ase A<br>ase A | ddre<br>ddre | ss Re<br>ss Re | egiste<br>egiste | r (258<br>r (250 | <br>3 <sub>H</sub> )<br>С <sub>Н</sub> ) | Res<br>Res | et Va<br>et Va | lue: 0<br>lue: 0 | 0000 (<br>0000 ( | 0000 <sub>H</sub><br>0000 <sub>H</sub><br>0000 <sub>H</sub> |
|----------------------------------------|----------------------------------------|----------------------------------|------------------|------------------|----------------------------------|--------------|----------------|------------------|------------------|------------------------------------------|------------|----------------|------------------|------------------|-------------------------------------------------------------|
| 31                                     | 30                                     | 29                               | 28               | 27               | 26                               | 25           | 24             | 23               | 22               | 21                                       | 20         | 19             | 18               | 17               | 16                                                          |
|                                        |                                        |                                  |                  |                  |                                  | 1            | ADDR           | [31:16           | 5]               |                                          |            |                |                  |                  |                                                             |
|                                        | 1                                      | 1                                | 1                | 1                |                                  | <u> </u>     | \<br>\         | N                | 1                | <u> </u>                                 | 1          | 1              | <u> </u>         | <u> </u>         | <u> </u>                                                    |
| 15                                     | 14                                     | 13                               | 12               | 11               | 10                               | 9            | 8              | 7                | 6                | 5                                        | 4          | 3              | 2                | 1                | 0                                                           |
|                                        |                                        |                                  |                  |                  | ADDR                             | [15:4]       | ]              |                  |                  |                                          |            |                | В                | S                |                                                             |
|                                        | 1                                      | 1                                | 1                | 1                | v                                | V            | 1              | 1                | 1                | 1                                        | 1          |                | v                | V                |                                                             |

| Field | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BS    | [3:0]  | W    | Size<br>This bit field determines the coded size of the Pipe x<br>Remote Window in the Remote Controller. When writing<br>MLI_TPOBAR, BS is copied into bit field<br>MLI_TPOSTATR.BS.<br>0000 1-bit offset address of Remote Window<br>0010 2-bit offset address of Remote Window<br>0010 3-bit offset address of Remote Window<br><br>1111 16-bit offset address of Remote Window |
| ADDR  | [31:4] | w    | Address<br>This bit field determines the most significant 28 bits of<br>the Pipe x Remote Window base address. When writing<br>MLI_TP0BAR, ADDR is copied into bit field<br>MLI_TCBAR.ADDR[31:4].                                                                                                                                                                                  |



## 4.3.2.10 Transmitter Copy Base Address Register

The Transmitter Copy Base Address Register **MLI\_TCBAR** contains the 28-bit Pipe x Remote Window base address of the latest write access to **MLI\_TP0BAR**.ADDR.

| MLI_<br>MLI 1 |    |    | r Cop | oy Ba | se Ad | Idres  | s Reg      | gister | (64 <sub>H</sub> ) | )  | Res | et Va | lue: 0 | 0000 (   | 0000 <sub>H</sub> |
|---------------|----|----|-------|-------|-------|--------|------------|--------|--------------------|----|-----|-------|--------|----------|-------------------|
| 31            | 30 | 29 | 28    | 27    | 26    | 25     | 24         | 23     | 22                 | 21 | 20  | 19    | 18     | 17       | 16                |
|               | 1  | 1  | 1     | 1     | 1     |        | ADDR       | [31:16 | 5]                 | 1  | 1   | 1     | 1      | 1        | 1                 |
|               | 1  | 1  | I     |       |       | I      | r          | h      | 1                  | I  |     | 1     | 1      | 1        | I]                |
| 15            | 14 | 13 | 12    | 11    | 10    | 9      | 8          | 7      | 6                  | 5  | 4   | 3     | 2      | 1        | 0                 |
|               | 1  | 1  | 1     | 1     | ADDR  | [15:4] | ,<br> <br> | 1      | 1                  | 1  | 1   |       | •      | <b>D</b> |                   |
|               |    |    | 1     |       | r     | h      | 1          |        |                    | 1  | 1   |       |        | r        |                   |

| Field | Bits   | Туре | Description                                                                                                                                                                                                     |
|-------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDR  | [31:4] | rh   | Address<br>This bit field contains the 28 address bits written to<br>MLI_TP0BAR.ADDR. This value will be transferred to<br>the Remote Controller to define the base address of the<br>Remote Window for Pipe x. |
| 0     | [3:0]  | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                         |



#### 4.3.3 MLI Receiver Registers

#### 4.3.3.1 Receiver Control Register

The Receiver Control Register MLI\_RCR contains control and status bits/bit fields that are related to the MLI receiver operation.

# MLI\_RCR

| MLI | MLI Receiver Control Register |    |    |    |          |    |            | (268 <sub>H</sub> ) |    |     |     |    | Reset Value: 0000 0000 <sub>H</sub> |    |          |  |  |  |
|-----|-------------------------------|----|----|----|----------|----|------------|---------------------|----|-----|-----|----|-------------------------------------|----|----------|--|--|--|
| 31  | 30                            | 29 | 28 | 27 | 26       | 25 | 24         | 23                  | 22 | 21  | 20  | 19 | 18                                  | 17 | 16       |  |  |  |
|     |                               | 1  | 0  | 1  | 1        | I  | RCV<br>RST |                     | 0  | I   | BEN |    | MI                                  | PE |          |  |  |  |
| L   |                               |    | r  |    |          |    | rw         |                     | r  |     | rw  |    | rv                                  | vh | <u> </u> |  |  |  |
| 15  | 14                            | 13 | 12 | 11 | 10       | 9  | 8          | 7                   | 6  | 5   | 4   | 3  | 2                                   | 1  | 0        |  |  |  |
| R   | RPN PE TF                     |    | D  | w  | V MOD CM |    | СМІ        | CMDP3               |    | DPE |     |    |                                     |    |          |  |  |  |
| L   | rh rh rh r                    |    | h  | rh | rh       |    |            | 1                   | rh |     |     |    |                                     |    |          |  |  |  |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DPE   | [3:0] | rh   | Delay for Parity Error<br>DPE determines the number of RCLK clock periods that<br>the MLI receiver waits before the RREADY signal is<br>raised again when it has detected a parity error. When<br>a Pipe 1 Command Frame is received by the MLI<br>receiver, the command code is stored in this bit field<br>(see Page 4-30).<br>0000 Zero RCLK clock period delay is selected<br>0001 One RCLK clock period delay is selected<br>0010 Two RCLK clock periods delay is selected<br><br>1110 Fourteen RCLK clock periods delay is selected<br>1111 Fifteen RCLK clock periods delay is selected |
| CMDP3 | [7:4] | rh   | <b>Command From Pipe 3</b><br>When a Pipe 3 Command Frame is received by the MLI<br>receiver, the command code is stored in this bit field.<br>Pipe 3 commands are available for software use.                                                                                                                                                                                                                                                                                                                                                                                                 |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOD   | 8       | rh   | <ul> <li>Mode of Operation This bit determines the data transfer operation mode of the MLI receiver. Bit MOD can be set with the reception of a Pipe 2 Command Frame (see Page 4-67). It can be set or cleared via bits MLI_SCR.SMOD or  MLI_SCR.CMOD. 0 Automatic Data Mode is disabled. Data read/write operations from/to a Remote Window must be executed by the DMA. 1 Automatic Data Mode selected. Data read/write operations from/to a Remote Window are executed by the MLI.</li></ul> |
| DW    | [10:9]  | rh   | Data WidthThis bit field is updated by the MLI receiver whenevernew data is received in the MLI_RDATAR register. Itindicates the relevant data width.008-bit relevant data width in MLI_RDATAR0116-bit relevant data width in MLI_RDATAR1032-bit relevant data width in MLI_RDATAR11Reserved                                                                                                                                                                                                    |
| TF    | [12:11] | rh   | Type of FrameThis bit field determines the frame type that has mostrecently been received by the MLI receiver. It is updatedwhenever the MLI receiver updates MLI_RDATAR,MLI_RADRR, or MLI_RPxBAR. The most recentlyreceived frame was a:00Copy Base Address Frame01Discrete Read Frame or Optimized Read Frame10Write Offset and Data Frame or Optimized WriteFrame11Answer Frame                                                                                                              |
| PE    | 13      | rh   | <b>Parity Error</b><br>PE is set when a parity error is detected by the receiver<br>in a received frame (see <b>Page 4-34</b> ). PE is cleared by<br>hardware when a frame has been received without<br>parity error. PE can be cleared via bit <b>MLI_SCR</b> .CRPE.                                                                                                                                                                                                                           |
| RPN   | [15:14] | rh   | <b>Received Pipe Number</b><br>This bit field contains the Pipe Number that was<br>indicated by the Pipe Number bit field of the latest<br>received frame. It is updated by any received frame.                                                                                                                                                                                                                                                                                                 |



| Field  | Bits                | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|---------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MPE    | [19:16]             | rwh  | <ul> <li>Maximum Parity Errors</li> <li>This bit field indicates the number of receive parity error conditions after which a receiver parity error interrupt event will be generated. It is set to a desired value by software and it is decremented down to 0 automatically by the MLI each time it detects a receiver parity error condition. If a receiver parity error condition is detected and MPE becomes 0 or is already 0, a receiver parity error event is generated (see Page 4-34).</li> <li>0000 A receiver parity event is generated if a receiver error condition is detected</li> <li>0001 A receiver parity event is generated if a receiver error condition is detected</li> <li>0010 A receiver parity event is generated if two receiver error conditions are detected</li> <li></li> <li>1111 A receiver parity event is generated if 15 receiver error conditions are detected</li> </ul> |
| BEN    | 20                  | rw   | Break Out EnableWhen setting BEN = 1, the MLI receiver generates anMLI Break Event when a Pipe Command Frame withcommand code CMD = 1111 <sub>B</sub> is received.0MLI Break Event generation is disabled.1MLI Break Event is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RCVRST | 24                  | rw   | Receiver ResetThis bit forces the receiver to be reset in order to be ableto change MLI_OICR settings without affecting thereceiver registers.0The MLI receiver is in operating mode.1The MLI receiver is held in reset state and OICR<br>can be modified without unintentional actions in<br>the receiver.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0      | [23:21],<br>[31:25] | r    | Reserved<br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



## 4.3.3.2 Receiver Pipe x Base Address Register

The Receiver Pipe x Base Address Register MLI\_RPxBAR (x = 0-3) is a read-only register that contains the complete target address in the Remote Window of Pipe x.

| MLI_RP0BARReset Value: 0000 0000 <sub>H</sub> MLI_RP1BARReset Value: 0000 0000 <sub>H</sub> MLI_RP2BARReset Value: 0000 0000 <sub>H</sub> MLI_RP2BARReset Value: 0000 0000 <sub>H</sub> MLI_RP3BARReset Value: 0000 0000 <sub>H</sub> MLI_RP3BARReset Value: 0000 0000 <sub>H</sub> MLI_Receiver Pipe 3 Base Address Register (278 <sub>H</sub> )Reset Value: 0000 0000 <sub>H</sub> |    |    |    |    |    |        |      |                 |    |    |    |    |    |    |    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|--------|------|-----------------|----|----|----|----|----|----|----|
| 31                                                                                                                                                                                                                                                                                                                                                                                   | 30 | 29 | 28 | 27 | 26 | 25     | 24   | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|                                                                                                                                                                                                                                                                                                                                                                                      | 1  | 1  | 1  | 1  | 1  | ,<br>, | ADDR | [31:16          | 5] | I  | 1  | 1  | 1  | 1  | 1  |
| <u> </u>                                                                                                                                                                                                                                                                                                                                                                             | 4  |    |    | 1  | 1  | 1      | r    | h               | I  | 1  | 1  | 4  | 1  |    |    |
| 15                                                                                                                                                                                                                                                                                                                                                                                   | 14 | 13 | 12 | 11 | 10 | 9      | 8    | 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |        | ADDR | <b>R[15:0</b> ] | l  |    |    |    |    |    |    |
|                                                                                                                                                                                                                                                                                                                                                                                      | 1  | 1  | 1  | 1  | 1  | 1      | r    | h               | 1  | 1  | 1  | 1  | 1  | 1  |    |

| Field | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDR  | [31:0] | rh   | Address<br>ADDR indicates the complete target address for the Pipe<br>x Remote Window.<br>If a Pipe x Copy Base Address Frame is received,<br>ADDR[31:4] becomes loaded with the transmitted 28-bit<br>address and bits [3:0] are cleared.<br>If a write or read frame with m bits of address offset is<br>received, bits ADDR[31:m] are held constant and bits<br>ADDR[m-1:0] are replaced by the received offset.<br>If an optimized read or data frame is received, the<br>address prediction mechanism adds the predicted<br>address offset MLI_RPxSTATR.AP to ADDR and stores<br>the result in ADDR.<br>If an Answer Frame is received, ADDR is not changed. |



## 4.3.3.3 Receiver Pipe x Status Register

The Receiver Pipe x Status Register MLI\_RPxSTATR (x = 0.3) indicates the data width (8-, 16-, or 32-bit) of the last access to the Pipe x Remote Window and the address prediction factor that has been calculated for Pipe x in the receiver of the Remote Controller.

| MLI F<br>MLI_<br>MLI F<br>MLI_<br>MLI F<br>MLI F | RP1S<br>Recei<br>RP2S<br>Recei<br>RP3S | ver P<br>STATF<br>ver P<br>STATF<br>ver P<br>STATF | ipe 0<br>२<br>ipe 1<br>२<br>ipe 2<br>२ | Statu<br>Statu | ıs Re<br>ıs Re | gister<br>gister | · (28<br>· (28 | (27C <sub>H</sub> ) Reset Value: 0<br>(280 <sub>H</sub> ) Reset Value: 0<br>(284 <sub>H</sub> ) Reset Value: 0<br>(288 <sub>H</sub> ) Reset Value: 0 |    |    |    |    | 000 (<br>000 ( | 0000 <sub>H</sub> |    |
|--------------------------------------------------|----------------------------------------|----------------------------------------------------|----------------------------------------|----------------|----------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----------------|-------------------|----|
| 31                                               | 30                                     | 29                                                 | 28                                     | 27             | 26             | 25               | 24             | 23                                                                                                                                                   | 22 | 21 | 20 | 19 | 18             | 17                | 16 |
|                                                  | 1                                      | 1                                                  | 1                                      | 1              | 1              | 1                |                | <b>D</b>                                                                                                                                             | 1  | 1  | 1  | 1  | 1              | 1                 |    |
|                                                  |                                        |                                                    |                                        |                |                |                  |                | r                                                                                                                                                    |    |    |    |    |                |                   |    |
| 15                                               | 14                                     | 13                                                 | 12                                     | 11             | 10             | 9                | 8              | 7                                                                                                                                                    | 6  | 5  | 4  | 3  | 2              | 1                 | 0  |
|                                                  | 1                                      | 1                                                  | 1                                      | 1              | ۰ <b>P</b>     | 1                |                | 1                                                                                                                                                    | 1  |    | 0  |    | B              | S                 | 1  |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BS    | [3:0] | rh   | Size<br>This bit field indicates the size of Pipe x Remote Window<br>in the Remote Controller. It is updated by hardware<br>when a Copy Base Address Frame has been received<br>(see Page 4-19).<br>0000 1-bit offset address of Remote Window<br>0001 2-bit offset address of Remote Window<br>0010 3-bit offset address of Remote Window<br><br>1111 16-bit offset address of Remote Window |



| Field | Bits              | Туре | Description                                                                                                                                                                                                                                          |
|-------|-------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| АР    | [15:6]            | rh   | Address Prediction Factor<br>AP contains the address prediction factor that has been<br>calculated for Pipe x in the receiver of the Remote<br>Controller. It is a signed 9-bit number with the sign in its<br>most significant bit (see Page 4-38). |
| 0     | [5:4],<br>[31:16] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                              |



#### 4.3.3.4 Receiver Address Register

The Receiver Address Register **MLI\_RADRR** is a read-only register storing the complete address of the most recently (or currently) targeted Remote Window.

#### MLI\_RADRR

| MLIF | Recei       | ver A | ddres | ss Re | giste | r  | (28 | (28C <sub>H</sub> ) |    |    |    | Reset Value: 0000 0000 <sub>H</sub> |    |    |    |  |  |
|------|-------------|-------|-------|-------|-------|----|-----|---------------------|----|----|----|-------------------------------------|----|----|----|--|--|
| 31   | 30          | 29    | 28    | 27    | 26    | 25 | 24  | 23                  | 22 | 21 | 20 | 19                                  | 18 | 17 | 16 |  |  |
|      | ADDR[31:16] |       |       |       |       |    |     |                     |    |    |    |                                     |    |    |    |  |  |
|      | rh          |       |       |       |       |    |     |                     |    |    |    |                                     |    |    |    |  |  |
| 15   | 14          | 13    | 12    | 11    | 10    | 9  | 8   | 7                   | 6  | 5  | 4  | 3                                   | 2  | 1  | 0  |  |  |
|      | ADDR[15:0]  |       |       |       |       |    |     |                     |    |    |    |                                     |    |    |    |  |  |
|      |             |       |       |       |       |    | r   | h                   |    |    |    |                                     |    |    |    |  |  |

| Field | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDR  | [31:0] | rh   | Address<br>ADDR indicates the complete target address for the<br>most recently (or currently) targeted Remote Window<br>(Pipe x).<br>If a Copy Base Address Frame is received, ADDR is<br>unchanged.<br>If a write or read frame with m bits of address offset is<br>received, bits ADDR[31:m] replaced by the bits<br>MLI_RPOBAR.ADDR[31:m] and bits ADDR[m-1:0]<br>are replaced by the received offset.<br>If an optimized read or data frame is received, the<br>address prediction mechanism adds the predicted<br>address offset MLI_RPOSTATR.AP to<br>MLI_RPOBAR.ADDR and stores the result in ADDR.<br>If an Answer Frame is received, ADDR becomes<br>invalid. |



#### 4.3.3.5 Receiver Data Register

The Receiver Data Register **MLI\_RDATAR** is a read-only register that stores data received by a write frame or an Answer Frame.

## MLI\_RDATAR

| MLI Receiver Data Register |             |    |    |    |    |    | (290 <sub>H</sub> ) |    |    |    |    | Reset Value: 0000 0000 <sub>H</sub> |    |    |    |  |  |
|----------------------------|-------------|----|----|----|----|----|---------------------|----|----|----|----|-------------------------------------|----|----|----|--|--|
| 31                         | 30          | 29 | 28 | 27 | 26 | 25 | 24                  | 23 | 22 | 21 | 20 | 19                                  | 18 | 17 | 16 |  |  |
|                            | DATA[31:16] |    |    |    |    |    |                     |    |    |    |    |                                     |    |    |    |  |  |
|                            | rh          |    |    |    |    |    |                     |    |    |    |    |                                     |    |    |    |  |  |
| 15                         | 14          | 13 | 12 | 11 | 10 | 9  | 8                   | 7  | 6  | 5  | 4  | 3                                   | 2  | 1  | 0  |  |  |
|                            | DATA[15:0]  |    |    |    |    |    |                     |    |    |    |    |                                     |    |    |    |  |  |
|                            |             |    |    |    |    |    | r                   | h  |    |    |    |                                     |    |    |    |  |  |

| Field | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA  | [31:0] | rh   | Data<br>In the Remote Controller, DATA contains the data<br>received by a write frame or an Answer Frame. Bit<br>field MLI_RCR.DW determines the width of the<br>relevant data that is stored in MLI_RDATAR.<br>MLI_RCR.DW = 00:MLI_RDATAR[7:0] are relevant<br>(8-bit)<br>MLI_RCR.DW = 01:MLI_RDATAR[15:0] are relevant<br>(16-bit)<br>MLI_RCR.DW = 10:MLI_RDATAR[31:0] are relevant<br>(32-bit) |



## 4.3.4 Transmitter Interrupt Registers

#### 4.3.4.1 Transmitter Interrupt Enable Register

The Transmitter Interrupt Enable Register **MLI\_TIER** contains the interrupt enable bits and the interrupt request enable flag clear bits for all transmitter interrupt request events. The bits marked w are always read as 0.

# MLI\_TIER

| MLI | Frans | ansmitter Interrupt Enable Register (298 <sub>H</sub> ) Reset Value: 0000 0000 |          |    |    |          |          |            | 0000 <sub>H</sub> |            |            |            |            |            |            |
|-----|-------|--------------------------------------------------------------------------------|----------|----|----|----------|----------|------------|-------------------|------------|------------|------------|------------|------------|------------|
| 31  | 30    | 29                                                                             | 28       | 27 | 26 | 25       | 24       | 23         | 22                | 21         | 20         | 19         | 18         | 17         | 16         |
|     | 1     | (                                                                              | <b>)</b> | 1  | I  | TE<br>IR | PE<br>IR | CFS<br>IR3 | CFS<br>IR2        | CFS<br>IR1 | CFS<br>IR0 | NFS<br>IR3 | NFS<br>IR2 | NFS<br>IR1 | NFS<br>IR0 |
| L   |       |                                                                                | r        | 1  | 1  | W        | W        | W          | W                 | W          | W          | W          | W          | W          | W          |
| 15  | 14    | 13                                                                             | 12       | 11 | 10 | 9        | 8        | 7          | 6                 | 5          | 4          | 3          | 2          | 1          | 0          |
|     | 1     |                                                                                | <b>)</b> | 1  | 1  | TE<br>IE | PE<br>IE | CFS<br>IE3 | CFS<br>IE2        | CFS<br>IE1 | CFS<br>IE0 | NFS<br>IE3 | NFS<br>IE2 | NFS<br>IE1 | NFS<br>IE0 |
|     |       |                                                                                | r        |    |    | rw       | rw       | rw         | rw                | rw         | rw         | rw         | rw         | rw         | rw         |

| Field                                   | Bits                | Туре | Description                                                                                                                                                                                            |
|-----------------------------------------|---------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFSIE0,<br>NFSIE1,<br>NFSIE2,<br>NFSIE3 | 0,<br>1,<br>2,<br>3 | rw   | <ul> <li>Normal Frame Sent in Pipe x Interrupt Enable</li> <li>Normal Frame sent in Pipe x interrupt source is disabled</li> <li>Normal Frame sent in Pipe x interrupt source is enabled</li> </ul>    |
| CFSIE0,<br>CFSIE1,<br>CFSIE2,<br>CFSIE3 | 4,<br>5,<br>6,<br>7 | rw   | <ul> <li>Command Frame Sent in Pipe x Interrupt Enable</li> <li>Command Frame sent in Pipe x interrupt source is disabled</li> <li>Command Frame sent in Pipe x interrupt source is enabled</li> </ul> |
| PEIE                                    | 8                   | rw   | Parity Error Interrupt Enable0Parity error interrupt source is disabled1Parity error interrupt source is enabled                                                                                       |
| TEIE                                    | 9                   | rw   | Time-Out Error Interrupt Enable0Time-out error interrupt source is disabled1Time-out error interrupt source is enabled                                                                                 |



| Field   | Bits     | Туре | Description                             |
|---------|----------|------|-----------------------------------------|
|         | 16,      | w    | Normal Frame Sent in Pipe x Flag Clear  |
| NFSIR1, | 17,      |      | 0 No action                             |
| NFSIR2, | 18,      |      | 1 Clear MLI_TISR.NFSIx                  |
| NFSIR3  | 19       |      |                                         |
| CFSIR0, | 20,      | w    | Command Frame Sent in Pipe x Flag Clear |
| CFSIR1, | 21,      |      | 0 No action                             |
| CFSIR2, | 22,      |      | 1 Clear MLI_TISR.CFSIx                  |
| CFSIR3  | 23       |      |                                         |
| PEIR    | 24       | w    | Parity or Time Out Error Flag Clear     |
|         |          |      | 0 No action                             |
|         |          |      | 1 Clear MLI_TISR.PEIx                   |
| TEIR    | 25       | w    | Time Out Error Flag Clear               |
|         |          |      | 0 No action                             |
|         |          |      | 1 Clear MLI_TISR.TEIx                   |
| 0       | [15:10], | r    | Reserved                                |
|         | [31:26]  |      | Read as 0; should be written with 0.    |



## 4.3.4.2 Transmitter Interrupt Register

The Transmitter Interrupt Status Register **MLI\_TISR** contains all of the interrupt request flags of the MLI transmitter. These interrupt request flags can be cleared by software when writing the appropriate bits in the **MLI\_TIER** register.

| MLI_<br>MLI 1 |    | mitte | r Inte | rrupt | Statu | us Re   | giste   | r (290    | S <sub>H</sub> ) |           | Res       | et Va     | lue: 0    | 0000 0    | 000 <sub>H</sub> |
|---------------|----|-------|--------|-------|-------|---------|---------|-----------|------------------|-----------|-----------|-----------|-----------|-----------|------------------|
| 31            | 30 | 29    | 28     | 27    | 26    | 25      | 24      | 23        | 22               | 21        | 20        | 19        | 18        | 17        | 16               |
|               | 1  | 1     |        | 1     | 1     | 1       |         | D         | 1                | 1         |           | 1         | 1         | 1         |                  |
| <u> </u>      |    |       |        |       |       |         |         | r         |                  |           |           |           |           |           | <u> </u>         |
| 15            | 14 | 13    | 12     | 11    | 10    | 9       | 8       | 7         | 6                | 5         | 4         | 3         | 2         | 1         | 0                |
|               | 1  |       | )      | 1     | 1     | TE<br>I | PE<br>I | CFS<br>I3 | CFS<br>I2        | CFS<br>I1 | CFS<br>I0 | NFS<br>I3 | NFS<br>I2 | NFS<br>I1 | NFS<br>10        |
|               |    | l     | ſ      |       |       | rh      | rh      | rh        | rh               | rh        | rh        | rh        | rh        | rh        | rh               |

| Field                               | Bits                | Туре | Description                                                                                                                                                                                                                    |
|-------------------------------------|---------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFSI0,<br>NFSI1,<br>NFSI2,<br>NFSI3 | 0,<br>1,<br>2,<br>3 | rh   | Normal Frame Sent in Pipe x Flag<br>This flag becomes set if a write or read frame has been<br>correctly sent and acknowledged for Pipe x.<br>The service request output that is activated is defined by<br>MLI_TINPR.NFSIPx.  |
| CFSI0,<br>CFSI1,<br>CFSI2,<br>CFSI3 | 4,<br>5,<br>6,<br>7 | rh   | <b>Command Frame Sent in Pipe x Flag</b><br>This flag becomes set if a Command Frame has been<br>correctly sent and acknowledged for Pipe x.<br>The service request output that is activated is defined by<br>MLI_TINPR.CFSIP. |
| PEI                                 | 8                   | rh   | Parity Error Flag<br>This flag becomes set if a transmitter parity error<br>interrupt event has been detected.<br>The service request output that is activated is defined by<br>MLI_TINPR.PTEIPx.                              |
| TEI                                 | 9                   | rh   | Time-Out Error Flag<br>This flag becomes set if a time-out error interrupt event<br>has been detected<br>The service request output that is activated is defined by<br>MLI_TINPR.PTEIPx.                                       |



| Field | Bits    | Туре | Description                                             |
|-------|---------|------|---------------------------------------------------------|
| 0     | [31:10] | r    | <b>Reserved</b><br>Read as 0; should be written with 0. |

#### 4.3.4.3 Transmitter Interrupt Node Pointer Register

The Transmitter Interrupt Node Pointer Register MLI\_TINPR contains the interrupt node pointers for the MLI transmitter interrupts events.

#### **MLI\_TINPR**

# MLI Transmitter Interrupt Node Pointer Register (2A0<sub>H</sub>) Reset Value: 0000 0000<sub>H</sub>

| 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24 | 23 | 22 | 21    | 20 | 19 | 18 | 17    | 16 |
|----|----|----|----|----|----|--------|----|----|----|-------|----|----|----|-------|----|
|    | Ι  | Ι  | I  | 0  | Ι  |        | I  | Ι  |    | PTEIP |    | 0  |    | CFSIP |    |
|    | 1  | I  | L  | r  | I  |        | I  | 1  |    | rw    |    | r  |    | rw    |    |
|    |    |    |    |    |    |        |    |    |    |       |    |    |    |       |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8  | 7  | 6  | 5     | 4  | 3  | 2  | 1     | 0  |
| 0  | 1  |    | 3  | 0  | M  | IFSIP: | 2  | 0  | 1  |       | 1  | 0  | 1  | NFSIP | D  |
|    |    | I  |    |    |    |        | I  |    |    | 1     |    |    |    | 1     |    |
| r  |    | rw |    | r  |    | rw     |    | r  |    | rw    |    | r  |    | rw    |    |

| Field  | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFSIP0 | [2:0] | rw   | <ul> <li>Normal Frame Sent in Pipe 0 Interrupt Pointer</li> <li>This bit field determines which MLI Request x becomes active when a Normal Frame sent in Pipe 0 interrupt occurs.</li> <li>000 MLI Request0 is selected</li> <li>001 MLI Request1 is selected</li> <li>010 MLI Request2 is selected</li> <li>011 MLI Request3 is selected</li> <li>100 Reserved, do not use</li> <li>101 Reserved, do not use</li> <li>110 Reserved, do not use</li> <li>111 Reserved, do not use</li> </ul> |
| NFSIP1 | [6:4] | rw   | <b>Normal Frame Sent in Pipe 1 Interrupt Pointer</b><br>This bit field determines which MLI Request x becomes<br>active when a Normal Frame sent in Pipe 1 interrupt<br>occurs. Coding see NFSIP0.                                                                                                                                                                                                                                                                                           |



| Field  | Bits                               | Туре | Description                                                                                                                                                                                        |
|--------|------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFSIP2 | [10:8]                             | rw   | <b>Normal Frame Sent in Pipe 2 Interrupt Pointer</b><br>This bit field determines which MLI Request x becomes<br>active when a Normal Frame sent in Pipe 2 interrupt<br>occurs. Coding see NFSIP0. |
| NFSIP3 | [14:12]                            | rw   | <b>Normal Frame Sent in Pipe 3 Interrupt Pointer</b><br>This bit field determines which MLI Request x becomes<br>active when a Normal Frame sent in Pipe 3 interrupt<br>occurs. Coding see NFSIP0. |
| CFSIP  | [18:16]                            | rw   | <b>Command Frame Sent Interrupt Pointer</b><br>This bit field determines which MLI Request x becomes<br>active when a Command Frame sent interrupt occurs.<br>Coding see NFSIP0.                   |
| PTEIP  | [22:20]                            | rw   | Parity or Time Out Interrupt Pointer<br>This bit field determines which MLI Request x becomes<br>active when a parity/time-out interrupt occurs. Coding<br>see NFSIP0.                             |
| 0      | 3, 7,<br>11, 15,<br>19,<br>[31:23] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                            |



#### 4.3.5 Receiver Interrupt Registers

#### 4.3.5.1 Receiver Interrupt Enable Register

The Receiver Interrupt Enable Register MLI\_RIER contains the interrupt enable bits and the interrupt request enable flag clear bits for all receiver interrupt request sources. The bits marked w are always read as 0.

#### **MLI\_RIER**

| MLI F | MLI Receiver Interrupt Enable Register (2A4 <sub>H</sub> ) Reset |    |    |    |    |           |    |          | et Va    | lue: 0     | 000 0      | 000 <sub>H</sub> |            |          |           |
|-------|------------------------------------------------------------------|----|----|----|----|-----------|----|----------|----------|------------|------------|------------------|------------|----------|-----------|
| 31    | 30                                                               | 29 | 28 | 27 | 26 | 25        | 24 | 23       | 22       | 21         | 20         | 19               | 18         | 17       | 16        |
|       | 1                                                                | (  | )  | 1  | 1  | DRA<br>IR | 0  | PE<br>IR | ICE<br>R | CFR<br>IR3 | CFR<br>IR2 | CFR<br>IR1       | CFR<br>IR0 | ME<br>IR | NFR<br>IR |
| L     |                                                                  | l  | ſ  |    | 1  | W         | W  | W        | W        | W          | w          | w                | W          | W        | W         |
| 15    | 14                                                               | 13 | 12 | 11 | 10 | 9         | 8  | 7        | 6        | 5          | 4          | 3                | 2          | 1        | 0         |
|       | <b>0</b>                                                         |    |    |    |    | DRA<br>IE | 0  | PEIE     | ICE      | CFR<br>IE3 | CFR<br>IE2 | CFR<br>IE1       | CFR<br>IE0 |          | FR<br>E   |
|       |                                                                  |    | r  |    |    | rw        | rw | rw       | rw       | rw         | rw         | rw               | rw         | r        | W         |

| Field                                   | Bits                | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------|---------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFRIE                                   | [1:0]               | rw   | <ul> <li>Normal Frame Received Interrupt Enable</li> <li>This bit field defines whether an interrupt is generated</li> <li>when a Normal Frame is correctly received.</li> <li>00 The interrupt generation is disabled</li> <li>01 The interrupt is generated each time a Normal</li> <li>Frame is correctly received</li> <li>10 The interrupt is generated each time a Normal</li> <li>Frame is correctly received that is not handled</li> <li>automatically by the MLI (e.g. an Answer Frame)</li> <li>11 Reserved</li> </ul> |
| CFRIE0,<br>CFRIE1,<br>CFRIE2,<br>CFRIE3 | 2,<br>3,<br>4,<br>5 | rw   | <ul> <li>Command Received in Pipe x Interrupt Enable</li> <li>This bit determines whether an interrupt is generated</li> <li>when a Command Frame for Pipe x has been received</li> <li>correctly.</li> <li>0 Command received in Pipe x interrupt is disabled</li> <li>1 Command received in Pipe x interrupt is enabled</li> </ul>                                                                                                                                                                                              |



| Field                                  | Bits                    | Туре | Description                                                                                                                                                                                                                                  |
|----------------------------------------|-------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ICE                                    | 6                       | rw   | Interrupt Command EnableThis bit determines whether an interrupt is generatedwhen a Command Frame is received in Pipe 0.0Command Frame received in Pipe 0 interrupt is<br>disabled1Command Frame received in Pipe 0 interrupt is<br>enabled  |
| PEIE                                   | 7                       | rw   | <ul> <li>Parity Error Interrupt Enable</li> <li>This bit enables the interrupt generated if receiver a parity error event is detected.</li> <li>0 Parity error interrupt is disabled</li> <li>1 Parity error interrupt is enabled</li> </ul> |
| DRAIE                                  | 9                       | rw   | Discarded Read Answer Interrupt EnableThis bit enables the interrupt generated if a discardedread Answer Frame condition is detected.0Discarded read answer interrupt is disabled1Discarded read answer interrupt is enabled                 |
| NFRIR                                  | 16                      | w    | Normal Frame Received Interrupt Flag Clear0No action1Clear MLI_RISR.NFRI                                                                                                                                                                     |
| MEIR                                   | 17                      | w    | MLI Move Engine Interrupt Flag Clear         0       No action         1       Clear MLI_RISR.MEI                                                                                                                                            |
| CFRIR0<br>CFRIR1,<br>CFRIR2,<br>CFRIR3 | 18,<br>19,<br>20,<br>21 | W    | Command Frame Received through Pipe x InterruptFlag Clear00No action1Clear MLI_RISR.CFRIx                                                                                                                                                    |
| ICER                                   | 22                      | w    | Interrupt Command Flag Clear         0       No action         1       Clear MLI_RISR.ICE                                                                                                                                                    |
| PEIR                                   | 23                      | w    | Parity Error Interrupt Flag Clear0No action1Clear MLI_RISR.PEI                                                                                                                                                                               |
| DRAIR                                  | 25                      | W    | Discarded Read Answer Interrupt Flag Clear0No action1Clear MLI_RISR.DRAI                                                                                                                                                                     |
| 0                                      | 8, 24                   | W    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                      |



| Field | Bits               | Туре | Description                                             |
|-------|--------------------|------|---------------------------------------------------------|
| 0     | [15:10]<br>[31:26] | r    | <b>Reserved</b><br>Read as 0; should be written with 0. |

#### 4.3.5.2 Receiver Interrupt Status Register

The Receiver Interrupt Status Register MLI\_RISR contains all of the interrupt request flags of the MLI receiver. These interrupt request flags can be cleared by software when writing the appropriate bits in the MLI\_RIER register.

#### MLI\_RISR

MLI Receiver Interrupt Status Register(2A8<sub>H</sub>) Reset Value: 0000 0000<sub>H</sub> 31 30 29 28 27 25 24 23 22 21 20 26 19 18 17 16 0 r 15 14 13 10 9 8 7 6 5 4 3 2 1 0 12 11 CFR CFR CFR CFR ME NFR 0 DRAI 0 PEI IC 13 12 11 10 L L rh rh rh rh rh rh r rh rh rh r

| Field                              | Bits                | Туре | Description                                                                                                                                                                                                        |
|------------------------------------|---------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFRI                               | 0                   | rh   | Normal Frame Received Interrupt Flag<br>This flag is set when a write or a read frame has been<br>received.<br>The MLI Request that is activated is defined by<br>MLI_RINPR.NFRIP.                                 |
| MEI                                | 1                   | rh   | MLI Move Engine Interrupt Flag<br>This flag is set when the MLI has finished an operation<br>(read or write, depending on received frame).<br>The MLI Request that is activated is defined by<br>MLI_RINPR.MPPEIP. |
| CFRI0<br>CFRI1,<br>CFRI2,<br>CFRI3 | 2,<br>3,<br>4,<br>5 | rh   | Command Frame Received through Pipe x Interrupt<br>Flag<br>This flag is set when a Command Frame has been<br>received in Pipe x.<br>The MLI Request that is activated is defined by<br>MLI_RINPR.CFRIP.            |



| Field | Bits          | Туре | Description                                                                                                                                                                                                                                                                                                                                      |
|-------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IC    | 6             | rh   | Interrupt Command Flag<br>This flag is set when a Command Frame has been<br>received in Pipe 0 leading to an activation of one of the<br>MLI Requests.<br>The MLI Request that is activated is defined by the<br>received command CMD.                                                                                                           |
| PEI   | 7             | rh   | Parity Error Interrupt Flag<br>This flag is set when a parity error interrupt event has<br>occurred.<br>The MLI Request that is activated is defined by<br>MLI_RINPR.MPPEIP.                                                                                                                                                                     |
| DRAI  | 9             | rh   | Discarded Read Answer Interrupt Flag<br>This flag is set when the discarded read answer<br>interrupt event has occurred. This condition occurs if an<br>Answer Frame is received while none of the<br>MLI_TRSTATR.RPx bits is set (the Answer Frame was<br>not expected).<br>The MLI Request that is activated is defined by<br>MLI_RINPR.DRAIP. |
| 0     | 8,<br>[31:10] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                          |



#### 4.3.5.3 Receiver Interrupt Node Pointer Register

The Receiver Interrupt Node Pointer Register **MLI\_RINPR** contains the interrupt node pointers for the MLI receiver interrupts.

#### MLI\_RINPR

MLI Receiver Interrupt Node Pointer Register (2AC<sub>H</sub>) Reset Value: 0000 0000<sub>H</sub>

| 31 | 30       | 29       | 28       | 27 | 26 | 25       | 24       | 23 | 22       | 21    | 20       | 19       | 18       | 17    | 16       |
|----|----------|----------|----------|----|----|----------|----------|----|----------|-------|----------|----------|----------|-------|----------|
|    | O        |          |          |    |    |          |          |    |          |       |          |          |          |       |          |
|    | <u> </u> | <u> </u> | <u> </u> | I  | I  | <u> </u> | <u> </u> | ſ  | <u> </u> |       | <u> </u> | <u> </u> | <u> </u> | I     | <u> </u> |
| 15 | 14       | 13       | 12       | 11 | 10 | 9        | 8        | 7  | 6        | 5     | 4        | 3        | 2        | 1     | 0        |
| 0  | I        | DRAIF    | )        | 0  |    | 0        | I        | 0  | 1        | CFRIP |          | 0        |          | NFRIF |          |
| r  |          | rw       | <u> </u> | r  |    | rw       | I        | r  |          | rw    | <u> </u> | r        |          | rw    |          |

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|-------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| NFRIP | [2:0]   | rw   | <ul> <li>Normal Frame Received Interrupt Pointer</li> <li>This bit field determines which MLI Request x becomes active when a Normal Frame received interrupt occurs.</li> <li>000 MLI Request 0 is selected</li> <li>001 MLI Request 1 is selected</li> <li>010 MLI Request 2 is selected</li> <li>011 MLI Request 3 is selected</li> <li>100 Reserved, do not use</li> <li>101 Reserved, do not use</li> <li>110 Reserved, do not use</li> <li>111 Reserved, do not use</li> </ul> |  |  |  |
| CFRIP | [6:4]   | rw   | <b>Command Frame Received Interrupt Pointer</b><br>This bit field determines which MLI Request x becomes<br>active when a Command Frame received interrupt<br>occurs. Coding see NFRIP.                                                                                                                                                                                                                                                                                              |  |  |  |
| DRAIP | [14:12] | rw   | <b>Discarded Read Answer Interrupt Pointer</b><br>This bit field determines which MLI Request x becomes<br>active when a discarded read answer interrupt occurs.<br>Coding see NFRIP.                                                                                                                                                                                                                                                                                                |  |  |  |
| 0     | [10:8]  | r    | Reserved<br>Should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |



| Field | Bits     | Туре | Description                          |
|-------|----------|------|--------------------------------------|
| 0     | 3, 7, 11 | r    | Reserved                             |
|       | [31:15]  |      | Read as 0; should be written with 0. |



#### 4.4 MLI Address Map

The MLI module supports four Small Transfer Windows (STW)—one for each Pipe—and four Large Transfer Windows (LTW)—one for each Pipe.

#### **Transfer Window Areas and MLI Register Address Space**

| Module     | Base Address           | End Address            | Note           |
|------------|------------------------|------------------------|----------------|
| STW Pipe 0 | 0000 8000 <sub>H</sub> | 0000 9FFF <sub>H</sub> | 8 kBytes max.  |
| STW Pipe 1 | 0000 A000 <sub>H</sub> | 0000 BFFF <sub>H</sub> | 8 kBytes max.  |
| STW Pipe 2 | 0000 C000 <sub>H</sub> | 0000 DFFF <sub>H</sub> | 8 kBytes max.  |
| STW Pipe 3 | 0000 E000 <sub>H</sub> | 0000 FFFF <sub>H</sub> | 8 kBytes max.  |
| LTW Pipe 0 | 0001 0000 <sub>H</sub> | 0001 FFFF <sub>H</sub> | 64 kBytes max. |
| LTW Pipe 1 | 0002 0000 <sub>H</sub> | 0002 FFFF <sub>H</sub> | 64 kBytes max. |
| LTW Pipe 2 | 0003 0000 <sub>H</sub> | 0003 FFFF <sub>H</sub> | 64 kBytes max. |
| LTW Pipe 3 | 0004 0000 <sub>H</sub> | 0004 FFFF <sub>H</sub> | 64 kBytes max. |

#### Table 4-11Transfer Window Areas



# 5 Synchronous Serial Interface (SSC)

This chapter describes how the SSC interface is used in the CIC751.

#### 5.1 Overview

The SSC supports full-duplex and half-duplex serial synchronous communication up to 10 Mbit/s (@ 40 MHz module clock). The serial clock signal is received from an external master (Slave Mode). Data width, shift direction, clock polarity, and phase are programmable. This allows communication with SPI-compatible devices. Transmission and reception of data is double-buffered. A shift clock generator provides the SSC with a separate serial clock signal.

This chapter describes only the use of the SSC module as a slave because the CIC751 always operates as a slave to a host.

#### Features

- Slave Mode operation
  - Full-duplex or half-duplex operation
  - Automatic pad control possible
- Flexible data format
  - Programmable shift direction: LSB or MSB shift first
  - Programmable clock polarity: Idle low or idle high state for the shift clock
  - Programmable clock/data phase: Data shift with leading or trailing edge of the shift clock
- Internal Master Function
  - Access to the all addresses
  - Automatic address handling
  - Automatic data handling



#### 5.2 General Operation

The SSC supports full-duplex and half-duplex synchronous communication up to 10 Mbit/s (@ 40 MHz module clock). The serial clock signal is received from an external master (Slave Mode). Data width, shift direction, clock polarity, and phase are programmable. This allows communication with SPI-compatible devices. Transmission and reception of data are double-buffered. A shift clock generator provides the SSC with a separate serial clock signal.

Configuration of the high-speed synchronous serial interface is very flexible, so it can work with other synchronous serial interfaces, can serve for master/slave or multi-master interconnections, or can operate compatibly with the popular SPI interface. The SSC supports half-duplex and full-duplex communication. Data is transmitted or received on pins MTSR (Master Transmit/Slave Receive) and MRST (Master Receive/Slave Transmit). The clock signal is received via pin SCLK (Serial Clock). Using the RDY pin, the CIC751 signals the master that SCLK can be activated. The SSC can be selected from a master via the Slave Select input Line (SLS).



Figure 5-1 Synchronous Serial Channel SSC Block Diagram



# 5.2.1 SPI Communication Basics

There are two principal modes of operation for SPI communication: Full-Duplex and Half-Duplex.

# 5.2.1.1 Full-Duplex Operation

The description in this section assumes that the SSC is used with software controlled bidirectional GPIO port lines that have an open-drain capability.

The various devices are connected through three lines. The definition of these lines is always determined by the master. The line connected to the master's data output pin MTSR (Master Transmit Slave Receive) is the transmit line, the receive line is connected to its data input line MRST (Master Receive Slave Transmit), and the clock line is connected to pin SCLK. Only the device selected for master operation generates and outputs the serial clock on pin SCLK. All slaves receive this clock, so their pin SCLK must be switched to input mode. The output of the master's shift register is connected to the external transmit line, which in turn is connected to the slaves' shift register input. The output of the slaves' shift register is connections are hard-wired, with the function and direction of these pins determined by the master or slave operation of the individual device.

# Note: The shift direction shown in **Figure 5-2** applies to both MSB-first and LSB-first operation.

When initializing the devices in this configuration, one device must be selected for master operation while all other devices must be programmed for slave operation. Initialization includes the operating mode of the device's SSC and also the function of the respective port lines.





Figure 5-2 SSC Full-Duplex Configuration

The data output pins (MRST) of all slave devices are connected to one receive line in this configuration. During a transfer, each slave shifts out data from its shift register. There are two ways to avoid collisions on the receive line due to different slave data:

- Only one slave drives the line and enables the driver of its MRST pin. All the other slaves must program their MRST pins to input. Therefore, only one slave can input its data to the master's receive line. Only reception of data from the master is possible. The master selects the slave device from which it expects data either by separate select lines, or by sending a special command to this slave. The selected slave then switches its MRST line to output until it gets a de-selection signal or command.
- The slaves use an open drain output on MRST. This forms a wired-AND connection. The receive line needs an external pull-up in this case. Corruption of the data on the receive line sent by the selected slave is avoided when all slaves not selected for transmission to the master send only 1s. Since this high level is not actively driven onto the line, but is only held through the pull-up device, the selected slave can pull this line actively to a low level when transmitting a 0 bit. The master



selects the slave device from which it expects data either by separate select lines, or by sending a special command to this slave.

After performing all necessary initialization tasks for the SSC, the serial interfaces can be enabled. For a master device, the alternate clock line will now go to its programmed polarity. The alternate data line will go to either 0 or 1, until the first transfer starts. After a transfer, the alternate data line will always remain at the logic level of the last transmitted data bit.

When the serial interfaces are enabled, the master device can initiate the first data transfer. This value is copied into the shift register (assumed to be empty at this time), and the selected first bit of the transmit data will be placed onto the MTSR line on the next clock from the shift clock generator. Depending on the selected clock phase, a clock pulse is generated on the SCLK line. With the opposite clock edge, the master simultaneously latches and shifts in the data detected at its input line MRST. This "exchanges" the transmit data with the receive data. Because the clock line is connected to all slaves, their shift registers will be shifted synchronously with the master's shift register, shifting out the data contained in the registers, and shifting in the data detected at the input line. After the pre-programmed number of clock pulses (via the data width selection), the data transmitted by the master is contained in all slaves' shift registers, while the master's shift register holds the data of the selected slave. In the master and all slaves, the content of the shift register is copied into the Receive Buffer (SSC\_RB).

A slave device will immediately output the selected first bit (MSB or LSB of the transfer data) at pin MRST when the contents of the transmit buffer is copied into the slave's shift register. Bit SSC\_STAT.BSY is not set until the first clock edge at SCLK appears. The slave device will not wait for the next clock from the shift clock generator—as the master does—because the first clock edge generated by the master may be already used to clock in the first data bit, depending on the selected clock phase. So, the slave's first data bit must already be valid at this time.

Note: On the SSC, a transmission and a reception always takes place at the same time, regardless of whether valid data has been transmitted or received.



# 5.2.1.2 Half-Duplex Operation

The description in this section assumes that the SSC is used with software controlled bidirectional GPIO port lines that provide an open-drain capability.

In a half-duplex configuration, only one data line is necessary for both receiving **and** transmitting data. The data exchange line is connected to both pins MTSR and MRST of each device, and the clock line is connected to the SCLK pin.

The master device controls the data transfer by generating the shift clock, while the slave devices receive it. Due to the fact that all transmit and receive pins are connected to the one data exchange line, serial data may be moved between arbitrary stations.

As in full-duplex mode, there are two ways to avoid collisions on the data exchange line:

- Only the transmitting device may enable its transmit pin driver
- The non-transmitting devices use open-drain output and only send 1's

Because the data inputs and outputs are connected together, a transmitting device will clock in its own data at the input pin (MRST for a master device, MTSR for a slave). In this way, any corruption is detected on the common data exchange line when the received data is not equal to the transmitted data.





Figure 5-3 SSC Half-Duplex Configuration



# 5.2.2 Operating the SSC

The following sections explain how the SSC is best used for operation of the CIC751.

The basic task of the SSC is to communicate with a host controller to which the CIC751 is connect. Therefore, the CIC751 SSC always operates as a slave within the serial communication. The communication requirements can be split into two categories:

- Configuration of the CIC751
  - This requires write access from the host to the CIC751 to update the various control registers.
- Transfer of the conversion result back to the host
  - The conversion results need to be transferred back to the requesting host. The CIC751 provides all required hardware support so that the conversion results can be communicated back to the host in a semi-automatic way.

# 5.2.2.1 SSC Transaction Header

The first halfword that is send by the host is interpreted as the transaction header and is composed of the CMD bit, the INCE bit and an address ADDR of 14 bits. Therefore, the master (host) must first send the 16-bit header information before sending each communication block. A communication block is composed of the transaction header and one or more 16-bit communication data blocks.

The following table defines the SSC transaction header.

| Name | Description                                                                                                                                                                                | Bit<br>Position |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| CMD  | Transfer Type Identifier0A read transfer is selected1A write transfer is selected                                                                                                          | 15              |
| INCE | <ul> <li>Address Increment Enable</li> <li>The destination address is not increment after each transaction</li> <li>The destination address is increment after each transaction</li> </ul> | 14              |
| ADDR | Destination Address                                                                                                                                                                        | 130             |

| Table 5-1 | Transaction Header  |
|-----------|---------------------|
|           | Than Subtron Thouse |

CMD determines if the following portion of the communication indicates a write or read operation.

INCE determines whether or not the address is automatically incremented by two after the first data block.



#### Example: INCE = 1

Setup for the source and destination addresses of DMA Channel 5 for additional data transfers must be updated. Therefore, the DMA channel registers DMA\_ADRCR5, DMA\_SADR5, and DMA\_DADR5 must be updated. Beginning with register DMA\_ADRCR5, all three registers can be updated with a single SSC communication block.

# 5.2.2.2 SSC Data Flow Model

As the SSC operates only as slave, the master must follow some rules to establish a working communication link.

#### Communication Rules

- An SSC communication block is composed out of one Transaction Header and several data blocks.
- An SSC communication block is started by the master with an assertion of SLS
- An SSC communication block is stopped by the master with a de-assertion of SLS
- The duration of a communication block should always be a multiple of 16 SCLK cycles
- A data block is the data that is transmitted during the 16 SCLK cycles
- Only 16-bit data blocks are legal for an SSC communication
- The first 16-bit data block is always used as the transaction header
- All 16-bit data blocks after the transaction header are used as write or read data

#### SSC Write Operation (CMD = 1)

For each SSC transfer that is received via the SSC interface, the transaction header information is extracted from the first transmitted halfword—which is the command CMD, the increment indicator INCE, and the address ADDR. The following halfwords are then used as data. With CMD, INCE, and ADDR available, the data is copied to the destination address according to the setting of INCE and ADDR.

The pin RDY is provided for additional synchronization between the host and slave. This pin or information is required due to the fact that the master does not know how much time (system cycles) is exactly consumed by the CIC751 to move the transmitted write data to the desired destination. The amount of time depends on the frequency of the CIC751 and the currently active CIC751 register accesses performed by the DMA. Therefore, the RDY pin is introduced to show that the SSC interface is ready for the next part of the transmission (RDY is asserted).

The RDY pin should be used by the master in the following way:

- If RDY changes from de-asserted ('0') to asserted ('1'), the master starts to generate 16 clock cycles for SCLK
- If RDY changes from asserted ('1') to de-asserted ('0'), the master takes no action



The default level of RDY is '0'. If a master selects the CIC751 for an SSC communication, SLS is asserted ('0') and RDY is changed to asserted ('1'). This allows the master to start with the transmission of the transaction header (the first 16 SCLK cycles). Meanwhile, RDY is de-asserted again to be ready for the next use and to signal the master that the first SCLK cycle was received. Using the first address, the first write data is forwarded to the destination register. This is indicated by the assertion of RDY again. Thereafter, the master can generate the next 16 SCLK required for the next write data to transmit. With the first cycle of SCLK, RDY is de-asserted again to be ready for the next write data to transmit. With the first cycle of SCLK, RDY is de-asserted again to be ready for the next use and to signal the master that the first SCLK cycle was received. This sequence is repeated until SLS is de-asserted ('1') by the master after RDY was asserted.



Figure 5-4 Consecutive Writes

#### SSC Read Operation (CMD = 0)

For each SSC transfer that is received via the SSC interface, the transaction header information is extracted from the first transmitted halfword—which is the command CMD, the increment indicator INCE, and the address ADDR. With this header, the data from the source address on the CIC751 reads automatically and sends them back to the host via the SSC transmit buffer SSC\_TB.

The pin RDY is provided for additional synchronization between the host and slave. This pin or information is required due to the fact that the master does not know how much time (system cycles) is exactly consumed by the CIC751 for fetching the requested read data. This depends on the frequency of the CIC751 and the currently active CIC751 register accesses performed by the DMA. Therefore, the RDY pin is introduced to ensure that the read data is ready for transmission (RDY is asserted).

The RDY pin should be used by the master in the following way:

- If RDY changes from de-asserted ('0') to asserted ('1'), the master starts to generate 16 clock cycles for SCLK
- If RDY changes from asserted ('1') to de-asserted ('0'), the master takes no action



The default level of RDY is '0'. If a master selects the CIC751 for an SSC communication, SLS is asserted ('0') and RDY is changed to asserted ('1'). This allows the master to start with the transmission of the transaction header (the first 16 SCLK cycles). Meanwhile, RDY is de-asserted again to be ready for the next use and to signal the master that the first SCLK cycle was received. Using the first address, the first read data is fetched and is ready for transmission. This is indicated by the assertion of RDY again. Thereafter, the master can generate the next 16 SCLK required for the slave to transmit the 16-bit read data. With the first cycle of SCLK, RDY is de-asserted again to be ready for the next use and to signal the master that the first SCLK cycle was received and the transmission of the first read data is started. In parallel with the transmission of the read data, the next read is fetched and prepared for transmission either from address ADDR (INCE = 0) or from address ADDR + 2 (INCE = 1). This sequence is repeated until SLS is de-asserted ('1') by the master.

This automatic read process is optimized for several consecutive read data transfers within one communication block. Therefore, the next to transmit read data is prefetched during the transmission of the currently processed data. This leads to a minimum dead time between the transmission of two 16-bit read data parts and an increase of the maximum usable bandwidth for communication. But, on the other hand, this mechanism has a negative impact for starting a read access.

After the first read access to the CIC751, the last read data that was prefetched is still read for transmission and will be automatically transmitted in parallel with the reception of the next transaction header. Automatically, during the transmission of this prefetched data, a new prefetch is started before the new transaction header is taken into account.

Therefore, the following rules must be considered for read accesses by the master:

- The read data that is received in parallel with sending the transaction header should be ignored
- The first read data that is received after sending the transaction header should be ignored
- The above mentioned rules does not apply to the first read access after a reset (PORST or SW reset) or a write access





Figure 5-5 Consecutive Reads



### 5.2.3 Operating Mode Selection

The following features of the serial data bit transfer can be programmed:

- A transfer may start with the LSB or the MSB
- The shift clock may be idle low or idle high
- The data bits may be shifted with the leading or trailing edge of the clock signal
- The baud rate (shift clock) can be set from 0.15 bit/s up to 10 Mbit/s (@ 40 MHz module clock)

These features allow the SSC to be adapted to a wide range of applications that require serial data transfer.

Regardless of whether the MSB or the LSB is transmitted first, the transfer data is always right-aligned in registers **SSC\_TB** and **SSC\_RB**, with the LSB of the transfer data in bit 0 of these registers. The data bits are rearranged for transfer by the internal shift register logic.

The Clock Control allows the adaptation of the transmit and receive behavior of the SSC to a variety of serial interfaces. A specific clock edge (rising or falling) is used to shift out transmit data, while the other clock edge is used to latch in receive data. Bit SSC\_CON.PH selects the leading edge or the trailing edge for each function. Bit SSC\_CON.PO selects the level of the clock line in the idle state. For an idle-high clock, the leading edge is a falling one, a 1-to-0 transition (see Figure 5-6).



Figure 5-6 Serial Clock SCLK: Phase and Polarity Options



# 5.2.4 Error Detection Mechanisms

The SSC is able to detect three different error conditions. Receive Error, Phase Error, and Transmit Error. When an error is detected, the respective error flag is always set. The error flags are not cleared automatically, but must be cleared via register SSC\_EFM after servicing. The error status flags can be set and cleared by software via the error flag modification register SSC\_EFM.

A **Receive Error** is detected when a new data frame is completely received, but the previous data was not read out of the receive buffer register RB. This condition sets the error flags STAT.RE and SCU\_ERRCUM.RE. The old data in the receive buffer RB will be overwritten with the new value and is unrecoverable lost.

A **Phase Error** is detected when the incoming data at pin MTSR (Slave Mode), sampled with the same frequency as the system clock, changes between one cycle before and two cycles after the latching edge of the shift clock signal SCLK. This condition sets the error status flags STAT.PE and SCU\_ERRCUM.PE.

Note: When using the setting SSC\_CON.PH = 1, phase errors can occur due to the fact that the slave select signal change can result in a change of the data signal. The slave select signal always changes with the leading clock edge.

A **Transmit Error** is detected when a transfer was initiated by the master (shift clock becomes active), but the transmit buffer TB of the slave was not updated since the last transfer. This condition sets the error status flags STAT.TE and SCU\_ERRCUM.TE. If a transfer starts while the transmit buffer is not updated, the slave will shift out the 'old' contents of the shift register, which is normally the data received during the last transfer. This may lead to the corruption of the data on the transmit/receive line in Half-duplex Mode (open-drain configuration) if this slave is not selected for transmission.

Note: A slave with push/pull output drivers not selected for transmission will normally have its output drivers switched off. However, to avoid possible conflicts or misinterpretations, it is recommended to always load the slave's transmit buffer prior to any transfer.



#### 5.3 Register Descriptions

 Table 5-2 identifies all of the SSC registers.

rw

rw

rw

rw

rw

rw

rw

rw

The base address of the SSC is 0000 0900. A register address is computed by adding the base address to the register offset address.

| Register<br>Short Name | Register Long Name               | Offset<br>Address | Page<br>Number |
|------------------------|----------------------------------|-------------------|----------------|
| SSC_CON                | Control Register                 | 10 <sub>H</sub>   | Page 5-15      |
| SSC_STAT               | Status Register                  | 28 <sub>H</sub>   | Page 5-18      |
| SSC_EFM                | Error Flag Modification Register | 2C <sub>H</sub>   | Page 5-19      |
| SSC_TB                 | Transmit Buffer Register         | 20 <sub>H</sub>   | Page 5-21      |
| SSC_RB                 | Receive Buffer Register          | 24 <sub>H</sub>   | Page 5-22      |
| SSC_BR                 | Baud Rate Timer Reload Register  | 14 <sub>H</sub>   | Page 5-22      |

#### Table 5-2Registers Overview

| SSC_<br>SSC |    |    | egiste | er |     |     | (10 | D <sub>H</sub> ) | Reset Value: 0000 875F <sub>r</sub> |    |    |    |    | 875F <sub>Н</sub> |    |
|-------------|----|----|--------|----|-----|-----|-----|------------------|-------------------------------------|----|----|----|----|-------------------|----|
| 31          | 30 | 29 | 28     | 27 | 26  | 25  | 24  | 23               | 22                                  | 21 | 20 | 19 | 18 | 17                | 16 |
|             | 1  | I  | 1      | I  | 1   | I   |     | <b>)</b>         | I                                   | I  | 1  | 1  | 1  | 1                 |    |
|             |    |    |        |    |     |     |     | l                |                                     |    |    |    |    |                   |    |
| 15          | 14 | 13 | 12     | 11 | 10  | 9   | 8   | 7                | 6                                   | 5  | 4  | 3  | 2  | 1                 | 0  |
| EN          | MS | 0  |        | )  | PEN | REN | TEN | LB               | РО                                  | PH | НВ |    | В  | М                 |    |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                              |
|-------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ВМ    | [3:0] | rw   | <b>Data Width Selection</b><br>BM determines the number of data bits of the serial frame. The data width is set to 16-bit and should never be changed. Always write $1111_B$ to this bit field when this register is updated. Otherwise, the communication is corrupted. |

rw

rw

r

rw



| Field | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| НВ    | 4    | rw   | Heading Bit Control0Transmit/Receive LSB First1Transmit/Receive MSB First                                                                                                                                                                                                                                                                |
| PH    | 5    | rw   | <ul> <li>Clock Phase Control</li> <li>Shift transmit data on the leading clock edge,<br/>latch on trailing edge</li> <li>Latch receive data on leading clock edge, shift<br/>on trailing edge</li> </ul>                                                                                                                                 |
| PO    | 6    | rw   | <ul> <li>Clock Polarity Control</li> <li>Idle clock line is low, the leading clock edge is low-to-high transition</li> <li>Idle clock line is high, the leading clock edge is high-to-low transition</li> </ul>                                                                                                                          |
| LB    | 7    | rw   | Loop-Back Control0Normal output1Receive input is connected to transmit output<br>(Half-duplex Mode)                                                                                                                                                                                                                                      |
| TEN   | 8    | rw   | Transmit Error Enable0Ignore transmit errors1Check transmit errors                                                                                                                                                                                                                                                                       |
| REN   | 9    | rw   | Receive Error Enable0Ignore receive errors1Check receive errors                                                                                                                                                                                                                                                                          |
| PEN   | 10   | rw   | Phase Error Enable0Ignore phase errors1Check phase errors                                                                                                                                                                                                                                                                                |
| MS    | 14   | rw   | <ul> <li>Master Select</li> <li>Slave Mode. Operate on shift clock received via<br/>SCLK</li> <li>Master Mode. This mode should not be selected.</li> <li>The module should also operated in Slave Mode only.</li> <li>Always set this bit when this register is updated.</li> <li>Otherwise, the communication is corrupted.</li> </ul> |



| Field | Bits           | Туре | Description                                                                                                                                                                                                                                                                     |
|-------|----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EN    | 15             | rw   | <ul> <li>Enable Bit</li> <li>0 Transmission and reception are disabled.</li> <li>1 Transmission and reception are enabled.</li> <li>The module should also be enabled. Always set this bit when this register is updated. Otherwise, the communication is corrupted.</li> </ul> |
| 0     | [12:11]        | rw   | <b>Reserved</b><br>Returns $0_B$ if read; has to be written with $0_B$ . Writing<br>something different than $0_B$ could lead to a corruption<br>of the communication.                                                                                                          |
| 0     | 13,<br>[31:16] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                         |



The Status Register SSC\_STAT contains status flags for error identification, the busy flag, and a bit field that indicates the current shift counter status.

| SSC_<br>SSC | _  |    | gister |    |    |        | (28 | З <sub>Н</sub> ) |    |          | Res | et Va | lue: C | 0000 ( | 0000 <sub>H</sub> |
|-------------|----|----|--------|----|----|--------|-----|------------------|----|----------|-----|-------|--------|--------|-------------------|
| 31          | 30 | 29 | 28     | 27 | 26 | 25     | 24  | 23               | 22 | 21       | 20  | 19    | 18     | 17     | 16                |
|             | 1  | 1  | 1      |    | 1  | I<br>I | (   | )                | 1  | I<br>I   | 1   | 1     | 1      | 1      |                   |
|             | 1  | 1  |        |    | 1  | I      |     | r                | 1  | 1        | 1   | 1     | 1      | 1      | I]                |
| 15          | 14 | 13 | 12     | 11 | 10 | 9      | 8   | 7                | 6  | 5        | 4   | 3     | 2      | 1      | 0                 |
|             | 0  | 1  | BSY    | 0  | PE | RE     | ΤE  |                  | •  | <b>)</b> | 1   |       | B      | C      |                   |
| L           | r  | 1  | rh     | r  | rh | rh     | rh  | 1                |    | r        | 1   | 1     | r      | h      |                   |

| Field | Bits                | Туре | Description                                                                                                                              |
|-------|---------------------|------|------------------------------------------------------------------------------------------------------------------------------------------|
| BC    | [3:0]               | rh   | <b>Bit Count Status</b><br>BC indicates the current status of the shift counter. The<br>shift counter is updated with every shifted bit. |
| TE    | 8                   | rh   | Transmit Error Flag0No error1Transfer starts with the slave's transmit buffer not<br>being updated                                       |
| RE    | 9                   | rh   | Receive Error Flag0No error1Reception completed before the receive buffer<br>was read                                                    |
| PE    | 10                  | rh   | Phase Error Flag0No error1Received data changes during the sampling<br>clock edge                                                        |
| BSY   | 12                  | rh   | Busy Flag<br>BSY is set while a transfer is in progress.                                                                                 |
| 0     | [7:4],11<br>[31:13] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                  |

The Error Flag Modification Register SSC\_EFM is required for resetting or setting the four error flags that are located in register SSC\_STAT.



# SSC\_EFM

| SSC | SC Error Flag Modification Register (2C <sub>H</sub> ) F |           |           |    |           |           |           |    |    |    |        | et Va | lue: ( | 0000 ( | 0000 <sub>H</sub> |
|-----|----------------------------------------------------------|-----------|-----------|----|-----------|-----------|-----------|----|----|----|--------|-------|--------|--------|-------------------|
| 31  | 30                                                       | 29        | 28        | 27 | 26        | 25        | 24        | 23 | 22 | 21 | 20     | 19    | 18     | 17     | 16                |
|     | 1                                                        | 1         | 1         | 1  | 1         | 1         | C         | )  | 1  | 1  | 1      | 1     | 1      | 1      | 1                 |
|     |                                                          | I         | I         | I  | I         | I         | ľ         | •  |    | I  |        | 1     | I      | I      | 11                |
| 15  | 14                                                       | 13        | 12        | 11 | 10        | 9         | 8         | 7  | 6  | 5  | 4      | 3     | 2      | 1      | 0                 |
| 0   | SET<br>PE                                                | SET<br>RE | SET<br>TE | 0  | CLR<br>PE | CLR<br>RE | CLR<br>TE |    | 1  | 1  | 1<br>( | D     | 1      | 1      |                   |
| W   | W                                                        | W         | W         | W  | W         | W         | W         |    | 1  |    |        | r     | 1      |        |                   |

| Field | Bits | Туре | Description                                                                            |
|-------|------|------|----------------------------------------------------------------------------------------|
| CLRTE | 8    | w    | Clear Transmit Error Flag0No effect1Bit SSC_STAT.TE is clearedBit is always read as 0. |
| CLRRE | 9    | w    | Clear Receive Error Flag0No effect1Bit SSC_STAT.RE is clearedBit is always read as 0.  |
| CLRPE | 10   | w    | Clear Phase Error Flag0No effect1Bit SSC_STAT.PE is clearedBit is always read as 0.    |
| SETTE | 12   | w    | Set Transmit Error Flag0No effect1Bit SSC_STAT.TE is setBit is always read as 0.       |
| SETRE | 13   | w    | Set Receive Error Flag0No effect1Bit SSC_STAT.RE is setBit is always read as 0.        |
| SETPE | 14   | w    | Set Phase Error Flag0No effect1Bit SSC_STAT.PE is setBit is always read as 0.          |



| Field | Bits              | Туре | Description                                              |
|-------|-------------------|------|----------------------------------------------------------|
| 0     | 11, 15            | w    | <b>Reserved</b><br>Read as 0; have to be written with 0. |
| 0     | [7:0],<br>[31:16] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.  |

#### SCU\_ERRCUM

| SCU | J Cumulative Error Register |          |    |     |     |     | (85 | С <sub>н</sub> ) |    |    | Res | et Va    | lue: C | 0000 (   | 0000 <sub>H</sub> |
|-----|-----------------------------|----------|----|-----|-----|-----|-----|------------------|----|----|-----|----------|--------|----------|-------------------|
| 31  | 30                          | 29       | 28 | 27  | 26  | 25  | 24  | 23               | 22 | 21 | 20  | 19       | 18     | 17       | 16                |
|     | 1                           | 1        | 1  | 1   | 1   | 1   | (   | )                | 1  | 1  | 1   | 1        | 1      | 1        |                   |
|     |                             | 1        | 1  |     | 1   | 1   |     | r                |    |    |     |          |        | <u> </u> | II                |
| 15  | 14                          | 13       | 12 | 11  | 10  | 9   | 8   | 7                | 6  | 5  | 4   | 3        | 2      | 1        | 0                 |
|     |                             | <b>D</b> | 1  | 0   | PE  | RE  | TE  |                  | 1  | 1  | (   | <b>)</b> | 1      | 1        | 1                 |
| L   |                             | r        | 1  | rwh | rwh | rwh | rwh | 1                | 1  | 1  |     | r        | 1      | 1        | ıl                |

| Field | Bits | Туре | Description                                                                                                                                                                                                                                                           |
|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TE    | 8    | rwh  | <ul> <li>Transmit Error Flag         <ul> <li>No error</li> <li>Transfer starts with transmit buffer not being updated</li> </ul> </li> <li>This bit is set in case of a Transmit Error event (see Chapter 5.2.4). This bit has to be cleared by software.</li> </ul> |
| RE    | 9    | rwh  | Receive Error Flag0No error1Reception completed before the receive buffer<br>was readThis bit is set in case of a Receive Error event (see<br>Chapter 5.2.4). This bit has to be cleared by<br>software.                                                              |

5-20



| Field | Bits              | Туре | Description                                                                                                                                                                                                                                                   |
|-------|-------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PE    | 10                | w    | <ul> <li>Phase Error Flag         <ol> <li>No error</li> <li>Received data changes around the sampling clock edge</li> </ol> </li> <li>This bit is set in case of a Phase Error event (see Chapter 5.2.4). This bit has to be cleared by software.</li> </ul> |
| 0     | 15                | rwh  | <b>Reserved</b><br>Read as 0; have to be written with 0.                                                                                                                                                                                                      |
| 0     | [7:0],<br>[31:12] | r    | Reserved<br>Read as 0; should be written with 0.                                                                                                                                                                                                              |

| SSC_<br>SSC |          | smit E | Buffe | r Reg | ister |    | (2 | 0 <sub>H</sub> ) |    |    | Res | et Va | lue: ( | 0000 ( | 0000 <sub>Н</sub> |
|-------------|----------|--------|-------|-------|-------|----|----|------------------|----|----|-----|-------|--------|--------|-------------------|
| 31          | 30       | 29     | 28    | 27    | 26    | 25 | 24 | 23               | 22 | 21 | 20  | 19    | 18     | 17     | 16                |
|             | <b>0</b> |        |       |       |       |    |    |                  |    |    |     |       |        |        |                   |
|             | r        |        |       |       |       |    |    |                  |    |    |     |       |        |        |                   |
| 15          | 14       | 13     | 12    | 11    | 10    | 9  | 8  | 7                | 6  | 5  | 4   | 3     | 2      | 1      | 0                 |
|             | TB_VALUE |        |       |       |       |    |    |                  |    |    |     |       |        |        |                   |
|             |          |        |       |       |       |    | r  | W                |    |    |     |       |        |        |                   |

| Field    | Bits    | Туре | Description                                                                                                 |
|----------|---------|------|-------------------------------------------------------------------------------------------------------------|
| TB_VALUE | [15:0]  | rw   | <b>Transmit Data Register Value</b><br>Register SSC_TB stores the data value to be<br>transmitted TB_VALUE. |
| 0        | [31:16] | r    | <b>Reserved</b><br>Returns 0 if read; should be written with 0.                                             |

The Receive Buffer Register RB contains the receive data value.



| SSC_RB<br>SSC Receive Buffer Register (24 <sub>H</sub> ) |          |    |    |    |    |    |    |    |    | Res | et Va | lue: C | 0000 ( | 0000 <sub>H</sub> |    |
|----------------------------------------------------------|----------|----|----|----|----|----|----|----|----|-----|-------|--------|--------|-------------------|----|
| 31                                                       | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20    | 19     | 18     | 17                | 16 |
| O                                                        |          |    |    |    |    |    |    |    |    |     |       |        |        |                   |    |
|                                                          | r        |    |    |    |    |    |    |    |    |     |       |        |        |                   |    |
| 15                                                       | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4     | 3      | 2      | 1                 | 0  |
|                                                          | RB_VALUE |    |    |    |    |    |    |    |    |     |       |        |        |                   |    |
| L                                                        | 1        | 1  | 1  | 1  | 1  | 1  | r  | h  |    | 1   | 1     | 1      | 1      | 1                 | 11 |

| Field    | Bits    | Туре | Description                                                                                     |
|----------|---------|------|-------------------------------------------------------------------------------------------------|
| RB_VALUE | [15:0]  | rh   | <b>Receive Data Register Value</b><br>Register RB contains the received data value<br>RB_VALUE. |
| 0        | [31:16] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                         |

#### SSC\_BR SSC Baud Rate Timer Reload Register (14<sub>H</sub>) Reset Value: 0000 0063<sub>H</sub> r 8 7 6 **BR\_VALUE** rw



| Field    | Bits    | Туре | Description                                                                                                                                                                                                                                                  |
|----------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BR_VALUE | [15:0]  | rw   | <b>Baud Rate Timer Reload Value</b><br>This bit field has to be set to FFFF by the set-up<br>software to ensure a error free communication. The<br>reset value is set in a way that a communication with a<br>bandwidth greater than 400 KBit/s is possible. |
| 0        | [31:16] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                      |

#### 5.4 Port Control

If the SSC was selected as the communication interface (pin MODE was latched after PORST with '1') for the CIC751, the port control registers of port 0 are automatically configured in a way that a communication via SPI is possible.

Port 0 control registers P0\_IOCR0, P0\_IOCR4, P0\_IOCR8, and P0\_IOCR12 are initialized with the following values:

- P0\_IOCR0 = A0202020<sub>H</sub>
- P0\_IOCR4 = 0020A020<sub>H</sub>
- P0\_IOCR8 = 20202020<sub>H</sub>
- P0\_IOCR12 = 00000020<sub>H</sub>

Port pins that can be used for either SSC or MLI communication are automatically configured in way that the MLI part is inactive and does not generate any action that can cause any harm to an SSC communication.

Using the open-drain output feature of port lines helps avoid bus contention problems and reduces the need for hard-wired hand-shaking or slave-select lines. The open-drain output feature can be selected for pin MRST via bit field P0\_IOCR0.PC3

# 5.4.1 Connecting 2 or more CIC751 SSC Slaves to 1 Host

If more than one slave is connected to an SSC master, only one of them may be selected at a time. The master enables one of the connected slaves with the associated slave select output signals. The other output signals of the master (MTSR and SCLK) are broadcast and connected to each slave. The output signals of the slaves (MRST and RDY), which are inputs of the master, must be activated by the selected slave and must be deactivated by all other slaves. In this way, it is possible to directly connect the incoming signals at the master's input terminal. The deactivation of the output stage on the associated pads. This deactivation takes place, if MODE = 1 and  $\overline{SLS} = 1$ , i.e. SSC is selected and slave is not selected.



Two additional bit fields are defined: PC3B in register P0\_IOCR0 for pin P0.3 and PC5B in register P0\_IOCR4 for pin P0.5. If the upper condition is true, then the new bit fields, PC3B and PC5B, define the GPIO port behavior; otherwise, the regular PC3 and PC5 define the GPIO port behavior. These new bit fields are programmable and should be programmed to an input-function in this case. The port thus becomes input whenever SLS goes high and the slave is deselected.



# 6 The Analog/Digital Converter

The CIC751 provides an Analog/Digital Converter with 8-bit or 10-bit resolution and a sample & hold circuit on-chip. An input multiplexer selects from up to 16 analog input channels either via software (Fixed Channel Modes) or automatically (Auto Scan Modes).

To fulfill most requirements of embedded control applications, the ADC supports the following conversion modes:

- Standard Conversions
  - Fixed Channel Single Conversion produces just one result from the selected channel
  - Fixed Channel Continuous Conversion repeatedly converts the selected channel
  - Auto Scan Single Conversion
     produces one result from each of a selected group of channels
  - Auto Scan Continuous Conversion repeatedly converts the selected group of channels
  - Wait for Read Mode starts a conversion automatically when the previous result has been read
- Channel Injection Mode can insert the conversion of a specific channel into a group conversion (auto scan)

A set of SFRs provide access to control functions and results of the ADC. The Enhanced Mode registers provide more detailed control functions for the ADC.

The external analog reference voltages  $V_{\text{AREF}}$  and  $V_{\text{AGND}}$  are not programmable. The separate supply for the ADC reduces interference with other digital signals. The reference voltages must be stable during the reset calibration phase and during an entire conversion, to achieve maximum accuracy.

The sample time as well as the conversion time are programmable, so the ADC can be adjusted to the internal resistances of the analog sources and/or the analog reference voltage supply.





Figure 6-1 Analog/Digital Converter Block Diagram

The ADC is implemented as a capacitive network using successive approximation conversion. A conversion consists of three phases.

- During the sample phase, the capacitive network is connected to the selected analog input and is charged or discharged to the voltage of the analog signal.
- During the actual conversion phase, the network is disconnected from the analog input and is repeatedly charged or discharged via  $V_{\text{AREF}}$  during the steps of successive approximation.
- After the (optional) post-calibration phase (to adjust the network to changing conditions such as temperature), the result is written to the result register and an interrupt request is generated.

There are two sets of control, data, and status registers: one set for Compatibility Mode and one set for Enhanced Mode. Only one of these register sets may be active at a given time. As most of the bits and bit fields of the registers of the two sets control the same functionality or control the functionality in a very similar way, the following description is organized according to the functionality, not according to the two register sets.



#### 6.1 Mode Selection

It is recommended that the digital input stage should be disabled via register STCU\_SYSCON.P1DIDIS if the ADC is used. This avoids undesired cross currents and switching noise when the (analog) input signal level is between  $V_{\rm IL}$  and  $V_{\rm IH}$ .

The functions of the A/D Converter are controlled by two sets of control registers. In Compatibility Mode, registers ADC\_CON and ADC\_CON1 are used. In Enhanced Mode, registers ADC\_CTR0, ADC\_CTR2, and ADC\_CTR2IN are used. Their bit fields specify the analog channel to be acted upon, specify the conversion mode, and also reflect the status of the converter.

#### 6.1.1 Compatibility Mode

In Compatibility Mode (ADC\_CTR0.MD = 0), registers ADC\_CON and ADC\_CON1 select the basic functions.

#### 6.1.2 Enhanced Mode

In Enhanced Mode (ADC\_CTR0.MD = 1), registers ADC\_CTR0, ADC\_CTR2, and ADC\_CTR2IN select the basic functions. The register layout for Enhanced Mode differs from the Compatibility Mode layout, but this mode provides more options.

Conversion timing is selected via registers ADC\_CTR2IN, where ADC\_CTR2 controls standard conversions and ADC\_CTR2IN controls injected conversions.



# 6.2 ADC Operation

This section describes the various control mechanisms of the ADC.

### 6.2.1 Channel Selection

Bit field ADC\_CON.ADCH or ADC\_CTR0.ADCH controls the input channel multiplexer logic. In the Single Channel Modes, it specifies the analog input channel which is to be converted. In the Auto Scan Modes, it specifies the highest channel number to be converted in the auto scan round.

ADC\_CON.ADCH or ADC\_CTR0.ADCH may be changed while a conversion is in progress. The new value will go into effect after the current conversion is finished in the Fixed Channel Modes, or after the current conversion round is finished in the Auto Scan Modes.

### 6.2.2 ADC Status Flags

The ADC busy status flag (ADC\_CON.ADBSY or ADC.CTR0.ADBSY) is set when the ADC is started (by setting ADC\_CON.ADST or ADC\_CTR0.ADST) and remains set as long as the ADC performs conversions or calibration cycles.

ADC\_CON.ADBSY and ADC\_CTR0.ADBSY are cleared when the ADC is idle, meaning there are no conversion or calibration operations in progress.

Bit ADC\_CON1.SAMPLE or ADC\_CTR0.SAMPLE is set during the sample phase.

# 6.2.3 ADC Start/Stop Control

Bit ADC\_CON.ADST or ADC\_CTR0.ADST is used to start or to stop the ADC. A single conversion or a conversion sequence is started by setting bit ADC\_CON.ADST or ADC\_CTR0.ADST.

The busy flag ADC\_CON.ADBSY or ADC.CTR0.ADBSY will be set and the converter then selects and samples the input channel, which is specified by the channel selection bit field ADC\_CON.ADCH or ADC.CTR0.ADCH. The sampled level will then be held internally during the conversion. When the conversion of this channel is complete, the result is transferred into the result register together with the number of the converted channel and the interrupt request is generated. The conversion result is placed into bit field ADC\_DAT.ADRES.

ADC\_CON.ADST or ADC\_CTR0.ADST remains set until cleared either by hardware or by software. Hardware clears the bit dependent on the conversion mode:

- In Fixed Channel Single Conversion Mode, ADC\_CON.ADST or ADC\_CTR0.ADST is cleared after the conversion of the specified channel is finished.
- In Auto Scan Single Conversion Mode, ADC\_CON.ADST or ADC\_CTR0.ADST is cleared after the conversion of channel 0 is finished.



Note: In the Continuous Conversion Modes, ADC\_CON.ADST or ADC\_CTR0.ADST is never cleared by hardware.

Stopping the ADC via software is performed by clearing bit ADC\_CON.ADST or bit ADC\_CTR0.ADST. The reaction of the ADC depends on the conversion mode:

- In Fixed Channel Single Conversion Mode, the ADC finishes the conversion and then stops. There is no difference to the operation if ADC\_CON.ADST or ADC\_CTR0.ADST was not cleared by software.
- In Fixed Channel Continuous Conversion Mode, the ADC finishes the current conversion and then stops. This is the usual way to terminate this conversion mode.
- In Auto Scan Single Conversion Mode, the ADC continues the auto scan round until the conversion of channel 0 is finished, then it stops. There is no difference to the operation if ADST was not cleared by software.
- In Auto Scan Continuous Conversion Mode, the ADC continues the auto scan round until the conversion of channel 0 is finished, then it stops. This is the usual way to terminate this conversion mode.

A restart of the ADC can be performed by clearing and then setting bit ADC\_CON.ADST or ADC\_CTR0.ADST. This sequence will abort the current conversion and restart the ADC with the new parameters given in the control registers.

# 6.2.4 Conversion Mode Selection

Bit field ADC\_CON.ADM or ADC\_CTR0.ADM selects the conversion mode of the A/D Converter, as listed in **Table 6-1**.

| ADM | Description                              |
|-----|------------------------------------------|
| 00  | Fixed Channel Single Conversion Mode     |
| 01  | Fixed Channel Continuous Conversion Mode |
| 10  | Auto Scan Single Conversion Mode         |
| 11  | Auto Scan Continuous Conversion Mode     |

| Table 6-1         A/D Converter Conversion | Mode |
|--------------------------------------------|------|
|--------------------------------------------|------|

While a conversion is in progress, the mode selection bit field ADC\_CON.ADM or ADC\_CTR0.ADM and the channel selection bit field ADC\_CON.ADCH or ADC\_CTR0.ADCH may be changed. ADC\_CON.ADM or ADC\_CTR0.ADM will be evaluated after the current conversion. ADC\_CON.ADCH or ADC\_CTR0.ADCH will be evaluated after the current conversion (Fixed Channel Modes) or after the current conversion sequence (Auto Scan Modes).



# 6.2.5 Conversion Resolution Control

10-bit either (ADC CON1.RES = 0The ADC can produce а result or  $ADC\_CTR2.RES = 00_{R}$ ) 8-bit  $(ADC_CON1.RES = 1)$ or an result or ADC\_CTR2.RES =  $01_{\rm B}$ ). Depending on the application's requirements, a higher conversion speed (an 8-bit conversion requires less conversion time) or a higher resolution can be chosen.

# 6.2.5.1 Conversion Result

The result of a conversion is stored in the result register ADC\_DAT, or in register ADC\_DAT2 for an injected conversion.

The position of the result depends on the basic operating mode (compatibility or enhanced) and on the selected resolution (8-bit or 10-bit).

Note: Bit field CHNR of register ADC\_DAT is loaded by the ADC to indicate the channel to which the result refers. Bit field CHNR of register ADC\_DAT2 is loaded by software to select the analog channel, which is to be injected.

# 6.2.6 Fixed Channel Conversion Modes

These modes are selected by programming the mode selection bit field ADC\_CON.ADM or ADC\_CTR0.ADM to  $00_B$  (single conversion) or to  $01_B$  (continuous conversion). After starting the converter through setting bit ADC\_CON.ADST or ADC\_CTR0.ADST the busy flag ADC\_CON.ADBSY or ADC\_CTR0.ADBSY will be set and the channel specified in bit field ADC\_CON.ADCH or ADC\_CTR0.ADCH will be converted. After the conversion is complete, an interrupt request trigger (ADC event 0) is generated that can be used to trigger the DMA.

**In Single Conversion Mode** the converter will automatically stop and clears bits ADC\_CON.ADBSY or ADC\_CTR0.ADBSY and ADC\_CON.ADST or ADC\_CTR0.ADST.

**In Continuous Conversion Mode** the converter will automatically start a new conversion of the channel specified in bit field ADC\_CON.ADCH or ADC\_CTR0.ADCH. An interrupt request trigger (ADC event 0) is generated that can be used to trigger the DMA after each completed conversion.

When bit ADC\_CON.ADST or ADC\_CTR0.ADST is cleared by software, while a conversion is in progress, the converter will complete the current conversion and then stop and clear bit ADC\_CON.ADBSY or ADC\_CTR0.ADBSY.

# 6.2.7 Auto Scan Conversion Modes

These modes are selected by programming the mode selection bit field ADC\_CON.ADM or ADC\_CTR0.ADM to  $10_B$  (single conversion) or to  $11_B$  (continuous conversion). Auto Scan Modes automatically convert a sequence of analog channels, beginning with the



channel specified in bit field ADC\_CON.ADCH or ADC\_CTR0.ADCH and ending with channel 0, without requiring software to change the channel number.

After starting the converter through bit ADC\_CON.ADST or ADC\_CTR0.ADST, the busy flag ADC\_CON.ADBSY or ADC\_CTR0.ADBSY will be set and the channel specified in bit field ADC\_CON.ADCH or ADC\_CTR0.ADCH will be converted. After the conversion is completed, an interrupt request trigger (ADC event 0) is generated that can be used to trigger the DMA and the converter will automatically start a new conversion of the next lower channel. After each completed conversion an interrupt trigger is generated. After conversion of channel 0, the current sequence is complete.

**In Single Conversion Mode,** the converter will automatically stop and clear bits ADC\_CON.ADBSY or ADC\_CTR0.ADBSY and ADC\_CON.ADST or ADC\_CTR0.ADST.

**In Continuous Conversion Mode,** the converter will automatically start a new sequence beginning with the conversion of the channel specified in ADC\_CON.ADCH or ADC\_CTR0.ADCH.

When bit ADC\_CON.ADST or ADC\_CTR0.ADST is cleared by software while a conversion is in progress, the converter will complete the current sequence (including conversion of channel 0) and then stop and clear bit ADC\_CON.ADBSY or ADC\_CTR0.ADBSY.



Figure 6-2 Auto Scan Conversion Mode Example

# 6.2.8 Wait for Read Mode

If a previous conversion result has not been read out of the result register by the time a new conversion is complete, the previous result is lost because it is overwritten by the new value, and the error/injection interrupt request trigger is generated.



In order to avoid error/injection interrupts and the loss of conversion results especially when using Continuous Conversion Modes, the ADC can be switched to "Wait for Read Mode" by setting bit ADC\_CON.ADWR or ADC\_CTR0.ADWR.

If the result value has not been read by the time the current conversion is completed, the new result is stored in a temporary buffer and the next conversion is suspended (ADST and ADC\_CON.ADBSY or ADC\_CTR0.ADBSY will remain set in the meantime, but no interrupt will be generated). After reading the previous value, the temporary buffer is copied into ADC\_DAT (generating an interrupt) and the suspended conversion is started. This mechanism applies to both single and Continuous Conversion Modes.

Note: In Standard Mode, continuous conversions are executed at a fixed rate (determined by the conversion time), but, in "Wait for Read Mode" there may be delays due to suspended conversions.



Figure 6-3 Wait for Read Mode Example

# 6.2.9 Channel Injection Mode

Channel Injection Mode allows the conversion of a specific analog channel (also while the ADC is running in a Continuous or Auto Scan Mode) without changing the current operating mode. After the conversion of this specific channel, the ADC continues with the original operating mode.

Channel Injection Mode is enabled by setting bit ADC\_CON.ADCIN or ADC\_CTR0.ADCIN and requires the Wait for Read Mode (ADC\_CON.ADWR = 1 or ADC\_CTR0.ADWR = 1). The channel to be converted in this mode is specified in bit field CHNR of register ADC\_DAT2.



Note: Since the channel number for an injected conversion is not buffered, bit field CHNR of ADC\_DAT2 must never be modified during the sample phase of an injected conversion, otherwise the input multiplexer will switch to the new channel. It is recommended to change the channel number only when no injected conversion is running.



# Figure 6-4 Channel Injection Example

A Channel Injection can be triggered in the following way:

- setting of the Channel Injection Request bit ADC\_CON.ADCRQ or ADC\_CTR0.ADCRQ via software
- Note: The channel injection request bit ADC\_CON.ADCRQ or ADC\_CTR0.ADCRQ will be set regardless of whether or not the Channel Injection Mode is enabled. It is recommended to always clear bit ADC\_CON.ADCRQ or ADC\_CTR0.ADCRQ before enabling the Channel Injection Mode.

After the completion of the current conversion (if any is in progress), the converter will start (inject) the conversion of the specified channel. When the conversion of this channel is completed, the result will be placed into the alternate result register ADC\_DAT2, and a Channel Injection Complete interrupt request trigger (ADC event 1) is generated that can be used to trigger the DMA.

Note: The result of an injected conversion is directly written to ADC\_DAT2. If the previous result has not been read in the meantime, it is overwritten.



# 6.2.10 Arbitration of Conversions

Conversion requests that are activated while the ADC is idle immediately trigger the respective conversion. If a conversion is requested while another conversion is currently in progress, the operation of the A/D converter depends on the type of conversions involved (standard or injected).

Note: A conversion request is activated if the respective control bit (ADC\_CON.ADST / ADC:CTR0.ADST or ADC:CON.ADCRQ / ADC\_CTR0.ADCRQ) is toggled from 0 to 1, i.e. the bit must have been zero before being set.

 Table 6-2 summarizes the ADC operation in the possible situations.

| Conversion<br>in Progress | New Requested Conversion                                                          |                                                                                                                                                                   |  |  |  |  |  |  |  |
|---------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                           | Standard                                                                          | Injected                                                                                                                                                          |  |  |  |  |  |  |  |
| Standard                  | Abort running conversion,<br>and start requested new<br>conversion. <sup>1)</sup> | Complete running conversion, start requested conversion after that.                                                                                               |  |  |  |  |  |  |  |
| Injected                  | Complete running conversion,<br>start requested conversion after<br>that.         | Complete running conversion,<br>start requested conversion after that.<br>Bit ADC_CON.ADCRQ or<br>ADC_CTR0.ADCRQ will be 0 for the<br>second conversion, however. |  |  |  |  |  |  |  |

 Table 6-2
 Conversion Arbitration

1) If an injected conversion is pending when a Standard Conversion is re-started, the injected conversion is executed before the newly started Standard Conversion.



# 6.3 Automatic Calibration

The ADC of the CIC751 features automatic self-calibration. This calibration corrects gain errors, which are mainly due to process variation, and offset errors, which are mainly due to temperature changes.

Two types of calibration are supported:

- Reset calibration performs a thorough basic calibration of the ADC after a power-on reset.
- Post-calibration performs one small calibration step after each conversion.

### **Reset Calibration**

After a reset, a thorough power-up calibration is performed automatically to correct gain and offset errors of the A/D converter. To achieve the best calibration results, the reference voltages as well as the supply voltages must be stable during the power-up calibration. During the calibration sequence, a series of calibration cycles is executed, where the step width for adjustments is reduced gradually. The total number of executed calibration cycles depends on the actual properties of the respective ADC module. The maximum duration of the power-up calibration is 11,696 cycles of the basic clock  $f_{BC}$ .

Status flag ADC\_CON1.CAL is set as long as this power-up calibration takes place.

#### **Post-Calibration**

After each conversion, a small calibration step can be executed. For 8-bit and 10-bit conversions, post-calibration is not mandatory in order not to exceed the total unadjusted error (TUE) specified in the data sheet. Post-calibration can be disabled by setting bit CALOFF in register ADC\_CTR0. When disabled, the post-calibration cycles are skipped, which reduces the total conversion time.

Note: Calibration may be disabled only after the reset calibration is completed.

# 6.4 Multiplexer Test Mode

For analog channel 0, a Multiplexer Test Mode (MTM) is also available. This function is controlled via bit field SCU\_SYSCON.MTM. This feature is independent of the currently selected conversion mode. If the MTM is enabled, the analog input is connected to ADC ground via an internal resistor. This structure creates a voltage divider to ground. Therefore, conversion delivers a smaller result if MTM is enabled.



# 6.5 Conversion Timing Control

When a conversion is started, first the capacitances of the converter are loaded via the respective analog input pin to the current analog input voltage. The time to load the capacitances is referred to as sample time. Next, the sampled voltage is converted to a digital value in successive steps, which correspond to the resolution of the ADC. During these phases (except for the sample time), the internal capacitances are repeatedly charged and discharged via pins  $V_{\text{AREF}}$  and  $V_{\text{AGND}}$ .

The current that must be drawn from the sources for sampling and changing charges depends on the time required for each respective step, because the capacitors must reach their final voltage level within the given time, at least with a certain approximation. The maximum current, however, that a source can deliver, depends on its internal resistance.

The time that the two different actions during conversion take (sampling, and converting) can be programmed within a certain range in the CIC751 relative to the system clock. The absolute time that is consumed by the different conversion steps therefore is independent from the general speed of the device. This allows the A/D converter of the CIC751 to be adjusted to the properties of the system:

**Fast Conversion** can be achieved by programming the respective times to their absolute possible minimum. This is preferable for scanning high frequency signals. The internal resistance of analog source and analog supply must, however, be sufficiently low.

**High Internal Resistance** can be achieved by programming the respective times to a higher value, or to the possible maximum. This is preferable when using analog sources and supply with a high internal resistance in order to keep the current as low as possible. The conversion rate in this case may, however, be considerably lower.

#### **Control Bit Fields**

Two mechanisms are provided for timing control of the conversion and the sample phase:

- **Standard timing control** uses two 2-bit fields in register ADC\_CON to select prescaler values for the general conversion timing and the duration of the sample phase. This provides compact control, while limiting the prescaler factors to a few steps.
- Improved timing control uses two 6-bit fields in register ADC\_CON1 (Compatibility Mode) or register ADC\_CTR2/ADC\_CTR2IN (Enhanced Mode). This provides a wide range of prescaler factors, so the ADC can be better adjusted to the internal and external system circumstances.

Improved timing control is selected by setting bit ICST in register ADC\_CON1 in Compatibility Mode, or by selecting Enhanced Mode.

Note: The conversion clock  $f_{BC}$  must not exceed 20 MHz.



# Standard Timing Control

Standard timing control is performed by using two 2-bit fields in register ADC\_CON. Bit field ADCTC (conversion time control) selects the basic conversion clock ( $f_{BC}$ ), used for the operation of the A/D Converter. The sample time is derived from this conversion clock and controlled by bit field ADSTC. The sample time is always a multiple of 8  $f_{BC}$  periods. Table 6-3 lists the possible combinations.

| ADC_CON.ADCTC   | A/D Converter<br>Basic Clock $f_{\rm BC}$ | ADC_CON.ADSTC   | Sample Time <i>t</i> <sub>S</sub> |
|-----------------|-------------------------------------------|-----------------|-----------------------------------|
| 00 <sub>B</sub> | $f_{ADC}/4$                               | 00 <sub>B</sub> | $t_{\rm BC} \times 8$             |
| 01 <sub>B</sub> | $f_{ADC}/2$                               | 01 <sub>B</sub> | $t_{\rm BC} 	imes$ 16             |
| 10 <sub>B</sub> | <i>f</i> <sub>ADC</sub> /16               | 10 <sub>B</sub> | $t_{\rm BC} 	imes 32$             |
| 11 <sub>B</sub> | <i>f</i> <sub>ADC</sub> /8                | 11 <sub>B</sub> | $t_{\rm BC} 	imes 64$             |

### Table 6-3 Standard Conversion and Sample Timing Control

### Improved Timing Control

To provide a finer resolution for programming of the timing parameters, wider bit fields have been implemented for timing control (the 2-bit bit fields in register ADC\_CON are disregarded in all cases).

In Compatibility Mode (with bit ADC\_CON1.ICST = 1), the bit fields in register ADC\_CON1 are used for all conversions.

In Enhanced Mode (bit ADC\_CTR0.MD = 1), the bit fields in register ADC\_CTR2 are used for Standard Conversions. Injected conversions use the bit fields in register ADC\_CTR2IN.

Bit field ADCTC (conversion time control) selects the basic conversion clock ( $f_{BC}$ ), used for the operation of the A/D Converter. The sample time is derived from this conversion clock and is controlled by bit field ADC\_CTR2.ADSTC. The sample time is always a multiple of 4  $f_{BC}$  periods. Table 6-4 lists the possible combinations.

| ADCTC                                  | A/D Converter<br>Basic Clock $f_{BC}^{1}$ | ADSTC                                  | Sample Time <i>t</i> <sub>S</sub>              |  |  |  |  |
|----------------------------------------|-------------------------------------------|----------------------------------------|------------------------------------------------|--|--|--|--|
| 00 0000 <sub>B</sub> = 00 <sub>H</sub> | <i>f</i> <sub>SYS</sub> /1                | 00 0000 <sub>B</sub> = 00 <sub>H</sub> | $t_{\rm BC} 	imes 8$                           |  |  |  |  |
| $00\ 0001_{B} = 01_{H}$                | f <sub>SYS</sub> /2                       | 00 0001 <sub>B</sub> = 01 <sub>H</sub> | $t_{\rm BC} 	imes$ 12                          |  |  |  |  |
| $00\ 0010_{\rm B} = 02_{\rm H}$        | f <sub>SYS</sub> /3                       | 00 0010 <sub>B</sub> = 02 <sub>H</sub> | $t_{\rm BC} 	imes 16$                          |  |  |  |  |
|                                        | $f_{SYS}/(ADCTC + 1)$                     |                                        | $t_{\rm BC} \times 4 \times ({\rm ADSTC} + 2)$ |  |  |  |  |
| 11 1111 <sub>B</sub> = 3F <sub>H</sub> | f <sub>SYS</sub> /64                      | 11 1111 <sub>B</sub> = 3F <sub>H</sub> | $t_{\rm BC} 	imes 260$                         |  |  |  |  |

 Table 6-4
 Improved Conversion and Sample Timing Control



1) The limit values for  $f_{BC}$  (see data sheet) must not be exceeded when selecting ADC\_CTR2.ADCTC and  $f_{SYS}$ .

#### **Total Conversion Time Examples**

The time for a complete conversion includes the sample time  $t_s$ , the conversion itself (successive approximation and calibration), and the time required to transfer the digital value to the result register as shown in the example below (Standard Conversion timing).

The timings refer to module clock cycles, where  $t_{SYS} = 1/f_{SYS}$ .

- Assumptions:  $f_{SYS} = 40$  MHz (i.e.  $t_{SYS} = 25$  ns), ADC\_CON.ADCTC =  $01_B$ , ADC\_CON.ADSTC =  $00_B$
- Basic clock:  $f_{BC} = f_{SYS}/2 = 20$  MHz, i.e.  $t_{BC} = 50$  ns
- Sample time:  $t_{\rm S} = t_{\rm BC} \times 8 = 400$  ns

Conversion 10-bit:

- With post-calibr.:  $t_{C10P} = t_{S} + 52 \times t_{BC} + 6 \times t_{SYS} = (2600 + 400 + 150) \text{ ns} = 3.15 \,\mu\text{s}$
- Post-calibr. off:  $t_{C10} = t_{S} + 40 \times t_{BC} + 6 \times t_{SYS} = (2000 + 400 + 150) \text{ ns} = 2.55 \ \mu\text{s}$

Conversion 8-bit:

- With post-calibr.:  $t_{C8P} = t_{S} + 44 \times t_{BC} + 6 \times t_{SYS} = (2200 + 400 + 150) \text{ ns} = 2.75 \,\mu\text{s}$
- Post-calibr. off:  $t_{C8} = t_{S} + 32 \times t_{BC} + 6 \times t_{SYS} = (1600 + 400 + 150) \text{ ns} = 2.15 \,\mu\text{s}$

Note: For the exact specification, refer to the data sheet of the selected derivative.



# 6.6 A/D Converter Interrupt Operation

The ADC offers different interrupts request triggers that can occur due to different cases:

- End-of-conversion interrupt (ADC event 0)
- the result of a conversion is placed into register ADC\_DAT
- Error/injection interrupt (ADC event 1)
  - a conversion result overwrites a previous value in register ADC\_DAT (error interrupt in standard mode)
  - the result of an injected conversion has been stored into ADC\_DAT2 (end-ofinjected-conversion interrupt)
- ADC event 2; the OR-combination of all valid bits of the ADC\_RESBn registers

# 6.6.1 Interrupt Event Handling

Interrupt events can be handled in three different ways:

- Trigger an DMA action
- Forward the interrupt to pin SRn

# 6.6.1.1 Trigger an DMA Action

Both ADC interrupts can be used to trigger a DMA transfer. This mechanism can be used to store the conversion result within a extended result register.

Note: For more information about triggering a DMA transfer, see Chapter 3.1.

# 6.6.1.2 Forward to an SRn Pin

An ADC interrupt can be forwarded to a host controller via an SRn pin of the CIC751.

The following events can be selected as the source for an output of an SRn pin:

- An end-of-conversion interrupt was triggered
- An error/injection interrupt was triggered

Note: For information about routing an interrupt to an SRn pin, see Chapter 2.5.3.1.



# 6.7 ADC Buffer Registers

This section describes the extended result register, including the control and input register and the doorbell mechanism.

# 6.7.1 Overview

The ADC module offers the possibility of storing two results in its data registers. The result of the injected conversion is stored in register DAT2, whereas all other results (auto scan or single programmed conversions) are stored in register DAT.

In order to make all results available at the same time, additional result registers are added. As the ADC has 16 analog input channels, the same number of result registers is necessary to store the results of each single channel.

The data transfer between the standard ADC result registers and the extended result registers is performed by an interrupt request to the DMA.



Figure 6-5 Extended ADC Result Registers



Each of the 16 extended result registers contains a RESULT bit field with the conversion result delivered by the ADC. The ADC extended result registers also indicate the channel number belonging to the result.

# 6.7.2 Extended Result Registers

After being triggered, the DMA reads a 16-bit data word from the register DAT in the ADC and writes it to the input result register INRES. A 16-bit data word written to this register is transferred automatically to one of the 16 result registers. The upper 4 bits written to INRES indicate the number of the target result register.

Each result register has an associated valid bit RESBn.V. The valid bit of a result register is automatically set if data is transferred to it. The valid bit is automatically cleared if the result register is read out. As a result, the valid bit indicates that new data is available, that has not yet been read out.

In order to allow different read modes, two different 16-bit read views exist, selected by two different read address (one view (view A) shows the same bit positions as the original ADC register, the other view (view B) shows the valid bit instead of the channel number) so the user can do polling to check for new data in view B. This view B can be accessed when reading the second set of addresses.

The input register for the 16 result registers is INRES. Any write access to this address will lead to an update of the corresponding result register. The bit positions [15:12] of the written data are used as pointer to indicate the targeted result register.

All 16 valid bits of the different result registers RESBn are additionally accessible by a single status register RESV. This enable the host to verify easily which result register has valid date and which not.

# 6.7.3 Doorbell Mechanism

The doorbell mechanism offers a monitoring system for the extended result registers. Two doorbell channels are implemented, each with an individual sensitivity level. The sensitivity level can be configured to monitor one of the 16 extended result registers via ADC\_DBCTR.COMP0 or ADC\_DBCTR.COMP0.

The doorbell mechanism can be used to trigger either a DMA transfer or to stimulate an SRn pin.

# 6.7.3.1 Trigger an DMA Transfer

If a extended result register that is monitored by a doorbell channel is updated via register ADC\_INRES, the doorbell channel generates a trigger that can be used to request an DMA transfer.

Note: Please note that writing to register ADC:INRES updates both views of a extended result register.



Note: For more information about the control of DMA transfer triggers, see Chapter 3.1.

This mechanism can be used to create a sensitivity level for the start of the block ADC conversion result data download to the host controller for Auto Scan conversions.

# 6.7.3.2 Stimulate SRn Pins

The status valid bit of the extended result register that is monitored by a doorbell channel can be forwarded to an SRn pin. This offers an additional opportunity for supervision of the extended result registers.

Note: For information about routing a valid bit to an SRn pin, see Chapter 2.5.3.1.



# 6.8 ADC Registers

 Table 6-5 summarizes all ADC registers.

The base address of the ADC is 0000 1000. A register address is computed by adding the base address to the register offset address.

|                        | Registers Overview                    |                   |                |
|------------------------|---------------------------------------|-------------------|----------------|
| Register<br>Short Name | Register Long Name                    | Offset<br>Address | Page<br>Number |
| ADC_CON                | ADC Control Register                  | 10 <sub>H</sub>   | Page 6-21      |
| ADC_CON1               | ADC Control 1 Register                | 12 <sub>H</sub>   | Page 6-23      |
| ADC_CTR0               | ADC Control 0 Register                | 24 <sub>H</sub>   | Page 6-24      |
| ADC_CTR2               | ADC Control 2 Register                | 20 <sub>H</sub>   | Page 6-25      |
| ADC_<br>CTR2IN         | ADC Injection Control 2 Register      | 22 <sub>H</sub>   | Page 6-26      |
| ADC_DAT                | ADC Result Register                   | 30 <sub>H</sub>   | Page 6-27      |
| ADC_DAT2               | ADC Result 2 Register                 | 32 <sub>H</sub>   | Page 6-27      |
| ADC_<br>RESA0          | ADC Extended Result 0 View A Register | 100 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA1          | ADC Extended Result 1 View A Register | 104 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA2          | ADC Extended Result 2 View A Register | 108 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA3          | ADC Extended Result 3 View A Register | 10C <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA4          | ADC Extended Result 4 View A Register | 110 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA5          | ADC Extended Result 5 View A Register | 114 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA6          | ADC Extended Result 6 View A Register | 118 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA7          | ADC Extended Result 7 View A Register | 11C <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA8          | ADC Extended Result 8 View A Register | 120 <sub>H</sub>  | Page 6-30      |
| ADC_<br>RESA9          | ADC Extended Result 9 View A Register | 124 <sub>H</sub>  | Page 6-30      |

#### Table 6-5Registers Overview



| l able 6-5             | Registers Overview (cont'd)            |                   |                |  |  |  |  |  |  |  |  |
|------------------------|----------------------------------------|-------------------|----------------|--|--|--|--|--|--|--|--|
| Register<br>Short Name | Register Long Name                     | Offset<br>Address | Page<br>Number |  |  |  |  |  |  |  |  |
| ADC_<br>RESA10         | ADC Extended Result 10 View A Register | 128 <sub>H</sub>  | Page 6-30      |  |  |  |  |  |  |  |  |
| ADC_<br>RESA11         | ADC Extended Result 11 View A Register | 12C <sub>H</sub>  | Page 6-30      |  |  |  |  |  |  |  |  |
| ADC_<br>RESA12         | ADC Extended Result 12 View A Register | 130 <sub>H</sub>  | Page 6-30      |  |  |  |  |  |  |  |  |
| ADC_<br>RESA13         | ADC Extended Result 13 View A Register | 134 <sub>H</sub>  | Page 6-30      |  |  |  |  |  |  |  |  |
| ADC_<br>RESA14         | ADC Extended Result 14 View A Register | 138 <sub>H</sub>  | Page 6-30      |  |  |  |  |  |  |  |  |
| ADC_<br>RESA15         | ADC Extended Result 15 View A Register | 13C <sub>H</sub>  | Page 6-30      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB0          | ADC Extended Result 0 View B Register  | 140 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB1          | ADC Extended Result 1 View B Register  | 144 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB2          | ADC Extended Result 2 View B Register  | 148 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB3          | ADC Extended Result 3 View B Register  | 14C <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB4          | ADC Extended Result 4 View B Register  | 150 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB5          | ADC Extended Result 5 View B Register  | 154 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB6          | ADC Extended Result 6 View B Register  | 158 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB7          | ADC Extended Result 7 View B Register  | 15C <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB8          | ADC Extended Result 8 View B Register  | 160 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB9          | ADC Extended Result 9 View B Register  | 164 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |
| ADC_<br>RESB10         | ADC Extended Result 10 View B Register | 168 <sub>H</sub>  | Page 6-32      |  |  |  |  |  |  |  |  |

#### Table 6-5 Registers Overview (cont'd)



| Register<br>Short Name | Register Long Name                     | Offset<br>Address | Page<br>Number |
|------------------------|----------------------------------------|-------------------|----------------|
| ADC_<br>RESB11         | ADC Extended Result 11 View B Register | 16C <sub>H</sub>  | Page 6-32      |
| ADC_<br>RESB12         | ADC Extended Result 12 View B Register | 170 <sub>H</sub>  | Page 6-32      |
| ADC_<br>RESB13         | ADC Extended Result 13 View B Register | 174 <sub>H</sub>  | Page 6-32      |
| ADC_<br>RESB14         | ADC Extended Result 14 View B Register | 178 <sub>H</sub>  | Page 6-32      |
| ADC_<br>RESB15         | ADC Extended Result 15 View B Register | 17C <sub>H</sub>  | Page 6-32      |
| ADC_<br>INRES          | ADC Input Result Register              | 180 <sub>H</sub>  | Page 6-33      |
| ADC_<br>RESV           | ADC Result Valid Register              | 188 <sub>H</sub>  | Page 6-34      |
| ADC_<br>DBCTR          | ADC Doorbell Control Register          | 184 <sub>H</sub>  | Page 6-35      |

#### Table 6-5 Registers Overview (cont'd)

# 6.8.1 ADC Control Registers for Compatibility Mode

The following registers are used in the Compatibility Mode to configure the ADC module.

#### ADC\_CON ADC Control Register

| ADC Control Register |       |    |           |     |    |           | (010 <sub>H</sub> ) |           |          |   |   | Reset Value: 0000 <sub>H</sub> |   |    |    |   |
|----------------------|-------|----|-----------|-----|----|-----------|---------------------|-----------|----------|---|---|--------------------------------|---|----|----|---|
|                      | 15    | 14 | 13        | 12  | 11 | 10        | 9                   | 8         | 7        | 6 | 5 | 4                              | 3 | 2  | 1  | 0 |
|                      | ADCTC |    | C ADSTC A |     |    | AD<br>CIN | AD<br>WR            | AD<br>BSY | AD<br>ST | 0 | A | M                              |   | AD | СН |   |
| rw                   |       | r١ | W         | rwh | rw | rw        | rh                  | rwh       | r        | n | N | rw                             |   | W  |    |   |

| Field | Bits  | Туре | Description                                                                                        |
|-------|-------|------|----------------------------------------------------------------------------------------------------|
| ADCH  | [3:0] | rw   | ADC Analog Channel Input Selection<br>Selects the (first) ADC channel which is to be<br>converted. |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                          |
|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADM   | [5:4]   | rw   | <ul> <li>ADC Mode Selection</li> <li>00 Fixed Channel Single Conversion</li> <li>01 Fixed Channel Continuous Conversion</li> <li>10 Auto Scan Single Conversion</li> <li>11 Auto Scan Continuous Conversion</li> </ul>                               |
| ADST  | 7       | rwh  | ADC Start Bit0Stop a running conversion1Start conversion(s)                                                                                                                                                                                          |
| ADBSY | 8       | rh   | ADC Busy Flag0ADC is idle1A conversion is active                                                                                                                                                                                                     |
| ADWR  | 9       | rw   | <ul> <li>ADC Wait for Read Control</li> <li>Wait for Read Mode is deactivated</li> <li>Wait for Read Mode is activated</li> </ul>                                                                                                                    |
| ADCIN | 10      | rw   | <ul> <li>ADC Channel Injection Enable</li> <li>0 Channel Injection is disabled</li> <li>1 Channel Injection is enabled</li> </ul>                                                                                                                    |
| ADCRQ | 11      | rwh  | <ul> <li>ADC Channel Injection Request Flag</li> <li>0 No Channel Injection request is pending</li> <li>1 A Channel Injection request is pending</li> <li>This bit is automatically cleared if a Channel Injection conversion is started.</li> </ul> |
| ADSTC | [13:12] | rw   | ADC Sample Time Control(Defines the ADC sample time in a certain range) $00$ $t_{BC} \times 8$ $01$ $t_{BC} \times 16$ $10$ $t_{BC} \times 32$ $11$ $t_{BC} \times 64$                                                                               |
| ADCTC | [15:14] | rw   | ADC Conversion Time Control(Defines the ADC basic conversion clock $f_{BC}$ )00 $f_{BC} = f_{SYS}/4$ 01 $f_{BC} = f_{SYS}/2$ 10 $f_{BC} = f_{SYS}/16$ 11 $f_{BC} = f_{SYS}/8$                                                                        |
| 0     | 6       | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                                                                             |



| ADC<br>ADC |            |     | Regis | ster |       | (012 <sub>H</sub> ) |   |   |   |   |   | Res | et Va | lue: ( | 0000 <sub>H</sub> |
|------------|------------|-----|-------|------|-------|---------------------|---|---|---|---|---|-----|-------|--------|-------------------|
| 15         | 14         | 13  | 12    | 11   | 10    | 9                   | 8 | 7 | 6 | 5 | 4 | 3   | 2     | 1      | 0                 |
| ICST       | SAM<br>PLE | CAL | RES   |      | ADCTC |                     |   |   |   |   | ļ | AD  | STC   | 1      |                   |
| rw         | rh         | rh  | rw    | rw   |       |                     |   |   |   |   | 1 | r   | W     |        | ļ]                |

| Field  | Bits   | Туре | Description                                                                                                                                                                                                                                                                                                       |
|--------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADSTC  | [5:0]  | rw   | ADC Sample Time Control<br>Defines the ADC sample time:<br>$t_{\rm S} = t_{\rm BC} \times 4 \times (<\text{ADSTC}> + 1)$                                                                                                                                                                                          |
| ADCTC  | [11:6] | rw   | ADC Conversion Time Control<br>Defines the ADC basic conversion clock:<br>$f_{BC} = f_{SYS} / ( + 1)$                                                                                                                                                                                                             |
| RES    | 12     | rw   | Conversion Resolution Control010-bit resolution (default after reset)18-bit resolution                                                                                                                                                                                                                            |
| CAL    | 13     | rh   | Reset Calibration Phase Status Flag0A/D Converter is not in calibration phase1A/D Converter is in calibration phase                                                                                                                                                                                               |
| SAMPLE | 14     | rh   | Sample Phase Status Flag0A/D Converter is not in sampling1A/D Converter is currently in the sample phase                                                                                                                                                                                                          |
| ICST   | 15     | rw   | Improved Conversion and Sample TimingSelects the active timing control bit fields0Standard Conversion and sample time control,<br>controlled by the two bit fieldsADC_CON.ADCH and ADC_CON.ADM1Improved conversion and sample time control,<br>controlled by the two bit fields1ADC_CON1.ADCTC and ADC_CON1.ADCTC |

Note: The limit values for  $f_{\rm BC}$  (see data sheet) must not be exceeded when selecting ADCTC and  $f_{\rm SYS}$ .



# 6.8.2 ADC Control Registers for Enhanced Mode

The following registers are used in the Enhanced Mode to configure the ADC module.

| -  | ADC_CTR0<br>ADC Control 0 Register (024 <sub>H</sub> ) Reset Value: 1000 <sub>H</sub> |    |     |           |           |          |           |          |     |      |            |   |    |    | 1000 <sub>H</sub> |
|----|---------------------------------------------------------------------------------------|----|-----|-----------|-----------|----------|-----------|----------|-----|------|------------|---|----|----|-------------------|
| 15 | 14                                                                                    | 13 | 12  | 11        | 10        | 9        | 8         | 7        | 6   | 5    | 4          | 3 | 2  | 1  | 0                 |
| MD | SAM<br>PLE                                                                            | AD | стѕ | AD<br>CRQ | AD<br>CIN | AD<br>WR | AD<br>BSY | AD<br>ST | ADM |      | CAL<br>OFF |   | AD | СН | 1                 |
| rw | rh                                                                                    | r  | w   | rwh       | rw        | rw       | rh        | rwh      | r   | v rw |            |   | r  | N  | 1                 |

| Field  | Bits  | Туре | Description                                                                                                                                                |
|--------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADCH   | [3:0] | rw   | Analog Input Channel Selection<br>Selects the (first) ADC channel which is to be<br>converted                                                              |
| CALOFF | 4     | rw   | Calibration Disable Control0Calibration cycles are executed1Calibration is disabled (off)                                                                  |
|        |       |      | Note: This control bit is active in both compatibility and Enhanced Mode.                                                                                  |
| ADM    | [6:5] | rw   | Mode Selection Control00Fixed Channel Single Conversion01Fixed Channel Continuous Conversion10Auto Scan Single Conversion11Auto Scan Continuous Conversion |
| ADST   | 7     | rwh  | ADC Start/Stop Control0Stop a running conversion1Start conversion(s)                                                                                       |
| ADBSY  | 8     | rh   | Busy Flag0ADC is idle1A conversion is active                                                                                                               |
| ADWR   | 9     | rw   | <ul> <li>ADC Wait for Read Control</li> <li>Wait for Read Mode is deactivated</li> <li>Wait for Read Mode is activated</li> </ul>                          |
| ADCIN  | 10    | rw   | <ul> <li>ADC Channel Injection Enable</li> <li>0 Channel Injection is disabled</li> <li>1 Channel Injection is enabled</li> </ul>                          |



| Field  | Bits    | Туре | Description                                                                                                                                                                                                                                          |
|--------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADCRQ  | 11      | rwh  | <ul> <li>ADC Channel Injection Request Flag</li> <li>0 No Channel Injection request is pending</li> <li>1 A Channel Injection request is pending</li> <li>This bit is automatically cleared if a Channel Injection conversion is started.</li> </ul> |
| ADCTS  | [13:12] | rw   | Channel Injection Trigger Input Select00Channel injection trigger input disabled01Trigger input CAPCOM2 selected10Trigger input CAPCOM6 selected11ReservedNote: Reset value of bit field ADCTS is 01 <sub>B</sub> for                                |
|        |         |      | compatibility purposes.                                                                                                                                                                                                                              |
| SAMPLE | 14      | rh   | Sample Phase Status Flag0A/D Converter is not in sample phase1A/D Converter in sample phase                                                                                                                                                          |
| MD     | 15      | rw   | Mode Control0Compatibility Mode1Enhanced ModeNote: Any modification of control bit MD is forbidden<br>while a conversion is currently running. User<br>software must take care.                                                                      |

| ADC<br>ADC | _CTR<br>Cont |    | Regis | ster |    |    | (02 | 20 <sub>H</sub> ) |   |  | Res | et Va | lue: ( | 0000 <sub>H</sub> |   |
|------------|--------------|----|-------|------|----|----|-----|-------------------|---|--|-----|-------|--------|-------------------|---|
| 15         | 14           | 13 | 12    | 11   | 10 | 9  | 8   | 8 7 6             |   |  | 4   | 3     | 2      | 1                 | 0 |
|            | 0            | RI | ES    |      |    | AD | СТС | Γ                 | ſ |  | ſ   | AD    | STC    | Γ                 |   |
|            | r            | r  | w     |      | rw |    |     | 1                 | 1 |  | rw  |       |        |                   |   |

| Field | Bits   | Туре | Description                                                                                                               |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------|
| ADSTC | [5:0]  | rw   | ADC Sample Time Control<br>Defines the ADC sample time:<br>$t_{\rm S} = t_{\rm BC} \times 4 \times (< {\rm ADSTC} > + 1)$ |
| ADCTC | [11:6] | rw   | ADC Conversion Time Control<br>Defines the ADC basic conversion clock:<br>$f_{BC} = f_{SYS} / ( + 1)$                     |



| Field | Bits    | Туре | Description                                                                 |
|-------|---------|------|-----------------------------------------------------------------------------|
| RES   | [13:12] | rw   | Converter Resolution Control0010-bit resolution018-bit resolution1xReserved |
| 0     | [15:14] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                    |

#### ADC\_CTR2IN

| ADC Injection Control 2 Register |                     |   |      |       |  |   | (02 | 2 <sub>H</sub> ) |       |    |   | Reset Value: 0000 <sub>H</sub> |   |   |  |  |
|----------------------------------|---------------------|---|------|-------|--|---|-----|------------------|-------|----|---|--------------------------------|---|---|--|--|
| 15                               | 15 14 13 12 11 10 9 |   |      |       |  | 8 | 7   | 6                | 5     | 4  | 3 | 2                              | 1 | 0 |  |  |
| (                                | 0 RES               |   |      | ADCTC |  |   |     |                  | ADSTC |    |   |                                |   |   |  |  |
| l                                | r                   | r | w rw |       |  | W |     |                  |       | rw |   |                                |   |   |  |  |

| Field | Bits    | Туре | Description                                                                                                               |
|-------|---------|------|---------------------------------------------------------------------------------------------------------------------------|
| ADSTC | [5:0]   | rw   | ADC Sample Time Control<br>Defines the ADC sample time:<br>$t_{\rm S} = t_{\rm BC} \times 4 \times (< {\rm ADSTC} > + 1)$ |
| ADCTC | [11:6]  | rw   | ADC Conversion Time Control<br>Defines the ADC basic conversion clock:<br>$f_{BC} = f_{SYS} / ( + 1)$                     |
| RES   | [13:12] | rw   | Converter Resolution Control0010-bit resolution018-bit resolution1xReserved                                               |
| 0     | [15:14] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                  |

Note: The limit values for  $f_{\rm BC}$  (see data sheet) must not be exceeded when selecting ADCTC and  $f_{\rm SYS}$ .



# 6.8.3 ADC Result Registers

The following registers are used in the Compatibility Mode and Enhanced Mode for storage of the last conversion result.

# ADC\_DAT

| ADC | Resu | lt Re | giste | r  |    |   | (03 | 80 <sub>H</sub> ) |     |     | Reset Value: 0000 |   |   |   |   |
|-----|------|-------|-------|----|----|---|-----|-------------------|-----|-----|-------------------|---|---|---|---|
| 15  | 14   | 13    | 12    | 11 | 10 | 9 | 8   | 7                 | 6   | 5   | 4                 | 3 | 2 | 1 | 0 |
|     | СН   | NR    | 1     |    | 1  | 1 | 1   | 1                 | ADF | RES | 1                 | 1 | 1 | 1 | 1 |
|     | rv   | vh    |       |    | •  |   |     |                   | rv  | vh  |                   |   |   | • |   |

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                         |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADRES | [11:0]  | rwh  | A/D Conversion Result<br>The digital result of the most recent conversion.<br>In Compatibility Mode, the result is placed as follows:<br>8-bit: ADRES[9:2]<br>10-bit: ADRES[9:0]<br>In Enhanced Mode, the result is placed as follows:<br>8-bit: ADRES[11:4]<br>10-bit: ADRES[11:2] |
| CHNR  | [15:12] | rwh  | Note: Unused bits of ADRES are always set to 0. Channel Number                                                                                                                                                                                                                      |
| CHNK  | [13.12] |      | This bit field identifies the converted analog channel.                                                                                                                                                                                                                             |

|   | -  | _DAT<br>Resu |     | egist | er |    |   | (03 | 82 <sub>H</sub> ) |    |    | Reset Value: 0000 <sub>H</sub> |    |    |   |   |
|---|----|--------------|-----|-------|----|----|---|-----|-------------------|----|----|--------------------------------|----|----|---|---|
| Г | 15 | 14           | 13  | 12    | 11 | 10 | 9 | 8   | 7                 | 6  | 5  | 4                              | 3  | 2  | 1 | 0 |
|   |    | СН           | INR |       |    |    |   |     |                   |    |    |                                |    |    |   |   |
| L | rw |              |     |       |    |    |   | I   | I                 | rv | vh | 1                              | .[ | .[ | I |   |



| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                       |
|-------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADRES | [11:0]  | rwh  | <ul> <li>A/D Conversion Result The digital result of the most recent conversion. In Compatibility Mode, the result is placed as follows: 8-bit: ADRES[9:2] 10-bit: ADRES[9:0] In Enhanced Mode, the result is placed as follows: 8-bit: ADRES[11:4] 10-bit: ADRES[11:2] Note: Unused bits of ADRES are always set to 0.</li></ul> |
| CHNR  | [15:12] | rw   | Channel Number           This bit field identifies the converted analog channel.                                                                                                                                                                                                                                                  |



# 6.8.4 ADC Extended Result Registers

The following registers can be used in the Compatibility Mode and Enhanced Mode for storage of the conversion results.



| ADC | RES                                                                   | A0   |       |         |       |       |        |                     |                   |     |                                     |                |                                         |         |                               |  |  |  |
|-----|-----------------------------------------------------------------------|------|-------|---------|-------|-------|--------|---------------------|-------------------|-----|-------------------------------------|----------------|-----------------------------------------|---------|-------------------------------|--|--|--|
|     |                                                                       |      | Resu  | lt 0 V  | iew A | A Reg | jister | (100 <sub>H</sub>   | )                 |     | Res                                 | et Va          | lue: 0                                  | 000 0   | 0000 <sub>H</sub>             |  |  |  |
| -   | _RES                                                                  |      | Deeu  | 14 A V  |       |       |        | 404                 |                   |     | Dee                                 | - <b>1</b> / - | O                                       |         | 000                           |  |  |  |
|     | RES                                                                   |      | Resu  | IT 1 V  | Iew A | A Reg | lister | (104 <sub>H</sub>   | )                 |     | Res                                 | et va          | iue: u                                  | 1000 1  | 000 <sub>H</sub>              |  |  |  |
| -   |                                                                       |      | Resu  | lt 2 V  | iew A | Reg   | ister  | (108 <sub>1</sub> ) | )                 |     | Res                                 | et Va          | lue: 0                                  | 000 2   | 2000 <sub>11</sub>            |  |  |  |
|     | _RES                                                                  |      |       |         |       | U     |        | · · · ·             |                   |     | Reset Value: 0000 2000 <sub>H</sub> |                |                                         |         |                               |  |  |  |
|     |                                                                       |      | Resu  | lt 3 V  | iew A | Reg   | jister | (10C <sub>H</sub>   | )                 |     | Res                                 | et Va          | lue: 0                                  | 000 3   | 8000 <sub>H</sub>             |  |  |  |
| -   |                                                                       |      | Deeu  | II A \/ |       | Dee   | liotor | (440)               | 、                 |     | Bee                                 |                | lue. (                                  |         | 1000                          |  |  |  |
|     |                                                                       |      | Resu  | IC 4 V  | iew P | кед   | ister  | (IIU <sub>H</sub>   | )                 |     | Res                                 | etva           | lue: u                                  | 4000 4  | юоо <sub>н</sub>              |  |  |  |
| -   | ADC Extended Result 5 View A Register(114 <sub>H</sub> )              |      |       |         |       |       |        |                     |                   |     |                                     |                | lue: 0                                  | 000 5   | 5000 <sub>н</sub>             |  |  |  |
| -   | ADC_RESA6                                                             |      |       |         |       |       |        |                     |                   |     |                                     |                |                                         |         |                               |  |  |  |
|     | ADC Extended Result 6 View A Register(118 <sub>H</sub> )<br>ADC RESA7 |      |       |         |       |       |        |                     |                   |     |                                     |                | lue: 0                                  | 000 6   | 6000 <sub>Н</sub>             |  |  |  |
| -   |                                                                       |      | Pocul |         | Pos   | ot Va | luo: 0 | 000 7               | 7000 <sub>H</sub> |     |                                     |                |                                         |         |                               |  |  |  |
|     | ADC Extended Result 7 View A Register(11C <sub>H</sub> )<br>ADC_RESA8 |      |       |         |       |       |        |                     |                   |     |                                     |                | iue. u                                  | 000 /   | 000 <sub>H</sub>              |  |  |  |
| -   | ADC_RESA6<br>ADC Extended Result 8 View A Register(120 <sub>H</sub> ) |      |       |         |       |       |        |                     |                   |     |                                     |                | Reset Value: 0000 8000 <sub>H</sub>     |         |                               |  |  |  |
| -   | ADC_RESA9                                                             |      |       |         |       |       |        |                     |                   |     |                                     |                | <br>Reset Value: 0000 9000 <sub>н</sub> |         |                               |  |  |  |
|     |                                                                       |      | Resu  | lt 9 V  | iew A | Reg   | jister | (124 <sub>H</sub> ) | )                 |     | Res                                 | et Va          | lue: 0                                  | 000 9   | 9000 <sub>H</sub>             |  |  |  |
| -   | _RES                                                                  |      | Resu  | 14 10   | Viow  |       | aisto  | r/178               | `                 |     | Pas                                 | ot Va          | luo: 0                                  | <u></u> | 000                           |  |  |  |
|     | RES                                                                   |      | Nesu  |         | VICW  | ANC   | giste  | 1(120               | HJ                |     | Reset Value: 0000 A000 <sub>H</sub> |                |                                         |         |                               |  |  |  |
| -   |                                                                       |      | Resu  | lt 11   | View  | A Re  | giste  | r(12C               | ; <sub>H</sub> )  |     | Res                                 | et Va          | lue: 0                                  | 000 E   | 8000 <sub>н</sub>             |  |  |  |
| -   | _RES                                                                  |      |       |         |       |       |        |                     |                   |     |                                     |                |                                         |         |                               |  |  |  |
|     |                                                                       |      | Resu  | lt 12   | View  | A Re  | giste  | r(130               | н)                |     | Res                                 | et Va          | lue: 0                                  | 000 C   | :000 <sub>Н</sub>             |  |  |  |
| -   | _RES                                                                  |      | Resu  | 1+ 13   | Viow  |       | aista  | r/13/               | `                 |     | Ras                                 | ot Va          | ۰ میںا                                  | 000 F   | 000                           |  |  |  |
|     | RES                                                                   |      | Nesu  | 11 15   |       | ANC   | giste  | 1(134               | HJ                |     | Reset Value: 0000 D000 <sub>H</sub> |                |                                         |         |                               |  |  |  |
| -   |                                                                       |      | Resu  | lt 14   | View  | A Re  | giste  | r(138               | н)                |     | Res                                 | et Va          | lue: 0                                  | 000 E   | Е <b>000</b> н                |  |  |  |
| -   | _RES                                                                  |      |       |         |       |       |        |                     |                   |     |                                     |                |                                         |         |                               |  |  |  |
| ADC | Exte                                                                  | nded | Resu  | lt 15   | View  | A Re  | giste  | r(13C               | ; <sub>H</sub> )  |     | Res                                 | et Va          | lue: 0                                  | 000 F   | <sup>-</sup> 000 <sub>Н</sub> |  |  |  |
| 31  | 30                                                                    | 29   | 28    | 27      | 26    | 25    | 24     | 23                  | 22                | 21  | 20                                  | 19             | 18                                      | 17      | 16                            |  |  |  |
|     | I                                                                     | Ι    | 1 1   |         | Ι     | I     |        | 0                   | 1                 | Ι   | Ι                                   | T              | 1                                       |         |                               |  |  |  |
|     | 1                                                                     |      | 1 1   |         | 1     |       | 1      | 1                   | 1                 | l   | 1                                   | 1              | 1                                       |         |                               |  |  |  |
| 15  | 14                                                                    | 13   | 12    | 11      | 10    | 9     | 8      | r<br>7              | 6                 | 5   | 4                                   | 3              | 2                                       | 1       | 0                             |  |  |  |
|     | СН                                                                    | NR   | I     |         | I     | I     | 1      | 1                   | RES               | ULT | I                                   | 1              | 1                                       | I       |                               |  |  |  |
|     | 1                                                                     | ·-   | 1     |         | 1     |       | 1      | 1                   | 1                 | 1   | 1                                   | 1              | 1                                       |         |                               |  |  |  |
|     | l                                                                     | I    |       |         |       |       |        |                     | r                 | h   |                                     |                |                                         |         |                               |  |  |  |



| Field  | Bits    | Туре | Description                                                                                                                                                                                                                                                           |
|--------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESULT | [11:0]  | rh   | Conversion Result<br>This bit field represents the conversion result for the<br>selected channel.<br>If the conversion result is smaller than 10 bits, the<br>result always starts with its MSB at bit position 11 and<br>the unused bit positions are filled with 0. |
| CHNR   | [15:12] | r    | Channel Number<br>This bit field indicates the channel number.                                                                                                                                                                                                        |
| 0      | [31:16] | r    | Reserved;<br>Read as 0; should be written with 0.                                                                                                                                                                                                                     |



| ADC_  |                                                                                             |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
|-------|---------------------------------------------------------------------------------------------|-----|------|--------|-------|-------|--------|------------------|------------------|-------------------|-------------------------------------|-------|--------|--------|-------------------|--|
| ADC E | Exten                                                                                       | ded | Resu | lt 0 V | iew E | 8 Reg | ister( | 140 <sub>H</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000   | 0000 <sub>Н</sub> |  |
| ADC_  |                                                                                             |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 1 V | iew E | 8 Reg | ister( | 144 <sub>H</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>Н</sub> |  |
| ADC_  |                                                                                             |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 2 V | iew E | 8 Reg | ister( | 148 <sub>H</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>Н</sub> |  |
| ADC_  | RESE                                                                                        | 33  |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 3 V | iew E | 8 Reg | ister( | 14C <sub>H</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>Н</sub> |  |
| ADC_  | RESE                                                                                        | 34  |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 4 V |       | Res   | et Va  | lue: (           | 0000 (           | 0000 <sub>Н</sub> |                                     |       |        |        |                   |  |
| ADC_  | C_RESB5                                                                                     |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | DC Extended Result 5 View B Register(154 <sub>H</sub> ) Reset Value: 0000 0000 <sub>H</sub> |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC_  | C_RESB6                                                                                     |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Extended Result 6 View B Register(158 <sub>H</sub> ) Reset Value: 0000 0000 <sub>H</sub>    |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC_  | DC_RESB7                                                                                    |     |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 7 V | iew E | 8 Reg | ister( | 15C <sub>н</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>н</sub> |  |
| ADC_  | RESE                                                                                        | 88  |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 8 V | iew E | 8 Reg | ister( | 160 <sub>H</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>н</sub> |  |
| ADC_  | RESE                                                                                        | 39  |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 9 V | iew E | 8 Reg | ister( | 164 <sub>H</sub> | )                |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>н</sub> |  |
| ADC_  | RESE                                                                                        | 310 |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 10  | View  | B Re  | giste  | r(168            | н)               |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>Н</sub> |  |
| ADC_  | RESE                                                                                        | 811 |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 11  | View  | B Re  | giste  | r(16C            | ; <sub>н</sub> ) |                   | Reset Value: 0000 0000 <sub>H</sub> |       |        |        |                   |  |
| ADC_  | RESE                                                                                        | 812 |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 12  | View  | B Re  | giste  | r(170            | н)               |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>Н</sub> |  |
| ADC_  | RESE                                                                                        | 813 |      |        |       |       |        |                  |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 13  | View  | B Re  | giste  | r(174            | н)               |                   | Res                                 | et Va | lue: ( | 0000 ( | 0000 <sub>н</sub> |  |
| ADC_  | RESE                                                                                        | 314 |      |        |       |       | -      | -                |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 14  | View  | B Re  | giste  | r(178            | н)               |                   | Res                                 | et Va | lue: ( | 0000   | 0000 <sub>н</sub> |  |
| ADC_  |                                                                                             |     |      |        |       |       | -      | -                |                  |                   |                                     |       |        |        |                   |  |
| ADC E | Exten                                                                                       | ded | Resu | lt 15  | View  | B Re  | giste  | r(178            | н)               |                   | Res                                 | et Va | lue: ( | 0000   | 0000 <sub>н</sub> |  |
| 31    | 30                                                                                          | 29  | 28   | 27     | 26    | 25    | 24     | 23               | 22               | 21                | 20                                  | 19    | 18     | 17     | 16                |  |
|       |                                                                                             | 20  | 20   | 21     | 20    | 20    | 27     | 20               |                  | 21                | 20                                  |       |        | 17     |                   |  |
|       |                                                                                             |     |      |        |       |       | (      | )                |                  |                   |                                     |       |        |        |                   |  |
|       | I                                                                                           |     | 1    | L      | 1     | I     | I      | <u> </u>         | 1                | 1                 | 1                                   | 1     | 1      | 1      |                   |  |
| 15    | 4.4                                                                                         | 10  | 10   | 4.4    | 10    | 0     | 0      | 7                | c                | F                 | 4                                   | 2     | 2      | 4      | 0                 |  |
| 15    | 14                                                                                          | 13  | 12   | 11     | 10    | 9     | 8      | 7                | Ö                | э<br>             | 4                                   | 3     | 2      | 1      | U                 |  |
| v     |                                                                                             | 0   |      |        |       |       |        |                  | RES              | ULT               |                                     |       |        |        |                   |  |
| rh    | I                                                                                           | -   | 1    |        | 1     | 1     | 1      |                  | 1                | 'n                | 1                                   | 1     | 1      | 1      |                   |  |
| in    |                                                                                             | 1   |      |        |       |       |        |                  | r                | 11                |                                     |       |        |        |                   |  |

r

rh

rh



| Field  | Bits               | Туре                                                       | Description                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|--------|--------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| RESULT | [11:0]             | rh                                                         | Conversion Result<br>This bit field represents the conversion result for the<br>selected channel.<br>If the conversion result is smaller than 10 bits, the<br>result always starts with its MSB at bit position 11 and<br>the unused bit positions are filled with 0.                                                                                              |  |  |  |  |
| V      | 15                 | rh                                                         | <ul> <li>Valid This bit indicates that the result has been written with a new value since the last read from this location. It becomes set with the write action of a new result and cleared when at least the low byte of the result is read out. 0 The result is not new (has already been read out). 1 The result is new (has not yet been read out).</li></ul> |  |  |  |  |
| 0      | [14:12]<br>[31:16] | r <b>Reserved;</b><br>Read as 0; should be written with 0. |                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |

#### ADC\_INRES . \_

| ADC      | _  |    | ult Re | egiste   | er | (180 <sub>H</sub> ) |     |    |     |     | Reset Value: 0000 0000 <sub>H</sub> |    |          |    |          |  |
|----------|----|----|--------|----------|----|---------------------|-----|----|-----|-----|-------------------------------------|----|----------|----|----------|--|
| 31       | 30 | 29 | 28     | 27       | 26 | 25                  | 24  | 23 | 22  | 21  | 20                                  | 19 | 18       | 17 | 16       |  |
|          |    | 1  | 1      |          |    | 1                   | . ( | )  |     | 1   |                                     |    | 1        | 1  |          |  |
|          | 1  | ļ  | ļ      | <u> </u> | 1  | ļ                   |     | r  | 1   | ļ   | 1                                   | 1  | <u> </u> |    | ļ]       |  |
| 15       | 14 | 13 | 12     | 11       | 10 | 9                   | 8   | 7  | 6   | 5   | 4                                   | 3  | 2        | 1  | 0        |  |
|          | СН | NR | i      |          |    | i                   |     | i  | RES | ULT |                                     |    | 1        | 1  |          |  |
| <u> </u> | W  |    |        |          |    |                     |     |    | v   | v   |                                     |    |          |    | <u> </u> |  |

| Field  | Bits   | Туре | Description                                                                                                                                                     |
|--------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESULT | [11:0] | W    | <b>Conversion Result</b><br>This bit field updates both bit fields for the registers<br>RESAn.RESULT and RESBn.RESULT. n is equal<br>the value written to CHNR. |



| Field | Bits    | Туре | Description                                                                                        |
|-------|---------|------|----------------------------------------------------------------------------------------------------|
| CHNR  | [15:12] | W    | <b>Channel Number</b><br>This bit field defines the extended result registers that<br>are updated. |
| 0     | [31:15] | r    | Reserved;<br>Read as 0; should be written with 0.                                                  |

# ADC\_RESV

| ADC        | DC Result Valid Register |            |            |            |            |           | (18       | 8 <sub>H</sub> ) |           | Reset Value: 0000 0000 |           |           |           |           |           |
|------------|--------------------------|------------|------------|------------|------------|-----------|-----------|------------------|-----------|------------------------|-----------|-----------|-----------|-----------|-----------|
| 31         | 30                       | 29         | 28         | 27         | 26         | 25        | 24        | 23               | 22        | 21                     | 20        | 19        | 18        | 17        | 16        |
|            | 1                        | 1          | 1          | 1          | 1          | 1         | (         | )                | 1         | 1                      | 1         | 1         | 1         | 1         |           |
|            |                          |            |            |            |            |           |           | r                |           |                        |           |           |           |           | <u> </u>  |
| 15         | 14                       | 13         | 12         | 11         | 10         | 9         | 8         | 7                | 6         | 5                      | 4         | 3         | 2         | 1         | 0         |
| CHN<br>15V | CHN<br>14V               | CHN<br>13V | CHN<br>12V | CHN<br>11V | CHN<br>10V | CHN<br>9V | CHN<br>8V | CHN<br>7V        | CHN<br>6V | CHN<br>5V              | CHN<br>4V | CHN<br>3V | CHN<br>2V | CHN<br>1V | CHN<br>0V |
| rh         | rh                       | rh         | rh         | rh         | rh         | rh        | rh        | rh               | rh        | rh                     | rh        | rh        | rh        | rh        | rh        |

| Field                  | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHNnV<br>(n = 0 to 15) | n       | rh   | <ul> <li>Channel n Valid Status This bit indicates that the result has been written with a new value since the last read from this location. It becomes set with the write action of a new result and cleared when at least the low byte of the result is read out. 0 The result is not new (has already been read out). 1 The result is new (has not yet been read out).</li></ul> |
| 0                      | [31:16] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                            |



## 6.8.5 ADC Doorbell Register

The following register control the doorbell mechanism of the extended result registers.

| ADC<br>ADC | _   |          | Contr | ol Re | giste | r   | (18    | 84 <sub>H</sub> ) |    |    | Res | et Va | lue: C | 0000 ( | 0000 <sub>H</sub> |
|------------|-----|----------|-------|-------|-------|-----|--------|-------------------|----|----|-----|-------|--------|--------|-------------------|
| 31         | 30  | 29       | 28    | 27    | 26    | 25  | 24     | 23                | 22 | 21 | 20  | 19    | 18     | 17     | 16                |
|            | 1   | 1        | 1     | 1     | 1     | 1   | ,<br>, | <b>D</b>          | 1  | 1  | 1   | 1     | 1      | I      |                   |
|            |     |          |       |       |       | _   |        | r                 |    |    |     |       |        | _      |                   |
| 15         | 14  | 13       | 12    | 11    | 10    | 9   | 8      | 7                 | 6  | 5  | 4   | 3     | 2      | 1      | 0                 |
|            | . ( | <b>D</b> | 1     |       | COI   | MP1 | I      | 0                 |    |    | 1   |       | COI    | MP0    |                   |
| <u>.</u>   |     | r        | rw    |       |       |     |        | r                 |    |    |     | rw    |        |        |                   |

| Field | Bits              | Туре | Description                                                                                              |
|-------|-------------------|------|----------------------------------------------------------------------------------------------------------|
| COMP0 | [3:0]             | rw   | <b>Compare Value 0</b><br>This bit field defines the compare value for the doorbell mechanism channel 0. |
| COMP1 | [11:8]            | rw   | <b>Compare Value 1</b><br>This bit field defines the compare value for the doorbell mechanism channel 1. |
| 0     | [7:4],<br>[31:12] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                 |

| SCU_<br>SCU | _  |    | ontro | l Reg | ister |    | (82 | 20 <sub>H</sub> ) |    |             | Rese      | et Val | ue: 0 | 0000 0    | 000С <sub>Н</sub> |
|-------------|----|----|-------|-------|-------|----|-----|-------------------|----|-------------|-----------|--------|-------|-----------|-------------------|
| 31          | 30 | 29 | 28    | 27    | 26    | 25 | 24  | 23                | 22 | 21          | 20        | 19     | 18    | 17        | 16                |
|             | 1  | 1  | 1     | 1     | 1     | 1  | •   | D                 | 1  | 1           | 1         |        | I     |           | 1                 |
| 15          | 14 | 13 | 12    | 11    | 10    | 9  | 8   | r<br>7            | 6  | 5           | 4         | 3      | 2     | 1         | 0                 |
|             | 1  | 1  | •     | D     | 1     | 1  | 1   | M.                | ТМ | P1DI<br>DIS | SW<br>RST |        | 1     | RES<br>LD | LOC<br>K          |
|             |    |    |       | r     | 1     |    |     | r                 | w  | rw          | rw        | r      | w     | rwh       | rh                |



| Field   | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LOCK    | 0     | rh   | PLL Lock Status Flag0PLL is not locked1PLL is locked                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| RESLD   | 1     | rwh  | Restart Lock DetectionSetting this bit will reset bit LOCK and restart the lockdetection. When set, this bit is automatically cleared.0No effect1Reset LOCK and restart lock detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SWRST   | 4     | rw   | Software Reset Trigger<br>Setting this bit will automatically request and<br>generate a reset. With the reset execution, this bit is<br>automatically cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P1DIDIS | 5     | rw   | Port 1 Digital Input DisableThis bit controls the digital input stage for all port 1pins.0Digital input stage (Schmitt-trigger) is enabled1Digital input stage (Schmitt-trigger) is disabled.This is necessary if pins are used as analoginput.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ΜΤΜ     | [7:6] | rw   | <ul> <li>Multiplexer Test Mode for Channel 0 This bit enables/disables the Multiplexer Test Mode for the input channel 0. This feature is independent of the current mode of the analog part. If the Multiplexer Test Mode is enabled, the analog input is connected to ADC ground via an internal resistance<sup>1)</sup>. This structure creates a voltage divider to ground, so the measurement result becomes smaller. 00 The Multiplexer Test Mode is disabled. The analog input is not connected to ground and can be used for normal measurements. 01 The Multiplexer Test Mode is enabled. The internal resistance to ground is in the range of 300 Ohm. 10 The Multiplexer Test Mode is enabled. The internal resistance to ground is in the range of 300 Ohm. 11 Reserved, like 00</li></ul> |



| Field | Bits   | Туре | Description                                       |
|-------|--------|------|---------------------------------------------------|
| 1     | [3:2]  | rw   | Reserved;<br>Should be written with 1.            |
| 0     | [15:8] | r    | Reserved;<br>Read as 0; should be written with 0. |

1) Please refer to the ACDC chapter for the current capability of the grounding resistor, especially when using RC input filters at the analog inputs.



#### **Parallel Ports**

# 7 Parallel Ports

The CIC751 has two parallel ports, port 0 and port 1. Port 0 controls all pins for the communication (MLI/SSC, Service Requests). Port 1 controls 16 inputs of the 16 ADC channels.

Each port line has a number of control and data bits, enabling very flexible usage of the line. Each port pin can be configured for input or output operation. In Input Mode, the output driver is switched off (high-impedance). The actual voltage level present at the port pin is translated into a logical 0 or 1 via a Schmitt-Trigger device and can be read via the read-only register Pn\_IN. The input can also be connected directly to the various inputs of the peripheral units (Alternate Input). The function of the input line from the pin to the input register Pn\_IN and to the alternate input is independent of whether the port pin operates as input or output. This means that when the port is in Output Mode, the level of the pin can be read via Pn\_IN or a peripheral can use the pin level as an input.

In Output Mode, the output driver is activated and drives the value supplied through the multiplexer to the port pin. Switching between Input and Output Mode is accomplished through the Pn\_IOCRx registers, which enables or disables the output driver. If a peripheral unit uses a GPIO port line as a bi-directional I/O line, register Pn\_IOCR has to be written for input or output selection. The Pn\_IOCRx registers further controls the driver type of the output driver, and determines whether an internal weak pull-up or pull-down device is alternatively connected to the pin when used as an input. This offers additional advantages in an application.

The output multiplexer in front of the output driver selects the source for the GPIO line when used as output. If the pin is used as general-purpose output, the multiplexer is switched (by Pn\_IOCRx register) to the Output Data Register Pn\_OUT. If the on-chip peripheral units use the pin for output, the alternate output lines ALT1 to ALT3 can be switched via the multiplexer to the output driver. The data written into the output register Pn\_OUT can be used as input data to an on-chip peripheral.

When selected as general-purpose output line, the logic state of each port pin can be changed individually by programming the pin-related bits in the Output Modification Register Pn\_OMR. The bits in Pn\_OMR make it possible to set, reset, toggle, or leave the bits in the Pn\_OUT register unchanged.

When selected as general-purpose output line, the actual logic level at the pin can be examined through reading latch Pn\_IN and compared against the applied output level. This can be used to detect some electrical failures at the pin caused through external circuitry. Collisions on the external communication lines can be detected when a high level (1) is output, but a low level (0) is seen when reading the pin value via the input register Pn\_IN.



#### **Parallel Ports**

# 7.1 Port 0

This section describes the control mechanisms of all pins other than the ADC analog channels and the reset pin PORST.

# 7.1.1 Block Diagram

Figure 7-1 shows the different options for the control of port 0.





# 7.1.2 Input Stage

The input value of each pin can be used in two different ways:

- 1. The input value of pin 0.x is always available at bit P0\_IN.Px
- 2. The input can be used directly by peripheral if connected
  - a) pins P0.1, P0.3, P0.6, and P0.7 are connected to the MLI
  - b) pins P0.2, P0.6, and P0.7 are connected to the SSC
  - c) pins P0.3, P0.8, P0.9, P0.10, P0.11, and P0.12 are used for general purpose

Note: Not all pins are directly connected for functional reasons to a peripheral.



### **Parallel Ports**

# 7.1.3 Port 0 Routing

The following table describes the mapping of the pins of Port 0 and the related I/O functions.

| Table 7-1 | Port 0 Input/Output Functions |
|-----------|-------------------------------|
|-----------|-------------------------------|

| Port<br>Pin | I/O    | Select | Connected Function             | From / to Module |
|-------------|--------|--------|--------------------------------|------------------|
| P0.0        | Input  |        | Not used                       |                  |
|             | Output | GPIO   | Port Output Register P0_OUT.P0 | Port             |
|             |        | ALT1   | TCLK                           | MLI              |
|             |        | ALT2   | SR3                            | SCU              |
|             |        | ALT3   | SR3                            | SCU              |
| P0.1        | Input  | •      | TREADY                         | MLI              |
|             | Output | GPIO   | Port Output Register P0_OUT.P1 | Port             |
|             |        | ALT1   | SR4                            | SCU              |
|             |        | ALT2   | SR4                            | SCU              |
|             |        | ALT3   | SR4                            | SCU              |
| P0.2        | Input  |        | SCLK                           | SSC              |
|             | Output | GPIO   | Port Output Register P0_OUT.P2 |                  |
|             |        | ALT1   | TVAILD                         | MLI              |
|             |        | ALT2   | Not used                       |                  |
|             |        | ALT3   | Not used                       |                  |
| P0.3        | Input  |        | Not used                       |                  |
|             | Output | GPIO   | Port Output Register P0_OUT.P3 |                  |
|             |        | ALT1   | TDAT                           | MLI              |
|             |        | ALT2   | MRST                           | SSC              |
|             |        | ALT3   | Not used                       |                  |
| P0.4        | Input  |        | RCLK                           | MLI              |
|             |        |        | RCLK                           | SCU              |
|             | Output | GPIO   | Port Output Register P0_OUT.P4 |                  |
|             |        | ALT1   | Not used                       |                  |
|             |        | ALT2   | Not used                       |                  |
|             |        | ALT3   | Not used                       |                  |



# **CIC751**

# **Parallel Ports**

| Port<br>Pin | I/O    | Select | Connected Function             | From / to Module |
|-------------|--------|--------|--------------------------------|------------------|
| P0.5        | Input  |        | Not used                       |                  |
|             | Output | GPIO   | Port Output Register P0_OUT.P5 |                  |
|             |        | ALT1   | RREADY                         | MLI              |
|             |        | ALT2   | RDY                            | SSC              |
|             |        | ALT3   | Not used                       |                  |
| P0.6        | Input  | 1      | RVALID                         | MLI              |
|             |        |        | SLS                            | SSC              |
|             | Output | GPIO   | Port Output Register P0_OUT.P6 |                  |
|             |        | ALT1   | Not used                       |                  |
|             |        | ALT2   | Not used                       |                  |
|             |        | ALT3   | Not used                       |                  |
| P0.7        | Input  |        | RDATA                          | MLI              |
|             |        |        | MTSR                           | SSC              |
|             | Output | GPIO   | Port Output Register P0_OUT.P7 |                  |
|             |        | ALT1   | Not used                       |                  |
|             |        | ALT2   | Not used                       |                  |
|             |        | ALT3   | Not used                       |                  |
| P0.8        | Input  |        | MODE                           | SCU              |
|             | Output | GPIO   | Port Output Register P0_OUT.P8 |                  |
|             |        | ALT1   | SR5                            | SCU              |
|             |        | ALT2   | SR5                            | SCU              |
|             |        | ALT3   | SR5                            | SCU              |
| P0.9        | Input  |        | TESTMODE                       | SCU              |
|             | Output | GPIO   | Port Output Register P0_OUT.P9 |                  |
|             |        | ALT1   | Not used                       |                  |
|             |        | ALT2   | Not used                       |                  |
|             |        | ALT3   | Not used                       |                  |

### Table 7-1Port 0 Input/Output Functions (cont'd)



# **CIC751**

### **Parallel Ports**

| Port<br>Pin | I/O     | Select   | Connected Function              | From / to Module |  |  |  |  |  |
|-------------|---------|----------|---------------------------------|------------------|--|--|--|--|--|
| P0.10       | Input   |          | SR0                             | SCU              |  |  |  |  |  |
|             | Output  | GPIO     | Port Output Register P0_OUT.P10 |                  |  |  |  |  |  |
|             |         | ALT1     | SR0                             | SCU              |  |  |  |  |  |
|             |         | ALT2     | SR0                             | SCU              |  |  |  |  |  |
|             |         | ALT3     | SR0                             | SCU              |  |  |  |  |  |
| P0.11       | 1 Input |          | SR1                             | SCU              |  |  |  |  |  |
|             | Output  | GPIO     | Port Output Register P0_OUT.P11 |                  |  |  |  |  |  |
|             |         | ALT1     | SR1                             | SCU              |  |  |  |  |  |
|             |         | ALT2     | SR1                             | SCU              |  |  |  |  |  |
|             |         | ALT3     | SR1                             | SCU              |  |  |  |  |  |
| P0.12       | Input   |          | SR2                             | SCU              |  |  |  |  |  |
|             | Output  | GPIO     | Port Output Register P0_OUT.P12 |                  |  |  |  |  |  |
|             |         | ALT1 SR2 |                                 | SCU              |  |  |  |  |  |
|             |         | ALT2     | SR2                             | SCU              |  |  |  |  |  |
|             |         | ALT3     | SR2                             | SCU              |  |  |  |  |  |

### Table 7-1 Port 0 Input/Output Functions (cont'd)

# 7.1.4 Port 0 Register Description

# 7.1.4.1 Port 0 Control Register

# P0\_IN

| Port |    | ut Re | giste | r   |     |     | (A2 | 24 <sub>H</sub> ) |     |     | Res | et Va      | lue: 0 | 000 0 | 000 <sub>H</sub> |
|------|----|-------|-------|-----|-----|-----|-----|-------------------|-----|-----|-----|------------|--------|-------|------------------|
| 31   | 30 | 29    | 28    | 27  | 26  | 25  | 24  | 23                | 22  | 21  | 20  | 19         | 18     | 17    | 16               |
|      | 1  | 1     | 1     | 1   | 1   | 1   |     | D                 | 1   | 1   | 1   | 1          | 1      | 1     |                  |
|      |    | I     |       | 1   | 1   | I   |     | r                 | I   | I   | I   | I          | I      | I     |                  |
| 15   | 14 | 13    | 12    | 11  | 10  | 9   | 8   | 7                 | 6   | 5   | 4   | 3          | 2      | 1     | 0                |
|      | 0  | 1     | P12   | P11 | P10 | P9  | P8  | P7                | P6  | Р5  | P4  | <b>P</b> 3 | P2     | P1    | P0               |
| L    | r  | 1     | rwh   | rwh | rwh | rwh | rwh | rwh               | rwh | rwh | rwh | rwh        | rwh    | rwh   | rwh              |



| Field            | Bits    | Туре | Description                                                                                                                                                                                      |
|------------------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>(x = 0-12) | x       | rwh  | <ul> <li>Port 0 Input Bit x</li> <li>This bit indicates the level at the input pin of port P0, pin x.</li> <li>0 The input level of P0.x is 0</li> <li>1 The input level of P0.x is 1</li> </ul> |
| 0                | [31:13] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                         |

|   | P0_C<br>Port |          | put F    | Regist | ter      |     |     | (A( | )0 <sub>H</sub> ) |          |     | Res      | et Va    | lue: 0   | 000 0    | 0000 <sub>H</sub> |
|---|--------------|----------|----------|--------|----------|-----|-----|-----|-------------------|----------|-----|----------|----------|----------|----------|-------------------|
| Г | 31           | 30       | 29       | 28     | 27       | 26  | 25  | 24  | 23                | 22       | 21  | 20       | 19       | 18       | 17       | 16                |
|   |              |          |          |        |          |     |     | (   | )                 |          |     |          |          |          |          |                   |
| L |              | <u> </u> | <u> </u> | ļ      | <u> </u> | ļ   |     |     | r                 | <u> </u> | ļ   | <u> </u>          |
| r | 15           | 14       | 13       | 12     | 11       | 10  | 9   | 8   | 7                 | 6        | 5   | 4        | 3        | 2        | 1        | 0                 |
|   |              | 0        | 1        | P12    | P11      | P10 | P9  | P8  | P7                | P6       | P5  | P4       | P3       | P2       | P1       | P0                |
| L |              | r        |          | rwh    | rwh      | rwh | rwh | rwh | rwh               | rwh      | rwh | rwh      | rwh      | rwh      | rwh      | rwh               |

| Field            | Bits    | Туре | Description                                                                                                                                                                                                                              |
|------------------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>(x = 0-12) | x       | rwh  | <ul> <li>Port Output Bit x</li> <li>This bit defines the level at the output pin of port 0, pin x if the output is selected as GPIO output.</li> <li>0 The output level of P0.x is 0</li> <li>1 The output level of P0.x is 1</li> </ul> |
| 0                | [31:13] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                                                                 |



#### P0 OMR Reset Value: 0000 0000<sub>H</sub> Port 0 Output Modification Register (A04<sub>H</sub>) 31 24 30 29 28 27 26 25 23 22 21 20 19 18 17 16 PR 0 12 11 10 9 8 7 6 5 4 3 2 1 0 r w w w W W W W W w W w w W 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 PS 0 12 11 10 9 8 7 6 5 4 3 2 1 0 w w w w w w w w W w w w r w

| Field             | Bits               | Туре | Description                                                                                                                                                                                  |
|-------------------|--------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSx<br>(x = 0-12) | x                  | w    | <b>Port Set Bit x</b><br>Setting this bit sets or toggles the corresponding bit in<br>the port output register P0_OUT (see <b>Table 7-2</b> ).<br>On a read access, this bit returns 0.      |
| PCx<br>(x = 0-12) | x + 16             | w    | <b>Port Clear Bit x</b><br>Setting this bit clears or toggles the corresponding bit<br>in the port output register P0_OUT. (see <b>Table 7-2</b> ).<br>On a read access, this bit returns 0. |
| 0                 | [15:13]<br>[31:29] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                     |

### Function of the PCx and PSx Bit fields

### Table 7-2Function of the Bits PCx and PSx

| PCx                  | PSx                  | Function                     |
|----------------------|----------------------|------------------------------|
| 0 or no write access | 0 or no write access | Bit P0_OUT.Px is not changed |
| 0 or no write access | 1                    | Bit P0_OUT.Px is set         |
| 1                    | 0 or no write access | Bit P0_OUT.Px is cleared     |
| 1                    | 1                    | Bit P0_OUT.Px is toggled     |

Note: If a bit position is not written (one out of two bytes not targeted by a byte write), the corresponding value is considered as 0. Toggling a bit requires one 16-bit write.



#### P0 IOCR0 Port 0 Input/Output Control 0 Register (A10<sub>H</sub>) Reset Value: Table 7-3 31 20 30 29 28 27 26 25 24 22 21 19 18 23 17 16 PC3A PC3 PC2 0 rw rw rw r 5 15 14 13 12 11 10 9 8 7 6 4 3 2 1 0 PC1 0 PC0 0 rw rw r r

| Field | Bits                         | Туре | Description                                              |  |
|-------|------------------------------|------|----------------------------------------------------------|--|
| PC0   | [7:4]                        | rw   | Port Input/Output Control Bit 0<br>see Table 7-4         |  |
| PC1   | [15:12]                      | rw   | Port Input/Output Control Bit 1<br>see Table 7-4         |  |
| PC2   | [23:20]                      | rw   | Port Input/Output Control Bit 2<br>see Table 7-4         |  |
| PC3A  | [27:24]                      | rw   | Port Input/Output Control Bit 3<br>see Table 7-4         |  |
| PC3   | [31:28]                      | rw   | Port Input/Output Control Bit 3<br>see Table 7-4         |  |
| 0     | [3:0],<br>[11:8],<br>[19:16] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0. |  |

#### Table 7-3 Register Reset Values

| Register Reset Type | <b>Reset Values</b>    | Reset Short Name | Reset Mode   | Note |
|---------------------|------------------------|------------------|--------------|------|
| SSC Mode Selected   | A020 2020 <sub>H</sub> | -                | Asynchronous |      |
| MLI Mode Selected   | 9290 0090 <sub>H</sub> | -                | Asynchronous |      |

### Coding of the PCx Bit field

The coding of the GPIO port behavior is done by the bit fields in the port control registers P0\_IOCRx. There's a control bit field PCx for each port pin. The bit fields PCx are located



in separate control registers in order to allow modifying a port pin (without influencing the others) with simple move operations.

# Table 7-4 PCx Coding

| PCx[3:0]          | I/O                           | Selected Pull-up/down /<br>Selected Output Function |
|-------------------|-------------------------------|-----------------------------------------------------|
| 0000 <sub>B</sub> | Input Mode                    | No pull device connected                            |
| 0001 <sub>B</sub> |                               | Pull-down device connected                          |
| 0010 <sub>B</sub> |                               | Pull-up device connected                            |
| 0011 <sub>B</sub> |                               | No pull device connected                            |
| 0100 <sub>B</sub> |                               | No pull device connected                            |
| 0101 <sub>B</sub> |                               | Pull-down device connected                          |
| 0110 <sub>B</sub> |                               | Pull-up device connected                            |
| 0111 <sub>B</sub> |                               | No pull device connected                            |
| 1000 <sub>B</sub> | Output Mode                   | General purpose Output                              |
| 1001 <sub>B</sub> | (Direct input)<br>— Push-pull | Output function ALT1                                |
| 1010 <sub>B</sub> |                               | Output function ALT2                                |
| 1011 <sub>B</sub> |                               | Output function ALT3                                |
| 1100 <sub>B</sub> | Output Mode                   | General purpose Output                              |
| 1101 <sub>B</sub> | (Direct input)<br>Open-drain  | Output function ALT1                                |
| 1110 <sub>B</sub> | Open-urain                    | Output function ALT2                                |
| 1111 <sub>B</sub> |                               | Output function ALT3                                |

### P0\_IOCR4 Port 0 Input/Output Control 4 Register (A14<sub>H</sub>)

#### Reset Value: Table 7-5

| 31 | 30 | 29 | 28       | 27 | 26   | 25 | 24       | 23  | 22 | 21 | 20       | 19 | 18       | 17 | 16 |
|----|----|----|----------|----|------|----|----------|-----|----|----|----------|----|----------|----|----|
|    | P  | C7 | I        |    | 0    |    |          |     | P  | C6 | I        | 0  |          |    |    |
|    | ٢١ | N  | <u> </u> |    | l    | •  | <u> </u> |     | r١ | N  | <u> </u> |    | <u> </u> | r  |    |
| 15 | 14 | 13 | 12       | 11 | 10   | 9  | 8        | 7   | 6  | 5  | 4        | 3  | 2        | 1  | 0  |
|    | P  | C5 | I        |    | PC5A |    |          | PC4 |    |    |          | 0  |          |    |    |
|    | rw |    | ۳۱       | N  | rw   |    |          | N   | r  |    |          |    |          |    |    |



| Field | Bits                         | Туре | Description                                              |
|-------|------------------------------|------|----------------------------------------------------------|
| PC4   | [7:4]                        | rw   | Port Input/Output Control Bit 4<br>see Table 7-4         |
| PC5A  | [11:8]                       | rw   | Port Input/Output Control Bit 5<br>see Table 7-4         |
| PC5   | [15:12]                      | rw   | Port Input/Output Control Bit 5<br>see Table 7-4         |
| PC6   | [23:20]                      | rw   | Port Input/Output Control Bit 6<br>see Table 7-4         |
| PC7   | [31:28]                      | rw   | Port Input/Output Control Bit 7<br>see Table 7-4         |
| 0     | [3:0],<br>[19:16]<br>[27:24] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0. |

# Table 7-5 Register Reset Values

| Register Reset Type | Reset Values           | Reset Short Name | Reset Mode   | Note |
|---------------------|------------------------|------------------|--------------|------|
| SSC Mode Selected   | 0020 A020 <sub>H</sub> | -                | Asynchronous |      |
| MLI Mode Selected   | 0020 9020 <sub>H</sub> | -                | Asynchronous |      |

# P0\_IOCR8

Port 0 Input/Output Control 8 Register (A18<sub>H</sub>)

### Reset Value: Table 7-6

| 31 | 30 | 29  | 28 | 27 | 26   | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|----|----|-----|----|----|------|----|-----|------|----|----|----|----|----|----|----------|
|    | PC | :11 | I  |    | 0    |    |     | PC10 |    |    | 0  |    |    |    |          |
|    | r  | N   | I  |    | II   | r  | I   |      | r  | w  | İ. |    |    | r  |          |
| 15 | 14 | 13  | 12 | 11 | 10   | 9  | 8   | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
|    | P  | C9  |    |    | 0    |    | PC8 |      |    | 0  |    |    |    |    |          |
|    | ۳  | N   | 1  |    | <br> | r  | 1   |      | r  | w  | 1  |    |    | r  | <u> </u> |



| Field | Bits                                    | Туре | Description                                              |
|-------|-----------------------------------------|------|----------------------------------------------------------|
| PC8   | [7:4]                                   | rw   | Port Input/Output Control Bit 8<br>see Table 7-4         |
| PC9   | [15:12]                                 | rw   | Port Input/Output Control Bit 9<br>see Table 7-4         |
| PC10  | [23:20]                                 | rw   | Port Input/Output Control Bit 10<br>see Table 7-4        |
| PC11  | [31:28]                                 | rw   | Port Input/Output Control Bit 11<br>see Table 7-4        |
| 0     | [3:0],<br>[11:8],<br>[19:16]<br>[27:24] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0. |

### Table 7-6 Register Reset Values

| Register Reset Type | <b>Reset Values</b>    | Reset Short Name | Reset Mode   | Note |
|---------------------|------------------------|------------------|--------------|------|
| SSC Mode Selected   | 2020 2020 <sub>H</sub> | -                | Asynchronous |      |
| MLI Mode Selected   | 2020 2020 <sub>H</sub> | -                | Asynchronous |      |

#### P0\_IOCR12 Port 0 Input/Output Control 12 Register (A1C<sub>H</sub>) Reset Value: Table 7-7 r **PC12** rw r r

| Field | Bits  | Туре | Description                                       |
|-------|-------|------|---------------------------------------------------|
| PC12  | [7:4] | rw   | Port Input/Output Control Bit 12<br>see Table 7-4 |



| Field | Bits             | Туре | Description                                              |  |
|-------|------------------|------|----------------------------------------------------------|--|
| 0     | [3:0],<br>[31:8] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0. |  |

### Table 7-7 Register Reset Values

| Register Reset Type | <b>Reset Values</b>    | Reset Short Name | Reset Mode   | Note |
|---------------------|------------------------|------------------|--------------|------|
| SSC Mode Selected   | 0000 0020 <sub>H</sub> | -                | Asynchronous |      |
| MLI Mode Selected   | 0000 0020 <sub>H</sub> | -                | Asynchronous |      |



# 7.2 Port 1

This section describes the control mechanisms of all pins used as ADC analog channels.

# 7.2.1 Block Diagram

Figure 7-1 shows the different options for the control of port 1.



Figure 7-2 Port 1 Control Structure

# 7.2.2 Input Stage

The input value of each pin can be used in up to three different ways:

- 1. The input value of pin 0.x is always available at bit P0\_IN.Px
- The input can be used directly as External Trigger Input a) pins P1.4, and P1.14 are usable as trigger inputs
- 3. The pins are used as analog inputs for the ADCa) pin P1.0 is equipped with the Multiplexer Test Mode Feature.



# 7.2.3 Port 1 Routing

The following table describes the mapping of the pins of Port 0 and the related I/O functions.

| Table 7-8 | Port 1 | Input/Output | Functions |
|-----------|--------|--------------|-----------|
|-----------|--------|--------------|-----------|

| Port<br>Pin | I/O     | Select | Connected Function | From / to Module |  |  |
|-------------|---------|--------|--------------------|------------------|--|--|
| P1.0        | Input I | Mode   | Analog Input 0     | ADC              |  |  |
| P1.1        |         |        | Analog Input 1     | ADC              |  |  |
| P1.2        |         |        | Analog Input 2     | ADC              |  |  |
| P1.3        |         |        | Analog Input 3     | ADC              |  |  |
| P1.4        |         |        | Analog Input 4     | ADC              |  |  |
|             |         |        | Trigger            | SCU/DMA          |  |  |
| P1.5        |         |        | Analog Input 5     | ADC              |  |  |
| P1.6        |         |        | Analog Input 6     | ADC              |  |  |
| P1.7        |         |        | Analog Input 7     | ADC              |  |  |
| P1.8        |         |        | Analog Input 8     | ADC              |  |  |
| P1.9        |         |        | Analog Input 9     | ADC              |  |  |
| P1.10       |         |        | Analog Input 10    | ADC              |  |  |
| P1.11       |         |        | Analog Input 11    | ADC              |  |  |
| P1.12       |         |        | Analog Input 12    | ADC              |  |  |
| P1.13       |         |        | Analog Input 13    | ADC              |  |  |
| P1.14       | 1       |        | Analog Input 14    | ADC              |  |  |
|             |         |        | Trigger            | SCU/DMA          |  |  |
| P1.15       |         |        | Analog Input 15    | ADC              |  |  |



# 7.2.4 Port 1 Register Description

# 7.2.4.1 Port Input Register

#### P1\_IN

| Port | 1 Inp | ut Re | giste | r   |     |     | (A6 | 64 <sub>H</sub> ) |     |     | Res | et Va | lue: 0 | 000 0 | 000 <sub>H</sub>                             |
|------|-------|-------|-------|-----|-----|-----|-----|-------------------|-----|-----|-----|-------|--------|-------|----------------------------------------------|
| 31   | 30    | 29    | 28    | 27  | 26  | 25  | 24  | 23                | 22  | 21  | 20  | 19    | 18     | 17    | 16                                           |
|      | I     | Į     | Į     | I   | I   | I   | (   | )                 | I   | Į   | I   | Į     |        |       |                                              |
|      | 1     | 1     | 1     | 1   | 1   | 1   | I   | r                 | 1   | 1   | 1   | 1     |        |       | <u>                                     </u> |
| 15   | 14    | 13    | 12    | 11  | 10  | 9   | 8   | 7                 | 6   | 5   | 4   | 3     | 2      | 1     | 0                                            |
| P15  | P14   | P13   | P12   | P11 | P10 | P9  | P8  | P7                | P6  | P5  | P4  | P3    | P2     | P1    | P0                                           |
| rwh  | rwh   | rwh   | rwh   | rwh | rwh | rwh | rwh | rwh               | rwh | rwh | rwh | rwh   | rwh    | rwh   | rwh                                          |

| Field            | Bits    | Туре | Description                                                                                                                                                                                      |
|------------------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>(x = 15-0) | x       | rwh  | <ul> <li>Port 1 Input Bit x</li> <li>This bit indicates the level at the input pin of port P1, pin x.</li> <li>0 The input level of P1.x is 0</li> <li>1 The input level of P1.x is 1</li> </ul> |
| 0                | [31:16] | r    | <b>Reserved;</b><br>Read as 0; should be written with 0.                                                                                                                                         |

# 7.3 Ports Register Overview

All port register can only be accessed by 32-bit accesses. 8-bit or 16-bit accesses are not allowed and lead to errors.

| Register<br>Short Name | Register Long Name                     | Address          | Description see |
|------------------------|----------------------------------------|------------------|-----------------|
| P0_OUT                 | Port 0 Output Register                 | A00 <sub>H</sub> | Page 7-6        |
| P0_OMR                 | Port 0 Output Modification Register    | A04 <sub>H</sub> | Page 7-7        |
| P0_IOCR0               | Port 0 Input/Output Control Register 0 | A10 <sub>H</sub> | Page 7-8        |
| P0_IOCR4               | Port 0 Input/Output Control Register 4 | A14 <sub>H</sub> | Page 7-9        |
| P0_IOCR8               | Port 0 Input/Output Control Register 8 | A18 <sub>H</sub> | Page 7-10       |



| Register<br>Short Name | Register Long Name                      | Address          | Description see |
|------------------------|-----------------------------------------|------------------|-----------------|
| P0_IOCR12              | Port 0 Input/Output Control Register 12 | A1C <sub>H</sub> | Page 7-11       |
| P0_IN                  | Port 0 Input Register                   | A24 <sub>H</sub> | Page 7-5        |

### Table 7-9 Port 0 Registers (cont'd)

# Table 7-10Port 1 Registers

| Register<br>Short Name | Register Long Name    | Address          | Description see |
|------------------------|-----------------------|------------------|-----------------|
| P1_IN                  | Port 1 Input Register | A64 <sub>H</sub> | Page 7-15       |



# 8 Register Overview

This chapter describes all registers of the CIC751. It also describes the read/write access rights of the specific address ranges/registers.

# 8.1 Address Map of CIC751

 Table 8-1 shows the block address map of CIC751.

### Table 8-1 Block Address Map of CIC751

| Unit                                  | Address Range               |
|---------------------------------------|-----------------------------|
| Reserved                              | 0000 0000 <sub>H</sub>      |
|                                       | -<br>0000 01FF <sub>H</sub> |
| Micro Link Interface (MLI)            | 0000 0200 <sub>H</sub>      |
|                                       | -                           |
|                                       | 0000 02FF <sub>H</sub>      |
| Reserved                              | 0000 0300 <sub>H</sub>      |
|                                       | -                           |
|                                       | 0000 03FF <sub>H</sub>      |
| Direct Memory Access Controller (DMA) | 0000 0400 <sub>H</sub>      |
|                                       | -<br>0000 05FF <sub>H</sub> |
|                                       |                             |
| Reserved                              | 0000 0600 <sub>H</sub>      |
|                                       | -<br>0000 07FF <sub>H</sub> |
| System Control Unit (SCU)             | 0000 0800 <sub>H</sub>      |
|                                       | -                           |
|                                       | 0000 08FF <sub>H</sub>      |
| Synchronous Serial Interface (SSC)    | 0000 0900 <sub>H</sub>      |
|                                       |                             |
|                                       | 0000 09FF <sub>H</sub>      |
| Ports                                 | 0000 0A00 <sub>H</sub>      |
|                                       |                             |
|                                       | 0000 0AFF <sub>H</sub>      |
| Reserved                              | 0000 0В00 <sub>Н</sub>      |
|                                       | -<br>0000 0FFF <sub>H</sub> |
|                                       |                             |



| Table 8-1         Block Address Map of CIC751 (cont'd) |              |                             |  |
|--------------------------------------------------------|--------------|-----------------------------|--|
| Unit                                                   |              | Address Range               |  |
| Analog-to-Digital Converter (ADC)                      |              | 0000 1000 <sub>H</sub>      |  |
|                                                        |              | -<br>0000 11FF <sub>H</sub> |  |
| Reserved                                               |              | 0000 1200 <sub>H</sub>      |  |
|                                                        |              |                             |  |
|                                                        | <b>D</b> : 0 | 0000 7FFF <sub>H</sub>      |  |
| MLI Small Transfer Windows                             | Pipe 0       | 0000 8000 <sub>H</sub><br>- |  |
|                                                        |              | 0000 9FFF <sub>H</sub>      |  |
|                                                        | Pipe 1       | 0000 A000 <sub>H</sub>      |  |
|                                                        |              | -<br>0000 BFFF <sub>H</sub> |  |
|                                                        | Pipe 2       | 0000 C000 <sub>H</sub>      |  |
|                                                        | po _         | -                           |  |
|                                                        |              | 0000 DFFF <sub>H</sub>      |  |
|                                                        | Pipe 3       | 0000 E000 <sub>H</sub>      |  |
|                                                        |              | -<br>0000 FFFF <sub>H</sub> |  |
| MLI Large Transfer Windows                             | Pipe 0       | 0001 0000 <sub>H</sub>      |  |
|                                                        |              | -<br>0001 FFFF <sub>H</sub> |  |
|                                                        | Pipe 1       | 0002 0000 <sub>H</sub>      |  |
|                                                        |              | -<br>0002 FFFF <sub>H</sub> |  |
|                                                        | Pipe 2       | 0003 0000 <sub>H</sub>      |  |
|                                                        |              | -<br>0003 FFFF <sub>H</sub> |  |
|                                                        | Pipe 3       | 0004 0000 <sub>H</sub>      |  |
|                                                        |              | -<br>0004 FFFF <sub>H</sub> |  |
| Reserved                                               |              | 0005 0000 <sub>H</sub>      |  |
|                                                        |              | -<br>FFFF FFFF <sub>H</sub> |  |

# 8.1.1 Access Rules

The following rules apply for all accesses:



- All registers read and write conditions can be found in the different module chapters
- Accesses to reserved marked addresses are forbidden and lead to an undefined behavior
- All port register can only be accesses by 32-bit accesses
- The MLI master automatically generates 32-bit accesses for 32-bit data transfers
- The MLI master automatically generates 16-bit accesses for 16-bit data transfers
- The MLI master automatically generates 8-bit accesses for 8-bit data transfers
- The SSC master automatically generates 32-bit accesses to all registers beside the ADC register
- The SSC master automatically generates 16-bit accesses to all ADC registers
- Accesses to not configured parts of an MLI Remote Window are forbidden and lead to an undefined behavior
- All registers beside the ADC core register are 32-bit registers
- The ADC core registers are 16-bit registers; 32-bit accesses are forbidden and lead to an undefined behavior
- The registers are ADC core registers
  - ADC\_CON; ADC Control Register
  - ADC\_CON1; ADC Control 1 Register
  - ADC\_CTR0; ADC Control 0 Register
  - ADC\_CTR2; ADC Control 2 Register
  - ADC\_CTR2IN; ADC Injection Control 2 Register
  - ADC\_DAT; ADC Result Register
  - ADC\_DAT2; ADC Result 2 Register



# 8.2 Registers Tables

| Register<br>Short Name | Register Long Name                            | Address                     | Description see |
|------------------------|-----------------------------------------------|-----------------------------|-----------------|
| Reserved               | Reserved                                      | 0000 0200 <sub>H</sub><br>- | -               |
|                        |                                               | 0000 0208 <sub>H</sub>      |                 |
| MLI_FDR                | Fractional Divider Register                   | 0000 020C <sub>H</sub>      | Page 4-49       |
| MLI_TCR                | Transmitter Control Register                  | 0000 0210 <sub>H</sub>      | Page 4-59       |
| MLI_TSTATR             | Transmitter Status Register                   | 0000 0214 <sub>H</sub>      | Page 4-62       |
| MLI_TP0STATR           | Transmitter Pipe 0 Status Register            | 0000 0218 <sub>H</sub>      | Page 4-64       |
| MLI_TP1STATR           | Transmitter Pipe 1 Status Register            | 0000 021C <sub>H</sub>      | Page 4-64       |
| MLI_TP2STATR           | Transmitter Pipe 2 Status Register            | 0000 0220 <sub>H</sub>      | Page 4-64       |
| MLI_TP3STATR           | Transmitter Pipe 3 Status Register            | 0000 0224 <sub>H</sub>      | Page 4-64       |
| MLI_TCMDR              | Transmitter Command Register                  | 0000 0228 <sub>H</sub>      | Page 4-66       |
| MLI_TSTATR             | Transmitter Receiver Status<br>Register       | 0000 022C <sub>H</sub>      | Page 4-62       |
| MLI_TP0AOFR            | Transmitter Pipe 0 Address Offset<br>Register | 0000 0230 <sub>H</sub>      | Page 4-70       |
| MLI_TP1AOFR            | Transmitter Pipe 1 Address Offset<br>Register | 0000 0234 <sub>H</sub>      | Page 4-70       |
| MLI_TP2AOFR            | Transmitter Pipe 2 Address Offset<br>Register | 0000 0238 <sub>H</sub>      | Page 4-70       |
| MLI_TP3AOFR            | Transmitter Pipe 3 Address Offset<br>Register | 0000 023C <sub>H</sub>      | Page 4-70       |
| MLI_TP0DATAR           | Transmitter Pipe 0 Data Register              | 0000 0240 <sub>H</sub>      | Page 4-71       |
| MLI_TP1DATAR           | Transmitter Pipe 1 Data Register              | 0000 0244 <sub>H</sub>      | Page 4-71       |
| MLI_TP2DATAR           | Transmitter Pipe 2 Data Register              | 0000 0248 <sub>H</sub>      | Page 4-71       |
| MLI_TP3DATAR           | Transmitter Pipe 3 Data Register              | 0000 024C <sub>H</sub>      | Page 4-71       |
| MLI_TDRAR              | Transmitter Data Read Answer<br>Register      | 0000 0250 <sub>H</sub>      | Page 4-72       |
| MLI_TP0BAR             | Transmitter Pipe 0 Base Address<br>Register   | 0000 0254 <sub>H</sub>      | Page 4-73       |



| Register<br>Short Name | Register Long Name                             | Address                | Description see |
|------------------------|------------------------------------------------|------------------------|-----------------|
| MLI_TP1BAR             | Transmitter Pipe 1 Base Address<br>Register    | 0000 0258 <sub>H</sub> | Page 4-73       |
| MLI_TP2BAR             | Transmitter Pipe 2 Base Address<br>Register    | 0000 025C <sub>H</sub> | Page 4-73       |
| MLI_TP3BAR             | Transmitter Pipe 3 Base Address<br>Register    | 0000 0260 <sub>H</sub> | Page 4-73       |
| MLI_TCBAR              | Transmitter Copy Base Address<br>Register      | 0000 0264 <sub>H</sub> | Page 4-74       |
| MLI_RCR                | Receiver Control Register                      | 0000 0268 <sub>H</sub> | Page 4-75       |
| MLI_RP0BAR             | Receiver Pipe 0 Base Address<br>Register       | 0000 026C <sub>H</sub> | Page 4-78       |
| MLI_RP1BAR             | Receiver Pipe 1 Base Address<br>Register       | 0000 0270 <sub>H</sub> | Page 4-78       |
| MLI_RP2BAR             | Receiver Pipe 2 Base Address<br>Register       | 0000 0274 <sub>H</sub> | Page 4-78       |
| MLI_RP3BAR             | Receiver Pipe 3 Base Address<br>Register       | 0000 0278 <sub>H</sub> | Page 4-78       |
| MLI_RP0STATR           | Receiver Pipe 0 Status Register                | 0000 027C <sub>H</sub> | Page 4-79       |
| MLI_RP1STATR           | Receiver Pipe 1 Status Register                | 0000 0280 <sub>H</sub> | Page 4-79       |
| MLI_RP2STATR           | Receiver Pipe 2 Status Register                | 0000 0284 <sub>H</sub> | Page 4-79       |
| MLI_RP3STATR           | Receiver Pipe 3 Status Register                | 0000 0288 <sub>H</sub> | Page 4-79       |
| MLI_RADRR              | Receiver Address Register                      | 0000 028C <sub>H</sub> | Page 4-81       |
| MLI_RDATAR             | Receiver Data Register                         | 0000 0290 <sub>H</sub> | Page 4-82       |
| MLI_SCR                | Set Clear Register                             | 0000 0294 <sub>H</sub> | Page 4-51       |
| MLI_TIER               | Transmitter Interrupt Enable<br>Register       | 0000 0298 <sub>H</sub> | Page 4-83       |
| MLI_TISR               | Transmitter Interrupt Status<br>Register       | 0000 029C <sub>H</sub> | Page 4-85       |
| MLI_TINPR              | Transmitter Interrupt Node Pointer<br>Register | 0000 02A0 <sub>H</sub> | Page 4-86       |
| MLI_RIER               | Receiver Interrupt Enable Register             | 0000 02A4 <sub>H</sub> | Page 4-88       |
| MLI_RISR               | Receiver Interrupt Status Register             | 0000 02A8 <sub>H</sub> | Page 4-90       |

### Table 8-2 MLI Kernel Registers (cont'd)



| Register<br>Short Name | Register Long Name                          | Address                     | Description see |
|------------------------|---------------------------------------------|-----------------------------|-----------------|
| MLI_RINPR              | Receiver Interrupt Node Pointer<br>Register | 0000 02AC <sub>H</sub>      | Page 4-92       |
| MLI_GINTR              | Global Interrupt Set Register               | 0000 02B0 <sub>H</sub>      | Page 4-53       |
| MLI_OICR               | Output Input Control Register               | 0000 02B4 <sub>H</sub>      | Page 4-54       |
| MLI_MEM0               | MLI Memory 0 Register                       | 0000 02B8 <sub>H</sub>      | -               |
| MLI_MEM1               | MLI Memory 1 Register                       | 0000 02BC <sub>H</sub>      | -               |
| Reserved               | Reserved                                    | 0000 02C0 <sub>H</sub>      | -               |
|                        |                                             | -<br>0000 02FF <sub>H</sub> |                 |

### Table 8-2 MLI Kernel Registers (cont'd)

### Table 8-3 DMA Kernel Registers

| Register<br>Short Name | Register Long Name                           | Address                | Description see |
|------------------------|----------------------------------------------|------------------------|-----------------|
| Reserved               | Reserved                                     | 0000 0400 <sub>H</sub> | -               |
|                        |                                              | -                      |                 |
|                        |                                              | 0000 040C <sub>H</sub> |                 |
| DMA_CHRSTR             | DMA Channel Request Register                 | 0000 0410 <sub>H</sub> | Page 3-29       |
| DMA_TRSR               | DMA Transaction Request State<br>Register    | 0000 0414 <sub>H</sub> | Page 3-31       |
| DMA_STREQ              | DMA Software Transaction<br>Request Register | 0000 0418 <sub>H</sub> | Page 3-32       |
| DMA_HTREQ              | DMA Hardware Transaction<br>Request Register | 0000 041C <sub>H</sub> | Page 3-33       |
| Reserved               | Reserved                                     | 0000 0420 <sub>H</sub> | -               |
| DMA_ERRSR              | DMA Error Status Register                    | 0000 0424 <sub>H</sub> | Page 3-34       |
| DMA_CLRE               | DMA Clear Error Register                     | 0000 0428 <sub>H</sub> | Page 3-36       |
| Reserved               | Reserved                                     | 0000 042C <sub>H</sub> | -               |
| DMA_MESR               | DMA Move Engine Status Register              | 0000 0430 <sub>H</sub> | Page 3-37       |
| DMA_ME0R               | DMA Move Engine 0 Read<br>Register           | 0000 0434 <sub>H</sub> | Page 3-38       |
| Reserved               | Reserved                                     | 0000 0438 <sub>H</sub> | -               |
| DMA_MEM0               | DMA Memory 0 Register                        | 0000 043C <sub>н</sub> | -               |



| Table 8-3DMA Kernel Registers (cont'd) |                                               |                             |                 |
|----------------------------------------|-----------------------------------------------|-----------------------------|-----------------|
| Register<br>Short Name                 | Register Long Name                            | Address                     | Description see |
| DMA_MEM1                               | DMA Memory 1 Register                         | 0000 0440 <sub>H</sub>      | -               |
| DMA_MEM2                               | DMA Memory 2 Register                         | 0000 0444 <sub>H</sub>      | -               |
| DMA_MEM3                               | DMA Memory 3 Register                         | 0000 0448 <sub>H</sub>      | -               |
| DMA_MEM4                               | DMA Memory 4 Register                         | 0000 044C <sub>H</sub>      | -               |
| DMA_MEM5                               | DMA Memory 5 Register                         | 0000 0450 <sub>H</sub>      | -               |
| Reserved                               | Reserved                                      | 0000 0454 <sub>H</sub><br>- | -               |
|                                        |                                               | 0000 0464 <sub>H</sub>      |                 |
| DMA_MEM14                              | DMA Memory 14 Register                        | 0000 0468 <sub>H</sub>      | -               |
| Reserved                               | Reserved                                      | 0000 046C <sub>H</sub><br>- | -               |
|                                        |                                               | 0000 047C <sub>H</sub>      |                 |
| DMA_CHSR00                             | DMA Channel 0 Status Register                 | 0000 0480 <sub>H</sub>      | Page 3-42       |
| DMA_CHCR00                             | DMA Channel 0 Control Register                | 0000 0484 <sub>H</sub>      | Page 3-39       |
| DMA_MEM6                               | DMA Memory 6 Register                         | 0000 0488 <sub>H</sub>      | -               |
| DMA_ADRCR00                            | DMA Channel 0 Address Control<br>Register     | 0000 048C <sub>H</sub>      | Page 3-43       |
| DMA_SADR00                             | DMA Channel 0 Source Address<br>Register      | 0000 0490 <sub>H</sub>      | Page 3-47       |
| DMA_DADR00                             | DMA Channel 0 Destination<br>Address Register | 0000 0494 <sub>H</sub>      | Page 3-36       |
| DMA_SHADR00                            | DMA Channel 0 Shadow Address<br>Register      | 0000 0498 <sub>H</sub>      | Page 3-49       |
| DMA_CHSR01                             | DMA Channel 1 Status Register                 | 0000 04A0 <sub>H</sub>      | Page 3-42       |
| DMA_CHCR01                             | DMA Channel 1 Control Register                | 0000 04A4 <sub>H</sub>      | Page 3-39       |
| DMA_MEM7                               | DMA Memory 7 Register                         | 0000 04A8 <sub>H</sub>      | -               |
| DMA_ADRCR01                            | DMA Channel 1 Address Control<br>Register     | 0000 04AC <sub>H</sub>      | Page 3-43       |
| DMA_SADR01                             | DMA Channel 1 Source Address<br>Register      | 0000 04B0 <sub>H</sub>      | Page 3-47       |
| DMA_DADR01                             | DMA Channel 1 Destination<br>Address Register | 0000 04B4 <sub>H</sub>      | Page 3-48       |



| Table 8-3DMA Kernel Registers (cont'd) |                                               |                        |                 |
|----------------------------------------|-----------------------------------------------|------------------------|-----------------|
| Register<br>Short Name                 | Register Long Name                            | Address                | Description see |
| DMA_SHADR01                            | DMA Channel 1 Shadow Address<br>Register      | 0000 04B8 <sub>H</sub> | Page 3-49       |
| DMA_CHSR02                             | DMA Channel 2 Status Register                 | 0000 04C0 <sub>H</sub> | Page 3-42       |
| DMA_CHCR02                             | DMA Channel 2 Control Register                | 0000 04C4 <sub>H</sub> | Page 3-39       |
| DMA_MEM8                               | DMA Memory 8 Register                         | 0000 04C8 <sub>H</sub> | -               |
| DMA_ADRCR02                            | DMA Channel 2 Address Control<br>Register     | 0000 04CC <sub>H</sub> | Page 3-43       |
| DMA_SADR02                             | DMA Channel 2 Source Address<br>Register      | 0000 04D0 <sub>H</sub> | Page 3-47       |
| DMA_DADR02                             | DMA Channel 2 Destination<br>Address Register | 0000 04D4 <sub>H</sub> | Page 3-48       |
| DMA_SHADR02                            | DMA Channel 2 Shadow Address<br>Register      | 0000 04D8 <sub>H</sub> | Page 3-49       |
| DMA_CHSR03                             | DMA Channel 3 Status Register                 | 0000 04E0 <sub>H</sub> | Page 3-42       |
| DMA_CHCR03                             | DMA Channel 3 Control Register                | 0000 04E4 <sub>H</sub> | Page 3-39       |
| DMA_MEM9                               | DMA Memory 9 Register                         | 0000 04E8 <sub>H</sub> | -               |
| DMA_ADRCR03                            | DMA Channel 3 Address Control<br>Register     | 0000 04EC <sub>H</sub> | Page 3-43       |
| DMA_SADR03                             | DMA Channel 3 Source Address<br>Register      | 0000 04F0 <sub>H</sub> | Page 3-47       |
| DMA_DADR03                             | DMA Channel 3 Destination<br>Address Register | 0000 04F4 <sub>H</sub> | Page 3-48       |
| DMA_SHADR03                            | DMA Channel 3 Shadow Address<br>Register      | 0000 04F8 <sub>H</sub> | Page 3-49       |
| DMA_CHSR04                             | DMA Channel 4 Status Register                 | 0000 0500 <sub>H</sub> | Page 3-42       |
| DMA_CHCR04                             | DMA Channel 4 Control Register                | 0000 0504 <sub>H</sub> | Page 3-39       |
| DMA_MEM10                              | DMA Memory 10 Register                        | 0000 0508 <sub>H</sub> | -               |
| DMA_ADRCR04                            | DMA Channel 4 Address Control<br>Register     | 0000 050C <sub>H</sub> | Page 3-43       |
| DMA_SADR04                             | DMA Channel 4 Source Address<br>Register      | 0000 0510 <sub>H</sub> | Page 3-47       |
| DMA_DADR04                             | DMA Channel 4 Destination<br>Address Register | 0000 0514 <sub>H</sub> | Page 3-48       |

### Table 8-3 DMA Kernel Registers (cont'd)



| Register    | Kernel Registers (cont'd) Register Long Name  | Address                | Description |
|-------------|-----------------------------------------------|------------------------|-------------|
| Short Name  | Register Long Name                            | Address                | see         |
| DMA_SHADR04 | DMA Channel 4 Shadow Address<br>Register      | 0000 0518 <sub>H</sub> | Page 3-49   |
| DMA_CHSR05  | DMA Channel 5 Status Register                 | 0000 0520 <sub>H</sub> | Page 3-42   |
| DMA_CHCR05  | DMA Channel 5 Control Register                | 0000 0524 <sub>H</sub> | Page 3-39   |
| DMA_MEM11   | DMA Memory 11 Register                        | 0000 0528 <sub>H</sub> | -           |
| DMA_ADRCR05 | DMA Channel 5 Address Control<br>Register     | 0000 052C <sub>H</sub> | Page 3-43   |
| DMA_SADR05  | DMA Channel 5 Source Address<br>Register      | 0000 0530 <sub>H</sub> | Page 3-47   |
| DMA_DADR05  | DMA Channel 5 Destination<br>Address Register | 0000 0534 <sub>H</sub> | Page 3-48   |
| DMA_SHADR05 | DMA Channel 5 Shadow Address<br>Register      | 0000 0538 <sub>H</sub> | Page 3-49   |
| DMA_CHSR06  | DMA Channel 6 Status Register                 | 0000 0540 <sub>H</sub> | Page 3-42   |
| DMA_CHCR06  | DMA Channel 6 Control Register                | 0000 0544 <sub>H</sub> | Page 3-39   |
| DMA_MEM12   | DMA Memory 12 Register                        | 0000 0548 <sub>H</sub> | -           |
| DMA_ADRCR06 | DMA Channel 6 Address Control<br>Register     | 0000 054C <sub>H</sub> | Page 3-43   |
| DMA_SADR06  | DMA Channel 6 Source Address<br>Register      | 0000 0550 <sub>H</sub> | Page 3-47   |
| DMA_DADR06  | DMA Channel 6 Destination<br>Address Register | 0000 0554 <sub>H</sub> | Page 3-48   |
| DMA_SHADR06 | DMA Channel 6 Shadow Address<br>Register      | 0000 0558 <sub>H</sub> | Page 3-49   |
| DMA_CHSR07  | DMA Channel 7 Status Register                 | 0000 0560 <sub>H</sub> | Page 3-42   |
| DMA_CHCR07  | DMA Channel 7 Control Register                | 0000 0564 <sub>H</sub> | Page 3-39   |
| DMA_MEM13   | DMA Memory 13 Register                        | 0000 0568 <sub>H</sub> | -           |
| DMA_ADRCR07 | DMA Channel 7 Address Control<br>Register     | 0000 056C <sub>H</sub> | Page 3-43   |
| DMA_SADR07  | DMA Channel 7 Source Address<br>Register      | 0000 0570 <sub>H</sub> | Page 3-47   |
| DMA_DADR07  | DMA Channel 7 Destination<br>Address Register | 0000 0574 <sub>H</sub> | Page 3-48   |

### Table 8-3 DMA Kernel Registers (cont'd)



| Register<br>Short Name | Register Long Name                       | Address                                               | Description see |
|------------------------|------------------------------------------|-------------------------------------------------------|-----------------|
| DMA_SHADR07            | DMA Channel 7 Shadow Address<br>Register | 0000 0578 <sub>H</sub>                                | Page 3-49       |
| Reserved               | Reserved                                 | 0000 0580 <sub>H</sub><br>-<br>0000 05FF <sub>H</sub> | -               |

### Table 8-3 DMA Kernel Registers (cont'd)

### Table 8-4SCU Registers

| Register Short<br>Name | Register Long Name                       | Address                     | Description see |
|------------------------|------------------------------------------|-----------------------------|-----------------|
| SCU_OSCCON             | SCU Oscillator Control Register          | 0000 0800 <sub>H</sub>      | Page 2-14       |
| SCU_PLLCON             | SCU PLL Control Register                 | 0000 0804 <sub>H</sub>      | Page 2-15       |
| Reserved               | Reserved                                 | 0000 0808 <sub>H</sub><br>- | -               |
|                        |                                          | 0000 081C <sub>H</sub>      |                 |
| SCU_SYSCON             | SCU System Control Register              | 0000 0820 <sub>H</sub>      | Page 2-16       |
| Reserved               | Reserved                                 | 0000 0824 <sub>H</sub><br>- | -               |
|                        |                                          | 0000 082C <sub>H</sub>      |                 |
| SCU_CHTR0              | SCU Channel Trigger 0 Register           | 0000 0830 <sub>H</sub>      | Page 2-22       |
| SCU_CHTR1              | SCU Channel Trigger 1 Register           | 0000 0834 <sub>H</sub>      | Page 2-22       |
| SCU_CHTR2              | SCU Channel Trigger 2 Register           | 0000 0838 <sub>H</sub>      | Page 2-22       |
| SCU_CHTR3              | SCU Channel Trigger 3 Register           | 0000 083C <sub>H</sub>      | Page 2-22       |
| SCU_CHTR4              | SCU Channel Trigger 4 Register           | 0000 0840 <sub>H</sub>      | Page 2-22       |
| SCU_CHTR5              | SCU Channel Trigger 5 Register           | 0000 0844 <sub>H</sub>      | Page 2-22       |
| SCU_CHTR6              | SCU Channel Trigger 6 Register           | 0000 0848 <sub>H</sub>      | Page 2-22       |
| SCU_CHTR7              | SCU Channel Trigger 7 Register           | 0000 084C <sub>H</sub>      | Page 2-22       |
| SCU_ETCTR              | SCU External Trigger Control<br>Register | 0000 0850 <sub>H</sub>      | Page 2-18       |
| Reserved               | Reserved                                 | 0000 0854 <sub>H</sub>      | -               |
| SCU_SRCR               | SCU Service Request Control<br>Register  | 0000 0858 <sub>H</sub>      | Page 2-19       |
| SCU_ERRCUM             | SCU Cumulative Error Register            | 0000 085C <sub>H</sub>      | Page 5-20       |



| Register Short<br>Name | Register Long Name           | Address                                               | Description see |
|------------------------|------------------------------|-------------------------------------------------------|-----------------|
| IDCHIP                 | Chip Identification Register | 0000 0860 <sub>H</sub>                                | Page 2-24       |
| Reserved               | Reserved                     | 0000 0864 <sub>H</sub><br>-<br>0000 08FF <sub>H</sub> | -               |

### Table 8-4SCU Registers (cont'd)

### Table 8-5SSC Registers

| Register Short<br>Name | Register Long Name                      | Address                                               | Description see |
|------------------------|-----------------------------------------|-------------------------------------------------------|-----------------|
| Reserved               | Reserved                                | 0000 0900 <sub>H</sub><br>-<br>0000 090C <sub>H</sub> | -               |
| SSC_CON                | SSC Control Register                    | 0000 0910 <sub>H</sub>                                | Page 5-15       |
| SSC_BR                 | SSC Baud Rate Timer Reload<br>Register  | 0000 0914 <sub>H</sub>                                | Page 5-22       |
| Reserved               | Reserved                                | 0000 0918 <sub>H</sub><br>-<br>0000 091C <sub>H</sub> | -               |
| SSC_TB                 | SSC Transmit Buffer Register            | 0000 0920 <sub>H</sub>                                | Page 5-21       |
| SSC_RB                 | SSC Receive Buffer Register             | 0000 0924 <sub>H</sub>                                | Page 5-22       |
| SSC_STAT               | SSC Status Register                     | 0000 0928 <sub>H</sub>                                | Page 5-18       |
| SSC_EFM                | SSC Error Flag Modification<br>Register | 0000 092C <sub>H</sub>                                | Page 5-19       |
| Reserved               | Reserved                                | 0000 0930 <sub>H</sub><br>-<br>0000 09FF <sub>H</sub> | -               |

# Table 8-6Port Registers

| Register Short<br>Name | Register Long Name                  | Address                | Description see |
|------------------------|-------------------------------------|------------------------|-----------------|
| P0_OUT                 | Port 0 Output Register              | 0000 0A00 <sub>H</sub> | Page 7-6        |
| P0_OMR                 | Port 0 Output Modification Register | 0000 0A04 <sub>H</sub> | Page 7-7        |



| Register Short<br>Name | Register Long Name                         | Address                     | Description see |
|------------------------|--------------------------------------------|-----------------------------|-----------------|
| Reserved               | Reserved                                   | 0000 0A08 <sub>H</sub>      | -               |
|                        |                                            | -<br>0000 0A0C <sub>H</sub> |                 |
| P0_IOCR0               | Port 0 Input/Output Control<br>Register 0  | 0000 0A10 <sub>H</sub>      | Page 7-8        |
| P0_IOCR4               | Port 0 Input/Output Control<br>Register 4  | 0000 0A14 <sub>H</sub>      | Page 7-9        |
| P0_IOCR8               | Port 0 Input/Output Control<br>Register 8  | 0000 0A18 <sub>H</sub>      | Page 7-10       |
| P0_IOCR12              | Port 0 Input/Output Control<br>Register 12 | 0000 0A1C <sub>H</sub>      | Page 7-11       |
| Reserved               | Reserved                                   | 0000 0A20 <sub>H</sub>      | -               |
| P0_IN                  | Port 0 Input Register                      | 0000 0A24 <sub>H</sub>      | Page 7-5        |
| Reserved               | Reserved                                   | 0000 0A28 <sub>H</sub><br>- | -               |
|                        |                                            | 0000 0A60 <sub>H</sub>      |                 |
| P1_IN                  | Port 1 Input Register                      | 0000 0A64 <sub>H</sub>      | Page 7-15       |
| Reserved               | Reserved                                   | 0000 0A68 <sub>H</sub><br>- | -               |
|                        |                                            | 0000 0AFF <sub>H</sub>      |                 |

### Table 8-6 Port Registers (cont'd)

### Table 8-7ADC Registers

| Register Short<br>Name | Register Long Name     | Address                                               | Description see |
|------------------------|------------------------|-------------------------------------------------------|-----------------|
| Reserved               | Reserved               | 0000 1000 <sub>H</sub><br>-<br>0000 100E <sub>H</sub> | -               |
| ADC_CON                | ADC Control Register   | 0000 1010 <sub>H</sub>                                | Page 6-21       |
| ADC_CON1               | ADC Control 1 Register | 0000 1012 <sub>H</sub>                                | Page 6-23       |
| Reserved               | Reserved               | 0000 1014 <sub>H</sub><br>-<br>0000 101E <sub>H</sub> | -               |
| ADC_CTR2               | ADC Control 2 Register | 0000 1020 <sub>H</sub>                                | Page 6-25       |



| Register Short<br>Name | Register Long Name                        | Address                     | Description see |
|------------------------|-------------------------------------------|-----------------------------|-----------------|
| ADC_CTR2IN             | ADC Injection Control 2 Register          | 0000 1022 <sub>H</sub>      | Page 6-26       |
| ADC_CTR0               | ADC Control 0 Register                    | 0000 1024 <sub>H</sub>      | Page 6-24       |
| Reserved               | Reserved                                  | 0000 1026 <sub>H</sub><br>- | -               |
|                        |                                           | 0000 101E <sub>H</sub>      |                 |
| ADC_DAT                | ADC Result Register                       | 0000 1030 <sub>H</sub>      | Page 6-27       |
| ADC_DAT2               | ADC Result 2 Register                     | 0000 1032 <sub>H</sub>      | Page 6-27       |
| Reserved               | Reserved                                  | 0000 1034 <sub>H</sub><br>- | -               |
|                        |                                           | 0000 10FE <sub>H</sub>      |                 |
| ADC_RESA0              | ADC Extended Result 0 View A Register     | 0000 1100 <sub>H</sub>      | Page 6-30       |
| ADC_RESA1              | ADC Extended Result 1 View A<br>Register  | 0000 1104 <sub>H</sub>      | Page 6-30       |
| ADC_RESA2              | ADC Extended Result 2 View A Register     | 0000 1108 <sub>H</sub>      | Page 6-30       |
| ADC_RESA3              | ADC Extended Result 3 View A Register     | 0000 110C <sub>H</sub>      | Page 6-30       |
| ADC_RESA4              | ADC Extended Result 4 View A Register     | 0000 1110 <sub>H</sub>      | Page 6-30       |
| ADC_RESA5              | ADC Extended Result 5 View A Register     | 0000 1114 <sub>H</sub>      | Page 6-30       |
| ADC_RESA6              | ADC Extended Result 6 View A Register     | 0000 1118 <sub>H</sub>      | Page 6-30       |
| ADC_RESA7              | ADC Extended Result 7 View A Register     | 0000 111C <sub>H</sub>      | Page 6-30       |
| ADC_RESA8              | ADC Extended Result 8 View A Register     | 0000 1120 <sub>H</sub>      | Page 6-30       |
| ADC_RESA9              | ADC Extended Result 9 View A<br>Register  | 0000 1124 <sub>H</sub>      | Page 6-30       |
| ADC_RESA10             | ADC Extended Result 10 View A<br>Register | 0000 1128 <sub>H</sub>      | Page 6-30       |

### Table 8-7 ADC Registers (cont'd)



| Register Short<br>Name | Register Long Name                        | Address                | Description see |
|------------------------|-------------------------------------------|------------------------|-----------------|
| ADC_RESA11             | ADC Extended Result 11 View A<br>Register | 0000 112C <sub>H</sub> | Page 6-30       |
| ADC_RESA12             | ADC Extended Result 12 View A<br>Register | 0000 1130 <sub>H</sub> | Page 6-30       |
| ADC_RESA13             | ADC Extended Result 13 View A Register    | 0000 1134 <sub>H</sub> | Page 6-30       |
| ADC_RESA14             | ADC Extended Result 14 View A Register    | 0000 1138 <sub>H</sub> | Page 6-30       |
| ADC_RESA15             | ADC Extended Result 15 View A Register    | 0000 113C <sub>H</sub> | Page 6-30       |
| ADC_RESB0              | ADC Extended Result 0 View B<br>Register  | 0000 1140 <sub>H</sub> | Page 6-32       |
| ADC_RESB1              | ADC Extended Result 1 View B<br>Register  | 0000 1144 <sub>H</sub> | Page 6-32       |
| ADC_RESB2              | ADC Extended Result 2 View B<br>Register  | 0000 1148 <sub>H</sub> | Page 6-32       |
| ADC_RESB3              | ADC Extended Result 3 View B<br>Register  | 0000 114C <sub>H</sub> | Page 6-32       |
| ADC_RESB4              | ADC Extended Result 4 View B<br>Register  | 0000 1150 <sub>H</sub> | Page 6-32       |
| ADC_RESB5              | ADC Extended Result 5 View B<br>Register  | 0000 1154 <sub>H</sub> | Page 6-32       |
| ADC_RESB6              | ADC Extended Result 6 View B<br>Register  | 0000 1158 <sub>H</sub> | Page 6-32       |
| ADC_RESB7              | ADC Extended Result 7 View B<br>Register  | 0000 115C <sub>H</sub> | Page 6-32       |
| ADC_RESB8              | ADC Extended Result 8 View B<br>Register  | 0000 1160 <sub>H</sub> | Page 6-32       |
| ADC_RESB9              | ADC Extended Result 9 View B<br>Register  | 0000 1164 <sub>H</sub> | Page 6-32       |
| ADC_RESB10             | ADC Extended Result 10 View B<br>Register | 0000 1168 <sub>H</sub> | Page 6-32       |
| ADC_RESB11             | ADC Extended Result 11 View B<br>Register | 0000 116C <sub>H</sub> | Page 6-32       |

### Table 8-7 ADC Registers (cont'd)



| Register Short<br>Name | Register Long Name                        | Address                                               | Description see |
|------------------------|-------------------------------------------|-------------------------------------------------------|-----------------|
| ADC_RESB12             | ADC Extended Result 12 View B<br>Register | 0000 1170 <sub>H</sub>                                | Page 6-32       |
| ADC_RESB13             | ADC Extended Result 13 View B<br>Register | 0000 1174 <sub>H</sub>                                | Page 6-32       |
| ADC_RESB14             | ADC Extended Result 14 View B<br>Register | 0000 1178 <sub>H</sub>                                | Page 6-32       |
| ADC_RESB15             | ADC Extended Result 15 View B<br>Register | 0000 117C <sub>H</sub>                                | Page 6-32       |
| ADC_INRES              | ADC Input Result Register                 | 0000 1180 <sub>H</sub>                                | Page 6-33       |
| ADC_DBCTR              | ADC Doorbell Control Register             | 0000 1184 <sub>H</sub>                                | Page 6-35       |
| ADC_RESV               | ADC Result Valid Register                 | 0000 1188 <sub>H</sub>                                | Page 6-34       |
| Reserved               | Reserved                                  | 0000 118C <sub>H</sub><br>-<br>0000 11FF <sub>H</sub> | -               |

### Table 8-7 ADC Registers (cont'd)

# 8.3 Memory Registers

Within the DMA and the MLI address area there are some memory register defined in **Table 8-2** and **Table 8-3**. These registers can be used as memory registers if needed. All memory registers in **Table 8-8** are 32-bit register that can be read and written from all masters. All memory registers in **Table 8-9** are 16-bit register that can be read and written from all masters. Register DMA\_MEM14 in **Table 8-10** is a 8-bit register that can be read and written from all masters.

| Register<br>Short Name | Register Long Name    | Address                | Description see |
|------------------------|-----------------------|------------------------|-----------------|
| MLI_MEM0               | MLI Memory 0 Register | 0000 02B8 <sub>H</sub> | -               |
| MLI_MEM1               | MLI Memory 1 Register | 0000 02BC <sub>H</sub> | -               |
| DMA_MEM0               | DMA Memory 0 Register | 0000 043C <sub>H</sub> | -               |
| DMA_MEM1               | DMA Memory 1 Register | 0000 0440 <sub>H</sub> | -               |
| DMA_MEM2               | DMA Memory 2 Register | 0000 0444 <sub>H</sub> | -               |
| DMA_MEM3               | DMA Memory 3 Register | 0000 0448 <sub>H</sub> | -               |

### Table 8-8 32-Bit Memory Registers



| Register<br>Short Name | Register Long Name    | Address                | Description see |  |  |
|------------------------|-----------------------|------------------------|-----------------|--|--|
| DMA_MEM4               | DMA Memory 4 Register | 0000 044C <sub>H</sub> | -               |  |  |
| DMA_MEM5               | DMA Memory 5 Register | 0000 0450 <sub>H</sub> | -               |  |  |

### Table 8-8 32-Bit Memory Registers (cont'd)

### Table 8-916-Bit Memory Registers

| Register<br>Short Name | Register Long Name     | Address                | Description see |
|------------------------|------------------------|------------------------|-----------------|
| DMA_MEM6               | DMA Memory 6 Register  | 0000 0488 <sub>H</sub> | -               |
| DMA_MEM7               | DMA Memory 7 Register  | 0000 04A8 <sub>H</sub> | -               |
| DMA_MEM8               | DMA Memory 8 Register  | 0000 04C8 <sub>H</sub> | -               |
| DMA_MEM9               | DMA Memory 9 Register  | 0000 04E8 <sub>H</sub> | -               |
| DMA_MEM10              | DMA Memory 10 Register | 0000 0508 <sub>H</sub> | -               |
| DMA_MEM11              | DMA Memory 11 Register | 0000 0528 <sub>H</sub> | -               |
| DMA_MEM12              | DMA Memory 12 Register | 0000 0548 <sub>H</sub> | -               |
| DMA_MEM13              | DMA Memory 13 Register | 0000 0568 <sub>H</sub> | -               |

### Table 8-108-Bit Memory Registers

| Register<br>Short Name | Register Long Name     | Address                | Description see |
|------------------------|------------------------|------------------------|-----------------|
| DMA_MEM14              | DMA Memory 14 Register | 0000 0468 <sub>H</sub> | -               |



### **Keyword Index**

# **Keyword Index**

# Α

ADC 6-1 Address map of segment 15 8-1 Analog/Digital Converter 6-1

# С

Calibration 6-11 Clock System 2-2 Oscillator run detection 2-9 Clock system PLL, see "PLL" Control reset 2-1 Conversion analog/digital 6-1 timing control 6-12

# D

DMA 3-8 Block diagram 3-8 Channel operation 3-12 Channel operation modes 3-16 Channel request control 3-15 Channel reset operation 3-20 Circular buffer 3-24 Definition of terms 3-10 Features 3-9 Principle 3-2 Transaction control 3-25

# Μ

MLI Communication principles 4-3 Frames Answer frame 4-14 Command frame 4-13 Copy base address frame 4-8 Optimized read frame 4-12 Optimized write frame 4-10 Write offset and data frame 4-9

Interrupts Receiver interrupts 4-43 Transmitter interrupts 4-41 Kernel registers 4-47 MLI Specific Terms 4-2 Registers **Overview 4-47** Transaction flow diagrams Command frame 4-31 Copy base address 4-20 Read frame 4-26 Write frame 4-22 Transmitter Description of frame transmission 4-19 Typical application 4-1

# Ρ

PLL Features 2-4 Functionality 2-4 Ports Output register Pn\_OUT 7-5, 7-15 Port 0 I/O functions 7-3, 7-14

# R

Register overview and address map 8-1 Reset control block 2-1

# S

Self-calibration 6-11 SSC Block diagram 5-2 Error detection 5-14 Full-duplex operation 5-3 Half-duplex operation 5-6 Interrupts 5-14 Module implementation Port control 5-23



Keyword Index

www.infineon.com

Published by Infineon Technologies AG