The revision list summarizes the locations of revisions and additions. Details should always be checked by referring to the relevant text. # SH7670 Group User's Manual: Hardware Renesas 32-Bit RISC Microcomputer SuperH<sup>™</sup> RISC engine Family / SH7670 Series > SH7670 R5S76700 SH7671 R5S76710 R5S76720 SH7672 SH7673 R5S76730 All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com). #### Notice - 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Reneasa Electronics products listed herein, please confirm the latest product information with a Reneasa Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website. - 2. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others. - 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. - 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information. - 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. - 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein. - 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application for which it is not intended without the prior written consent of Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc. - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots. - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anticrime systems; safety equipment; and medical equipment not specifically designed for life support. - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life. - 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges. - 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you. - 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations. - 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics - 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries. - (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majorityowned subsidiaries. - (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics. # General Precautions in the Handling of MPU/MCU Products The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each other, the description in the body of the manual takes precedence. ## 1. Handling of Unused Pins Handle unused pins in accord with the directions given under Handling of Unused Pins in the manual. The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual. ## 2. Processing at Power-on The state of the product is undefined at the moment when power is supplied. - The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied. - In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed. In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified. ### 3. Prohibition of Access to Reserved Addresses Access to reserved addresses is prohibited. The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed. ## 4. Clock Signals After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized. — When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable. ### 5. Differences between Products Before changing from one product to another, i.e. to one with a different type number, confirm that the change will not lead to problems. The characteristics of MPU/MCU in the same group but having different type numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different type numbers, implement a system-evaluation test for each of the products. # How to Use This Manual # 1. Objective and Target Users This manual was written to explain the hardware functions and electrical characteristics of this LSI to the target users, i.e. those who will be using this LSI in the design of application systems. Target users are expected to understand the fundamentals of electrical circuits, logic circuits, and microcomputers. This manual is organized in the following items: an overview of the product, descriptions of the CPU, system control functions, and peripheral functions, electrical characteristics of the device, and usage notes. When designing an application system that includes this LSI, take all points to note into account. Points to note are given in their contexts and at the final part of each section, and in the section giving usage notes. The list of revisions is a summary of major points of revision or addition for earlier versions. It does not cover all revised items. For details on the revised points, see the actual locations in the manual. The following documents have been prepared for the SH7670 Group. Before using any of the documents, please visit our web site to verify that you have the most up-to-date available version of the document. | Document Type | Contents | Document Title | Document No. | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------| | Data Sheet | Overview of hardware and electrical characteristics | _ | _ | | User's manual for<br>Hardware | Hardware specifications (pin<br>assignments, memory maps,<br>peripheral specifications, electrical<br>characteristics, and timing charts)<br>and descriptions of operation | SH7670 Group<br>User's Manual: Hardware | This User's<br>manual | | User's manual for<br>Software | Detailed descriptions of the CPU and instruction set | SH-2A, SH2A-FPU<br>Software Manual | REJ09B0051 | | Application Note | Examples of applications and sample programs | The latest versions are available web site. | ailable from our | | Renesas Technical<br>Update | Preliminary report on the specifications of a product, document, etc. | _ | | ## 2. Description of Numbers and Symbols Aspects of the notations for register names, bit names, numbers, and symbolic names in this manual are explained below. #### (1) Overall notation In descriptions involving the names of bits and bit fields within this manual, the modules and registers to which the bits belong may be clarified by giving the names in the forms "module name". "register name". "bit name" or "register name". "bit name". #### (2) Register notation The style "register name"\_"instance number" is used in cases where there is more than one instance of the same function or similar functions. [Example] CMCSR\_0: Indicates the CMCSR register for the compare-match timer of channel 0. #### (3) Number notation Binary numbers are given as B'nnnn (B' may be omitted if the number is obviously binary), hexadecimal numbers are given as H'nnnn or 0xnnnn, and decimal numbers are given as nnnn. [Examples] Binary: B'11 or 11 Hexadecimal: H'EFA0 or 0xEFA0 Decimal: 1234 #### (4) Notation for active-low An overbar $\underline{\text{on the name}}$ indicates that a signal or pin is active-low. [Example] WDTOVF Note: The bit names and sentences in the above figure are examples and have nothing to do with the contents of this manual. ## 3. Description of Registers Each register description includes a bit chart, illustrating the arrangement of bits, and a table of bits, describing the meanings of the bit settings. The standard format and notation for bit charts and tables are described below. Note: The bit names and sentences in the above figure are examples, and have nothing to do with the contents of this manual. #### (1) Bit Indicates the bit number or numbers. In the case of a 32-bit register, the bits are arranged in order from 31 to 0. In the case of a 16-bit register, the bits are arranged in order from 15 to 0. #### (2) Bit name Indicates the name of the bit or bit field. When the number of bits has to be clearly indicated in the field, appropriate notation is included (e.g., ASID[3:0]). A reserved bit is indicated by "-". Certain kinds of bits, such as those of timer counters, are not assigned bit names. In such cases, the entry under Bit Name is blank. #### (3) Initial value Indicates the value of each bit immediately after a power-on reset, i.e., the initial value. - 0: The initial value is 0 - 1: The initial value is 1 - -: The initial value is undefined #### (4) R/W For each bit and bit field, this entry indicates whether the bit or field is readable or writable, or both writing to and reading from the bit or field are impossible. The notation is as follows: R/W: The bit or field is readable and writable. R/(W): The bit or field is readable and writable. However, writing is only performed to flag clearing. R: The bit or field is readable. "R" is indicated for all reserved bits. When writing to the register, write the value under Initial Value in the bit chart to reserved bits or fields. W: The bit or field is writable. #### (5) Description Describes the function of the bit or field and specifies the values for writing. # 4. Description of Abbreviations The abbreviations used in this manual are listed below. • Abbreviations specific to this product | Abbreviation | Description | |--------------|--------------------------| | BSC | Bus controller | | CPG | Clock pulse generator | | DTC | Data transfer controller | | INTC | Interrupt controller | # • Abbreviations other than those listed above | Abbreviation | Description | |--------------|-----------------------------------------------| | ACIA | Asynchronous communications interface adapter | | bps | Bits per second | | CRC | Cyclic redundancy check | | DMA | Direct memory access | | DMAC | Direct memory access controller | | GSM | Global System for Mobile Communications | | Hi-Z | High impedance | | I/O | Input/output | | IrDA | Infrared Data Association | | LSB | Least significant bit | | MSB | Most significant bit | | NC | No connection | | PLL | Phase-locked loop | | PWM | Pulse width modulation | | SFR | Special function register | | SIM | Subscriber Identity Module | | UART | Universal asynchronous receiver/transmitter | | VCO | Voltage-controlled oscillator | All trademarks and registered trademarks are the property of their respective owners. # Contents | Secti | on 1 ( | Overview | 1 | | |-------|----------------|---------------------------------------|----|--| | 1.1 | Feature | S | 1 | | | 1.2 | Applica | ations | 2 | | | 1.3 | Overvie | ew of Specifications | 2 | | | 1.4 | Product Lineup | | | | | 1.5 | Block I | Diagram | 13 | | | 1.6 | Pin Ass | ignments | 14 | | | 1.7 | Pin Fur | actions | 15 | | | ~ . | | | | | | | | CPU | | | | 2.1 | _ | r Configuration | | | | | 2.1.1 | General Registers | | | | | 2.1.2 | Control Registers | | | | | 2.1.3 | System Registers | | | | | 2.1.4 | Register Banks | | | | | 2.1.5 | Initial Values of Registers | | | | 2.2 | | ormats | | | | | 2.2.1 | Data Format in Registers | | | | | 2.2.2 | Data Formats in Memory | | | | | 2.2.3 | Immediate Data Format | | | | 2.3 | Instruct | ion Features | | | | | 2.3.1 | RISC-Type Instruction Set | | | | | 2.3.2 | Addressing Modes | | | | | 2.3.3 | Instruction Format | 47 | | | 2.4 | Instruct | ion Set | 51 | | | | 2.4.1 | Instruction Set by Classification | 51 | | | | 2.4.2 | Data Transfer Instructions | 57 | | | | 2.4.3 | Arithmetic Operation Instructions | 61 | | | | 2.4.4 | Logic Operation Instructions | 64 | | | | 2.4.5 | Shift Instructions | 65 | | | | 2.4.6 | Branch Instructions | 66 | | | | 2.4.7 | System Control Instructions | 67 | | | | 2.4.8 | Floating-Point Operation Instructions | 69 | | | | 2.4.9 | FPU-Related CPU Instructions | 71 | | | | 2.4.10 | Bit Manipulation Instructions | 72 | | | 2.5 | Process | ing States | 74 | | | Sect | tion 3 | Floating-Point Unit (FPU) | 77 | |------|--------|------------------------------------------------|-----| | 3.1 | Featur | res | 77 | | 3.2 | Data I | Formats | 78 | | | 3.2.1 | Floating-Point Format | 78 | | | 3.2.2 | Non-Numbers (NaN) | 81 | | | 3.2.3 | Denormalized Numbers | 82 | | 3.3 | Regist | ter Descriptions | 83 | | | 3.3.1 | Floating-Point Registers | 83 | | | 3.3.2 | Floating-Point Status/Control Register (FPSCR) | 84 | | | 3.3.3 | Floating-Point Communication Register (FPUL) | 85 | | 3.4 | Round | ding | 86 | | 3.5 | Floati | ng-Point Exceptions | 87 | | | 3.5.1 | FPU Exception Sources | 87 | | | 3.5.2 | FPU Exception Handling | | | Sect | tion 4 | Cache | 89 | | 4.1 | Featur | res | | | | 4.1.1 | Cache Structure | | | 4.2 | Regist | ter Descriptions | | | | 4.2.1 | Cache Control Register 1 (CCR1) | | | | 4.2.2 | Cache Control Register 2 (CCR2) | | | 4.3 | Opera | tion | | | | 4.3.1 | Searching Cache | | | | 4.3.2 | Read Access | | | | 4.3.3 | Prefetch Operation (Only for Operand Cache) | | | | 4.3.4 | Write Operation (Only for Operand Cache) | | | | 4.3.5 | Write-Back Buffer (Only for Operand Cache) | | | | 4.3.6 | Coherency of Cache and External Memory | | | 4.4 | Memo | ory-Mapped Cache | | | | 4.4.1 | Address Array | | | | 4.4.2 | Data Array | 105 | | | 4.4.3 | Usage Examples | | | | 4.4.4 | Notes | | | Sect | tion 5 | Exception Handling | 109 | | 5.1 | Overv | riew | | | | 5.1.1 | Types of Exception Handling and Priority | 109 | | | 5.1.2 | Exception Handling Operations | | | | 5.1.3 | Exception Handling Vector Table | | | 5.2 | Resets | • | 115 | | | 5.2.1 | Input/Output Pins | 115 | |------|---------|-------------------------------------------------------------------------------|-----| | | 5.2.2 | Types of Reset | | | | 5.2.3 | Power-On Reset | | | | 5.2.4 | Manual Reset | 118 | | 5.3 | Addre | ss Errors | 119 | | | 5.3.1 | Address Error Sources | 119 | | | 5.3.2 | Address Error Exception Handling | | | 5.4 | Regist | er Bank Errors | | | | 5.4.1 | Register Bank Error Sources | 121 | | | 5.4.2 | Register Bank Error Exception Handling | 121 | | 5.5 | Interru | ipts | | | | 5.5.1 | Interrupt Sources | 122 | | | 5.5.2 | Interrupt Priority Level | 123 | | | 5.5.3 | Interrupt Exception Handling | 124 | | 5.6 | Excep | tions Triggered by Instructions | 125 | | | 5.6.1 | Types of Exceptions Triggered by Instructions | 125 | | | 5.6.2 | Trap Instructions | 126 | | | 5.6.3 | Slot Illegal Instructions | 126 | | | 5.6.4 | General Illegal Instructions | 126 | | | 5.6.5 | Integer Division Instructions | 127 | | | 5.6.6 | Floating-Point Operation Instruction | 128 | | 5.7 | When | Exception Sources Are Not Accepted | | | 5.8 | Stack | Status after Exception Handling Ends | 130 | | 5.9 | Usage | Notes | 132 | | | 5.9.1 | Value of Stack Pointer (SP) | 132 | | | 5.9.2 | Value of Vector Base Register (VBR) | 132 | | | 5.9.3 | Address Errors Caused by Stacking of Address Error Exception Handling | 132 | | Sect | tion 6 | Interrupt Controller (INTC) | 133 | | 6.1 | | es | | | 6.2 | | Output Pins | | | 6.3 | | er Descriptions | | | | 6.3.1 | Interrupt Priority Registers 01, 02, 06 to 16 (IPR01, IPR02, IPR06 to IPR16). | | | | 6.3.2 | Interrupt Control Register 0 (ICR0) | | | | 6.3.3 | Interrupt Control Register 1 (ICR1) | | | | 6.3.4 | IRQ Interrupt Request Register (IRQRR) | | | | 6.3.5 | Bank Control Register (IBCR). | | | | 6.3.6 | Bank Number Register (IBNR) | | | 6.4 | | ipt Sources | | | | 6.4.1 | NMI Interrupt | | | | | | | | | 6.4.2 | User Break Interrupt | 145 | |------|---------|---------------------------------------------------------------------------|-------| | | 6.4.3 | H-UDI Interrupt | 145 | | | 6.4.4 | IRQ Interrupts | 146 | | | 6.4.5 | On-Chip Peripheral Module Interrupts | . 147 | | 6.5 | Interru | pt Exception Handling Vector Table and Priority | . 148 | | 6.6 | Operat | ion | 153 | | | 6.6.1 | Interrupt Operation Sequence | 153 | | | 6.6.2 | Stack after Interrupt Exception Handling | 156 | | 6.7 | Interru | pt Response Time | 157 | | 6.8 | Regist | er Banks | 163 | | | 6.8.1 | Banked Register and Input/Output of Banks | 164 | | | 6.8.2 | Bank Save and Restore Operations | 164 | | | 6.8.3 | Save and Restore Operations after Saving to All Banks | | | | 6.8.4 | Register Bank Exception | 167 | | | 6.8.5 | Register Bank Error Exception Handling | 167 | | 6.9 | Data T | ransfer with Interrupt Request Signals | 168 | | | 6.9.1 | Handling Interrupt Request Signals as Sources for CPU Interrupt but Not | | | | | DMAC Activating | 169 | | | 6.9.2 | Handling Interrupt Request Signals as Sources for Activating DMAC but Not | | | | | CPU Interrupt | 169 | | 6.10 | Usage | Note | 170 | | | 6.10.1 | Timing to Clear an Interrupt Source | 170 | | | | | | | Sect | ion 7 | Bus State Controller (BSC) | .171 | | 7.1 | Featur | es | 171 | | 7.2 | Input/0 | Output Pins | 174 | | 7.3 | Area C | Overview | 176 | | | 7.3.1 | Address Map | 176 | | | 7.3.2 | Data Bus Width and Pin Function Setting in Each Area | 177 | | 7.4 | Regist | er Descriptions | 178 | | | 7.4.1 | Common Control Register (CMNCR) | 179 | | | 7.4.2 | CSn Space Bus Control Register (CSnBCR) (n = 0, 3 to 6) | 181 | | | 7.4.3 | CSn Space Wait Control Register (CSnWCR) (n = 0, 3 to 6) | 186 | | | 7.4.4 | SDRAM Control Register (SDCR) | 207 | | | 7.4.5 | Refresh Timer Control/Status Register (RTCSR) | 210 | | | 7.4.6 | Refresh Timer Counter (RTCNT) | 212 | | | 7.4.7 | Refresh Time Constant Register (RTCOR) | 213 | | | 7.4.8 | Internal Bus Master Bus Priority Register (IBMPR) | 214 | | 7.5 | Operat | ion | 216 | | | 751 | Endian/Access Size and Data Alignment | 216 | | | 7.5.2 | Normal Space Interface | 223 | |------|--------|------------------------------------------------------------|-----| | | 7.5.3 | Access Wait Control | 228 | | | 7.5.4 | CSn Assert Period Expansion | 230 | | | 7.5.5 | SDRAM Interface | 231 | | | 7.5.6 | SRAM Interface with Byte Selection | | | | 7.5.7 | PCMCIA Interface | 276 | | | 7.5.8 | Wait between Access Cycles | 283 | | | 7.5.9 | Others | | | Sect | ion 8 | Direct Memory Access Controller (DMAC) | 293 | | 8.1 | | res | | | 8.2 | Input/ | Output Pins | 296 | | 8.3 | Regist | er Descriptions | 297 | | | 8.3.1 | DMA Source Address Registers (SAR) | 301 | | | 8.3.2 | DMA Destination Address Registers (DAR) | 302 | | | 8.3.3 | DMA Transfer Count Registers (DMATCR) | 302 | | | 8.3.4 | DMA Channel Control Registers (CHCR) | 303 | | | 8.3.5 | DMA Reload Source Address Registers (RSAR) | 312 | | | 8.3.6 | DMA Reload Destination Address Registers (RDAR) | 313 | | | 8.3.7 | DMA Reload Transfer Count Registers (RDMATCR) | 314 | | | 8.3.8 | DMA Operation Register (DMAOR) | 315 | | | 8.3.9 | DMA Extension Resource Selectors 0 to 3 (DMARS0 to DMARS3) | 319 | | 8.4 | Opera | tion | 321 | | | 8.4.1 | Transfer Flow | 321 | | | 8.4.2 | DMA Transfer Requests | 323 | | | 8.4.3 | Channel Priority | 327 | | | 8.4.4 | DMA Transfer Types | 330 | | | 8.4.5 | Number of Bus Cycles and DREQ Pin Sampling Timing | 339 | | 8.5 | Usage | Notes | | | | 8.5.1 | NMIF Bit (NMI Flag) in DMA Operation Register (DMAOR) | 343 | | | 8.5.2 | Half-End Flag Setting and Half-End Interrupt Generation | 343 | | Sect | ion 9 | Clock Pulse Generator (CPG) | 345 | | 9.1 | Featur | es | 345 | | 9.2 | Input/ | Output Pins | 349 | | 9.3 | Clock | Operating Modes | 351 | | 9.4 | Regist | er Descriptions | 356 | | | 9.4.1 | Frequency Control Register (FRQCR) | | | 9.5 | Chang | ring the Frequency | | | | 9.5.1 | Changing the Multiplication Rate | 359 | | | 9.5.2 | Changing the Division Ratio | 360 | |------|---------|------------------------------------------------|-----| | 9.6 | Notes o | on Board Design | 361 | | | 9.6.1 | Note on Inputting External Clock | 361 | | | 9.6.2 | Note on Using an External Crystal Resonator | 361 | | | 9.6.3 | Note on Resonator | 362 | | | 9.6.4 | Note on Using a PLL Oscillation Circuit | 362 | | Sect | ion 10 | Watchdog Timer (WDT) | 363 | | 10.1 | Feature | es | 363 | | 10.2 | | Output Pin | | | 10.3 | _ | er Descriptions | | | | | Watchdog Timer Counter (WTCNT) | | | | 10.3.2 | Watchdog Timer Control/Status Register (WTCSR) | 366 | | | 10.3.3 | Watchdog Reset Control/Status Register (WRCSR) | 368 | | | 10.3.4 | Notes on Register Access | 369 | | 10.4 | | Usage | | | | 10.4.1 | Canceling Software Standby Mode | 371 | | | 10.4.2 | Changing the Frequency | 371 | | | 10.4.3 | Using Watchdog Timer Mode | 372 | | | 10.4.4 | Using Interval Timer Mode | 374 | | 10.5 | Usage | Notes | 375 | | | 10.5.1 | Timer Variation | 375 | | | 10.5.2 | Prohibition against Setting H'FF to WTCNT | 375 | | | 10.5.3 | System Reset by WDTOVF Signal | 375 | | | | Manual Reset in Watchdog Timer Mode | | | Sect | ion 11 | Power-Down Modes | 377 | | 11.1 | Feature | es | 377 | | | 11.1.1 | Power-Down Modes | 377 | | 11.2 | Registe | er Descriptions | 378 | | | 11.2.1 | Standby Control Register (STBCR) | 379 | | | 11.2.2 | Standby Control Register 2 (STBCR2) | 380 | | | 11.2.3 | Standby Control Register 3 (STBCR3) | 382 | | | 11.2.4 | Standby Control Register 4 (STBCR4) | 384 | | | 11.2.5 | System Control Register 1 (SYSCR1) | 386 | | | 11.2.6 | System Control Register 2 (SYSCR2) | 388 | | | | System Control Register 3 (SYSCR3) | | | 11.3 | | ion | | | | 11.3.1 | Sleep Mode | 391 | | | 11.3.2 | Software Standby Mode | 392 | | | 11.3.3 | Software Standby Mode Application Example | 394 | |------|--------|-------------------------------------------------------|-----| | | | Module Standby Function | | | 11.4 | Usage | Notes | 396 | | Sact | ion 12 | Ethernet Controller (EtherC) | 307 | | 12.1 | | es | | | 12.1 | | Output Pins | | | 12.2 | - | er Description | | | 12.3 | _ | EtherC Mode Register (ECMR) | | | | | EtherC Status Register (ECSR) | | | | | EtherC Interrupt Permission Register (ECSIPR) | | | | | PHY Interface Register (PIR) | | | | | MAC Address High Register (MAHR) | | | | | MAC Address Low Register (MALR) | | | | | Receive Frame Length Register (RFLR) | | | | | PHY Status Register (PSR) | | | | | Transmit Retry Over Counter Register (TROCR) | | | | | Delayed Collision Detect Counter Register (CDCR) | | | | | Lost Carrier Counter Register (LCCR) | | | | | 2 Carrier Not Detect Counter Register (CNDCR) | | | | | 3 CRC Error Frame Counter Register (CEFCR) | | | | | Frame Receive Error Counter Register (FRECR) | | | | | 5 Too-Short Frame Receive Counter Register (TSFRCR) | | | | | 5 Too-Long Frame Receive Counter Register (TLFRCR) | | | | | 7 Residual-Bit Frame Counter Register (RFCR) | | | | | 3 Multicast Address Frame Counter Register (MAFCR) | | | | | P IPG Register (IPGR) | | | | | Automatic PAUSE Frame Set Register (APR) | | | | | Manual PAUSE Frame Set Register (MPR) | | | | | 2 PAUSE Frame Retransfer Count Set Register (TPAUSER) | | | 12.4 | | ion | | | | - | Transmission | | | | 12.4.2 | Reception | 429 | | | | MII Frame Timing | | | | | Accessing MII Registers | | | | 12.4.5 | Magic Packet Detection | 435 | | | | Operation by IPG Setting | | | | 12.4.7 | Flow Control | 436 | | 12.5 | Connec | ction to PHY-LSI | 437 | | 12.6 | Usage | Notes | 438 | | Sect | ion 13 | Ethernet Controller Direct Memory Access Controller (E-DMAC) | /30 | |------|---------|--------------------------------------------------------------|-----| | 13.1 | Footura | (E-DNAC) | | | 13.2 | | r Descriptions | | | 13.2 | | E-DMAC Mode Register (EDMR) | | | | | E-DMAC Transmit Request Register (EDTRR) | | | | | E-DMAC Receive Request Register (EDRRR) | | | | | Transmit Descriptor List Address Register (TDLAR) | | | | | Receive Descriptor List Address Register (RDLAR) | | | | | EtherC/E-DMAC Status Register (EESR) | | | | | EtherC/E-DMAC Status Interrupt Permission Register (EESIPR) | | | | | Transmit/Receive Status Copy Enable Register (TRSCER) | | | | | Receive Missed-Frame Counter Register (RMFCR) | | | | | Transmit FIFO Threshold Register (TFTR) | | | | | FIFO Depth Register (FDR) | | | | | Receiving Method Control Register (RMCR) | | | | | E-DMAC Operation Control Register (EDOCR) | | | | | Receiving-Buffer Write Address Register (RBWAR) | | | | | Receiving-Descriptor Fetch Address Register (RDFAR) | | | | 13.2.16 | Transmission-Buffer Read Address Register (TBRAR) | 463 | | | | Transmission-Descriptor Fetch Address Register (TDFAR) | | | | 13.2.18 | Flow Control FIFO Threshold Register (FCFTR) | 464 | | | | Receive Data Padding Setting Register (RPADIR) | | | | 13.2.20 | Transmit Interrupt Register (TRIMD) | 467 | | | 13.2.21 | Checksum Mode Register (CSMR) | 467 | | | 13.2.22 | Checksum Skipped Bytes Monitor Register (CSSBM) | 469 | | | 13.2.23 | Checksum Monitor Register (CSSMR) | 470 | | 13.3 | Operati | on | 471 | | | 13.3.1 | Descriptor List and Data Buffers | 471 | | | 13.3.2 | Transmission | 483 | | | 13.3.3 | Reception | 485 | | | 13.3.4 | Multi-Buffer Frame Transmit/Receive Processing | 487 | | | | Padding Receive Data | | | | | Checksum Calculation Function | | | | 13.3.7 | Usage Notes | 493 | | Sect | ion 14 | DMAC That Works with Encryption/Decryption and Forward | | | | | Error Correction Core (A-DMAC) | 495 | | 14.1 | Overvio | ew | 495 | | | 14 1 1 | Features | 495 | | 14.1.3 | Restrictions on the A-DMAC | 499 | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------| | Registe | er Descriptions | 500 | | 14.2.1 | Channel [i] Processing Control Register (C[i]C) (i = 0, 1) | 501 | | 14.2.2 | Channel [i] Processing Mode Register (C[i]M) (i = 0, 1) | 504 | | 14.2.3 | Channel [i] Processing Interrupt Request Register (C[i]I) (i = 0, 1) | 505 | | 14.2.4 | Channel [i] Processing Descriptor Start Address Register (C[i]DSA) | | | | (i = 0, 1) | 507 | | 14.2.5 | Channel [i] Processing Descriptor Current Address Register (C[i]DCA) | | | | (i = 0, 1) | | | 14.2.6 | Channel [i] Processing Descriptor 0 Register (C[i]D0) [Control] (i = 0, 1) | 509 | | 14.2.7 | Channel [i] Processing Descriptor 1 Register (C[i]D1) | | | | [Source Address] (i = 0, 1) | 515 | | 14.2.8 | Channel [i] Processing Descriptor 2 Register (C[i]D2) | | | | [Destination Address] (i = 0, 1) | 516 | | 14.2.9 | Channel [i] Processing Descriptor 3 Register (C[i]D3) | | | | [Data Length] (i = 0, 1) | 516 | | 14.2.10 | Channel [i] Processing Descriptor 4 Register (C[i]D4) | | | | [Checksum Value Write Address] (i = 0, 1) | 518 | | 14.2.11 | FEC DMAC Processing Control Register (FECC) | 519 | | 14.2.12 | 2 FEC DMAC Processing Interrupt Request Register (FECI) | 522 | | 14.2.13 | FEC DMAC Processing Descriptor Start Address Register (FECDSA) | 525 | | 14.2.14 | FEC DMAC Processing Descriptor Current Address Register (FECDCA) | 526 | | 14.2.15 | FEC DMAC Processing Descriptor 0 Register (FECD00) [Control] | 527 | | 14.2.16 | 5 FEC DMAC Processing Descriptor 1 Register (FECD01D0A) | | | | [Destination Address] | 531 | | 14.2.17 | FEC DMAC Processing Descriptor 2 Register (FECD02S0A) | | | | [Source 0 Address] | 531 | | 14.2.18 | 3 FEC DMAC Processing Descriptor 3 Register (FECD03S1A) | | | | [Source 1 Address] | 532 | | Function | ons | 533 | | 14.3.1 | DMAC Channel Function | 534 | | 14.3.2 | Checksum | 534 | | 14.3.3 | FEC Channel | 534 | | 14.3.4 | FEC Operation | 535 | | Channe | el Operation | 536 | | 14.4.1 | Descriptor Format | 536 | | | | | | 14.4.3 | Checksum | 538 | | FEC C | hannel Operation | 540 | | | 14.1.3<br>Register 14.2.1<br>14.2.2<br>14.2.3<br>14.2.4<br>14.2.5<br>14.2.6<br>14.2.7<br>14.2.8<br>14.2.9<br>14.2.10<br>14.2.11<br>14.2.12<br>14.2.13<br>14.2.14<br>14.2.15<br>14.2.16<br>14.3.1<br>14.3.2<br>14.3.3<br>14.3.4<br>Channel 14.4.1<br>14.4.2<br>14.4.3 | 14.2.5 Channel [i] Processing Descriptor Current Address Register (C[i]DCA) (i = 0, 1) | | | 14.5.1 | Descriptor Format for FEC Channel | 540 | |------|---------|-------------------------------------------------------------------|-----| | | 14.5.2 | Basic FEC Channel Operation | 541 | | 14.6 | Usage 1 | Notes | 543 | | | 14.6.1 | Data Transfer Size Set in Descriptor for A-DMAC Channel Operation | 543 | | Sect | | Stream Interface (STIF) | | | 15.1 | | S | | | 15.2 | | Output Pins | | | 15.3 | _ | er Descriptions | | | | | STIF Mode Select Register (STMDR) | | | | 15.3.2 | STIF Control Register (STCTLR) | | | | 15.3.3 | STIF Internal Counter Control Register (STCNTCR) | | | | | STIF Internal Counter Set Register (STCNTVR) | | | | | STIF Status Register (STSTR) | | | | | STIF Interrupt Enable Register (STIER) | | | | | STIF Transfer Size Register (STSIZER) (n = 0,1) | | | | | STIFPWM Mode Register (STPWMMR) | | | | | STIFPWM Control Register (STPWMCR) | | | | 15.3.10 | STIFPWM Register (STPWMR) | 566 | | | 15.3.11 | STIFPCR0, STIFPCR01 Registers (STPCR0R, STPCR1R) | 567 | | | 15.3.12 | 2 STIFSTC0, STIFSTC1 Registers (STSTC0R, STSTC1R) | 568 | | | 15.3.13 | STIF Lock Control Register (STLKCR) | 569 | | | 15.3.14 | STIF Debugging Status Register (STDBGR) | 572 | | 15.4 | Examp | les of Clock Connection to Another Device | 572 | | | 15.4.1 | A Basic Example | 572 | | | 15.4.2 | An Example of Clock Connection When Another Device Has No Clock | | | | | Input | 573 | | | 15.4.3 | An Example of Clock Connection When Another Device Has No Clock | 572 | | 155 | T(6 | Output | | | 15.5 | - | Output Timing | | | 15.6 | | lock Recovery Module (PCRRCV) | | | | | Operation of PCR Clock Recovery | | | | | PCR Clock Recovery Operation | | | 15.7 | Usage . | Notes | 587 | | | | Serial Sound Interface (SSI) | | | 16.1 | | 28 | | | 16.2 | | Output Pins | | | 16.3 | _ | er Description | | | | 16.3.1 | Control Register (SSICR) | 595 | | | 16.3.2 | Status Register (SSISR) | 601 | | |------|---------------------|--------------------------------------------------------------|-----|--| | | 16.3.3 | Transmit Data Register (SSITDR) | 606 | | | | 16.3.4 | Receive Data Register (SSIRDR) | 606 | | | | 16.3.5 | SSI Clock Selection Register (SCSR) | 607 | | | 16.4 | | ion Description | | | | | 16.4.1 | Bus Format | 608 | | | | 16.4.2 | Non-Compressed Modes | 609 | | | | 16.4.3 | Operation Modes | 619 | | | | 16.4.4 | Transmit Operation | 620 | | | | 16.4.5 | Receive Operation | 623 | | | | 16.4.6 | Temporary Stop and Restart Procedures in Transmit Mode | 626 | | | | 16.4.7 | Serial Bit Clock Control | 627 | | | 16.5 | Usage | Notes | 628 | | | | 16.5.1 | Limitations from Overflow during Receive DMA Operation | 628 | | | Sect | ion 17 | USB 2.0 Host/Function Module (USB) | 629 | | | 17.1 | | es | | | | 17.2 | Input / Output Pins | | | | | 17.3 | Registe | er Description | 634 | | | | 17.3.1 | System Configuration Control Register (SYSCFG) | 641 | | | | | CPU Bus Wait Setting Register (BUSWAIT) | | | | | | System Configuration Status Register (SYSSTS) | | | | | 17.3.4 | Device State Control Register (DVSTCTR) | 648 | | | | | Test Mode Register (TESTMODE) | | | | | 17.3.6 | DMA-FIFO Bus Configuration Registers (D0FBCFG, D1FBCFG) | 657 | | | | 17.3.7 | FIFO Port Registers (CFIFO, D0FIFO, D1FIFO) | 658 | | | | | FIFO Port Select Registers (CFIFOSEL, D0FIFOSEL, D1FIFOSEL) | | | | | 17.3.9 | FIFO Port Control Registers (CFIFOCTR, D0FIFOCTR, D1FIFOCTR) | 667 | | | | 17.3.10 | Interrupts Enable Register 0 (INTENB0) | 671 | | | | | Interrupt Enable Register 1 (INTENB1) | | | | | | 2 BRDY Interrupt Enable Register (BRDYENB) | | | | | | 3 NRDY Interrupt Enable Register (NRDYENB) | | | | | | BEMP Interrupt Enable Register (BEMPENB) | | | | | | 5 SOF Control Register (SOFCFG) | | | | | | 6 Interrupt Status Register 0 (INTSTS0) | | | | | | 7 Interrupt Status Register 1 (INTSTS1) | | | | | | BRDY Interrupt Status Register (BRDYSTS) | | | | | | NRDY Interrupt Status Register (NRDYSTS) | | | | | | BEMP Interrupt Status Register (BEMPSTS) | | | | | 17.3.21 | Frame Number Register (FRMNUM) | 698 | | | | 17.3.22 | 2 μFrame Number Register (UFRMNUM) | 701 | |------|---------|-------------------------------------------------------------------------|-----| | | 17.3.23 | B USB Address Register (USBADDR) | 702 | | | 17.3.24 | USB Request Type Register (USBREQ) | 703 | | | 17.3.25 | 5 USB Request Value Register (USBVAL) | 705 | | | 17.3.26 | USB Request Index Register (USBINDX) | 706 | | | 17.3.27 | USB Request Length Register (USBLENG) | 707 | | | 17.3.28 | B DCP Configuration Register (DCPCFG) | 708 | | | 17.3.29 | DCP Maximum Packet Size Register (DCPMAXP) | 709 | | | 17.3.30 | DCP Control Register (DCPCTR) | 710 | | | 17.3.31 | Pipe Window Select Register (PIPESEL) | 720 | | | 17.3.32 | Pipe Configuration Register (PIPECFG) | 722 | | | 17.3.33 | Pipe Buffer Setting Register (PIPEBUF) | 729 | | | 17.3.34 | Pipe Maximum Packet Size Register (PIPEMAXP) | 732 | | | 17.3.35 | 5 Pipe Timing Control Register (PIPEPERI) | 734 | | | 17.3.36 | 6 PIPEn Control Registers (PIPEnCTR) (n = 1 to 9) | 736 | | | 17.3.37 | PIPEn Transaction Counter Enable Registers (PIPEnTRE) (n = 1 to 5) | 756 | | | 17.3.38 | 3 PIPEn Transaction Counter Registers (PIPEnTRN) (n = 1 to 5) | 758 | | | 17.3.39 | Device Address n Configuration Registers (DEVADDn) (n = 0 to A) | 760 | | | 17.3.40 | Bus Wait Register (D0FWAIT, D1FWAIT) | 763 | | 17.4 | Operat | ion | 764 | | | | System Control and Oscillation Control | | | | 17.4.2 | Interrupt Functions | 767 | | | 17.4.3 | Pipe Control | 790 | | | 17.4.4 | FIFO Buffer Memory | 800 | | | 17.4.5 | Control Transfers (DCP) | 810 | | | 17.4.6 | Bulk Transfers (PIPE1 to PIPE5) | 814 | | | 17.4.7 | Interrupt Transfers (PIPE6 to PIPE9) | 816 | | | 17.4.8 | Isochronous Transfers (PIPE1 and PIPE2) | 817 | | | 17.4.9 | SOF Interpolation Function | 829 | | | 17.4.10 | Pipe Schedule | 830 | | 17.5 | Usage | Notes | 832 | | | | Power Supplies for the USB Module | | | | 17.5.2 | DTCH Interrupt | 834 | | | 17.5.3 | Pin Treatment when USB is Not Used | 834 | | | 17.5.4 | Usage Precautions of USB Disconnection Process at the Time of Using the | | | | | Function Controller Function and Full-Speed Operations | 834 | | Soot | ion 19 | SD Hast Interface (SDHI) | 927 | | Secti | on 19 | I <sup>2</sup> C Bus Interface 3 (IIC3) | 839 | |---------------|--------------------|---------------------------------------------------------------------------|-----| | 19.1 Features | | S | 839 | | 19.2 | Input/C | Output Pins | 841 | | 19.3 | Registe | r Descriptions | 842 | | | 19.3.1 | I <sup>2</sup> C Bus Control Register 1 (ICCR1) | 842 | | | 19.3.2 | I <sup>2</sup> C Bus Control Register 2 (ICCR2) | 845 | | | 19.3.3 | I <sup>2</sup> C Bus Mode Register (ICMR) | 847 | | | 19.3.4 | I <sup>2</sup> C Bus Interrupt Enable Register (ICIER) | 849 | | | | I <sup>2</sup> C Bus Status Register (ICSR) | | | | 19.3.6 | Slave Address Register (SAR) | 854 | | | 19.3.7 | I <sup>2</sup> C Bus Transmit Data Register (ICDRT) | 854 | | | 19.3.8 | I <sup>2</sup> C Bus Receive Data Register (ICDRR) | 855 | | | 19.3.9 | I <sup>2</sup> C Bus Shift Register (ICDRS) | 855 | | | 19.3.10 | NF2CYC Register (NF2CYC) | 856 | | 19.4 | Operati | on | 857 | | | 19.4.1 | I <sup>2</sup> C Bus Format | 857 | | | 19.4.2 | Master Transmit Operation | 858 | | | 19.4.3 | Master Receive Operation. | 860 | | | 19.4.4 | Slave Transmit Operation | 862 | | | 19.4.5 | Slave Receive Operation | 865 | | | 19.4.6 | Clocked Synchronous Serial Format | 866 | | | 19.4.7 | Noise Filter | 870 | | | 19.4.8 | Example of Use | 871 | | 19.5 | Interrupt Requests | | 875 | | 19.6 | Bit Syn | chronous Circuit | 876 | | 19.7 | Usage l | Notes | 879 | | | 19.7.1 | Notes on Working in Multi-master Mode | 879 | | | 19.7.2 | Notes on Working in Master Receive Mode | 879 | | | 19.7.3 | Notes on Setting ACKBT in Master Receive Mode | 879 | | | 19.7.4 | Notes on the States of MST and TRN Bits when Arbitration Is Lost | 880 | | | 19.7.5 | Note Regarding Master Receive Mode of I <sup>2</sup> C-Bus Interface Mode | 880 | | | | Accessing ICE and IICRST during I <sup>2</sup> C Bus Operation | | | Secti | on 20 | Host Interface (HIF) | 883 | | 20.1 | | ·S | | | 20.2 | | Output Pins | | | 20.3 | _ | Access | | | | | Operation | | | | | Connection Method | | | 20.4 | Registe | er Descriptions | 887 | | | |-------|-------------------------------------------|---------------------------------------------------------------|-----|--|--| | | 20.4.1 | HIF Index Register (HIFIDX) | 888 | | | | | 20.4.2 | HIF General Status Register (HIFGSR) | 890 | | | | | 20.4.3 | HIF Status/Control Register (HIFSCR) | 891 | | | | | 20.4.4 | HIF Memory Control Register (HIFMCR) | 894 | | | | | 20.4.5 | HIF Internal Interrupt Control Register (HIFIICR) | 896 | | | | | | HIF External Interrupt Control Register (HIFEICR) | | | | | | 20.4.7 | HIF Address Register (HIFADR) | 898 | | | | | 20.4.8 | HIF Data Register (HIFDATA) | 899 | | | | | 20.4.9 | HIF Boot Control Register (HIFBCR) | 899 | | | | | 20.4.10 HIFDREQ Trigger Register (HIFDTR) | | | | | | | 20.4.11 | HIF Bank Interrupt Control Register (HIFBICR) | 902 | | | | 20.5 | Memor | ry Map | 904 | | | | 20.6 | Interfa | ce | 905 | | | | | 20.6.1 | Basic Sequence | 905 | | | | | 20.6.2 | Reading/Writing of HIF Registers other than HIFIDX and HIFIDX | 906 | | | | | 20.6.3 | Consecutive Data Writing to HIFRAM by External Device | 907 | | | | | 20.6.4 | Consecutive Data Reading from HIFRAM to External Device | 908 | | | | 20.7 | External DMAC Interface | | 909 | | | | 20.8 | Alignment Control | | | | | | 20.9 | Interfa | ce When External Device Power is Cut Off | 915 | | | | 20.10 | Usage | Notes | 918 | | | | Secti | on 21 | Compare Match Timer (CMT) | 919 | | | | 21.1 | | es | | | | | 21.2 | | er Descriptions | | | | | 21.2 | _ | Compare Match Timer Start Register (CMSTR) | | | | | | | Compare Match Timer Control/Status Register (CMCSR) | | | | | | | Compare Match Counter (CMCNT) | | | | | | | Compare Match Constant Register (CMCOR) | | | | | 21.3 | | ion | | | | | | | Interval Count Operation | | | | | | | CMCNT Count Timing | | | | | 21.4 | | pts | | | | | | | Interrupt Sources and DMA Transfer Requests | | | | | | | Timing of Compare Match Flag Setting | | | | | | | Timing of Compare Match Flag Clearing | | | | | 21.5 | | Notes | | | | | | _ | Conflict between Write and Compare-Match Processes of CMCNT | | | | | | | Conflict between Word-Write and Count-Un Processes of CMCNT | | | | | 21.5.4 Compare Match Between CMCNT and CMCOR 930 Section 22 Serial Communication Interface with FIFO (SCIF) 931 22.1 Features 93 22.2 Input/Output Pins 93 22.3 Register Descriptions 934 22.3.1 Receive Shift Register (SCRSR) 936 22.3.2 Receive FIFO Data Register (SCFRDR) 936 22.3.3 Transmit Shift Register (SCTSR) 937 22.3.4 Transmit FIFO Data Register (SCTSR) 937 22.3.5 Serial Mode Register (SCSMR) 935 22.3.6 Serial Control Register (SCSCR) 941 22.3.7 Serial Status Register (SCFSR) 945 22.3.8 Bit Rate Register (SCBRR) 955 | | 21.5.3 | Conflict between Byte-Write and Count-Up Processes of CMCNT | 930 | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|-------------------------------------------------------------|-----| | 22.1 Features 93 22.2 Input/Output Pins 93 22.3 Register Descriptions 93 22.3.1 Receive Shift Register (SCRSR) 93 22.3.2 Receive FIFO Data Register (SCFRDR) 93 22.3.3 Transmit Shift Register (SCTSR) 93 22.3.4 Transmit FIFO Data Register (SCFTDR) 93 22.3.5 Serial Mode Register (SCSMR) 93 22.3.6 Serial Control Register (SCSCR) 94 22.3.7 Serial Status Register (SCFSR) 94 22.3.8 Bit Rate Register (SCBRR) 95 | | 21.5.4 | Compare Match Between CMCNT and CMCOR | 930 | | 22.1 Features 93 22.2 Input/Output Pins 93 22.3 Register Descriptions 93 22.3.1 Receive Shift Register (SCRSR) 93 22.3.2 Receive FIFO Data Register (SCFRDR) 93 22.3.3 Transmit Shift Register (SCTSR) 93 22.3.4 Transmit FIFO Data Register (SCFTDR) 93 22.3.5 Serial Mode Register (SCSMR) 93 22.3.6 Serial Control Register (SCSCR) 94 22.3.7 Serial Status Register (SCFSR) 94 22.3.8 Bit Rate Register (SCBRR) 95 | | | | | | 22.2 Input/Output Pins 933 22.3 Register Descriptions 934 22.3.1 Receive Shift Register (SCRSR) 936 22.3.2 Receive FIFO Data Register (SCFRDR) 936 22.3.3 Transmit Shift Register (SCTSR) 937 22.3.4 Transmit FIFO Data Register (SCFTDR) 937 22.3.5 Serial Mode Register (SCSMR) 938 22.3.6 Serial Control Register (SCSCR) 94 22.3.7 Serial Status Register (SCFSR) 945 22.3.8 Bit Rate Register (SCBRR) 953 | | | · · · · · · · · · · · · · · · · · · · | | | 22.3 Register Descriptions 934 22.3.1 Receive Shift Register (SCRSR) 936 22.3.2 Receive FIFO Data Register (SCFRDR) 936 22.3.3 Transmit Shift Register (SCTSR) 937 22.3.4 Transmit FIFO Data Register (SCFTDR) 937 22.3.5 Serial Mode Register (SCSMR) 938 22.3.6 Serial Control Register (SCSCR) 944 22.3.7 Serial Status Register (SCFSR) 945 22.3.8 Bit Rate Register (SCBRR) 953 | 22.1 | | | | | 22.3.1 Receive Shift Register (SCRSR) 936 22.3.2 Receive FIFO Data Register (SCFRDR) 936 22.3.3 Transmit Shift Register (SCTSR) 937 22.3.4 Transmit FIFO Data Register (SCFTDR) 937 22.3.5 Serial Mode Register (SCSMR) 938 22.3.6 Serial Control Register (SCSCR) 941 22.3.7 Serial Status Register (SCFSR) 945 22.3.8 Bit Rate Register (SCBRR) 953 | 22.2 | - | <u>.</u> | | | 22.3.2 Receive FIFO Data Register (SCFRDR) 936 22.3.3 Transmit Shift Register (SCTSR) 937 22.3.4 Transmit FIFO Data Register (SCFTDR) 937 22.3.5 Serial Mode Register (SCSMR) 938 22.3.6 Serial Control Register (SCSCR) 949 22.3.7 Serial Status Register (SCFSR) 945 22.3.8 Bit Rate Register (SCBRR) 953 | 22.3 | _ | • | | | 22.3.3 Transmit Shift Register (SCTSR) 93° 22.3.4 Transmit FIFO Data Register (SCFTDR) 93° 22.3.5 Serial Mode Register (SCSMR) 93° 22.3.6 Serial Control Register (SCSCR) 94° 22.3.7 Serial Status Register (SCFSR) 94° 22.3.8 Bit Rate Register (SCBRR) 95° | | | | | | 22.3.4 Transmit FIFO Data Register (SCFTDR) 93° 22.3.5 Serial Mode Register (SCSMR) 93° 22.3.6 Serial Control Register (SCSCR) 94° 22.3.7 Serial Status Register (SCFSR) 94° 22.3.8 Bit Rate Register (SCBRR) 95° | | | | | | 22.3.5 Serial Mode Register (SCSMR) 938 22.3.6 Serial Control Register (SCSCR) 94 22.3.7 Serial Status Register (SCFSR) 94 22.3.8 Bit Rate Register (SCBRR) 95 | | | | | | 22.3.6 Serial Control Register (SCSCR) 94 22.3.7 Serial Status Register (SCFSR) 94 22.3.8 Bit Rate Register (SCBRR) 95 | | 22.3.4 | Transmit FIFO Data Register (SCFTDR) | 937 | | 22.3.7 Serial Status Register (SCFSR) 945 22.3.8 Bit Rate Register (SCBRR) 953 | | 22.3.5 | Serial Mode Register (SCSMR) | 938 | | 22.3.8 Bit Rate Register (SCBRR) | | 22.3.6 | Serial Control Register (SCSCR) | 941 | | | | 22.3.7 | Serial Status Register (SCFSR) | 945 | | | | 22.3.8 | Bit Rate Register (SCBRR) | 953 | | 22.3.9 FIFO Control Register (SCFCR) | | 22.3.9 | FIFO Control Register (SCFCR) | 960 | | 22.3.10 FIFO Data Count Set Register (SCFDR)963 | | 22.3.10 | FIFO Data Count Set Register (SCFDR) | 963 | | 22.3.11 Serial Port Register (SCSPTR)964 | | 22.3.11 | Serial Port Register (SCSPTR) | 964 | | 22.3.12 Line Status Register (SCLSR)967 | | 22.3.12 | Line Status Register (SCLSR) | 967 | | 22.4 Operation | 22.4 | Operati | on | 968 | | 22.4.1 Overview968 | | 22.4.1 | Overview | 968 | | 22.4.2 Operation in Asynchronous Mode | | 22.4.2 | Operation in Asynchronous Mode | 971 | | 22.4.3 Operation in Clocked Synchronous Mode | | 22.4.3 | Operation in Clocked Synchronous Mode | 982 | | 22.5 SCIF Interrupts | 22.5 | | · · | | | 22.6 Usage Notes | 22.6 | | • | | | 22.6.1 SCFTDR Writing and TDFE Flag992 | | _ | | | | 22.6.2 SCFRDR Reading and RDF Flag992 | | | | | | 22.6.3 Break Detection and Processing | | | | | | 22.6.4 Sending a Break Signal 993 | | | · · · · · · · · · · · · · · · · · · · | | | 22.6.5 Receive Data Sampling Timing and Receive Margin (Asynchronous Mode) 993 | | | <u> </u> | | | Section 23 Pin Function Controller (PFC)995 | Secti | ion 23 | Pin Function Controller (PFC) | 995 | | 23.1 Register Descriptions 101 | | | | | | 23.1.1 Port A I/O Register H (PAIORH) | | _ | • | | | 23.1.2 Port A Control Registers H2 and H1 (PACRH2, PACRH1) | | | | | | 23.1.3 Port B I/O Register L (PBIORL) | | | | | | 23.1.4 Port B Control Register L1 (PBCRL1) | | | | | | 23.1.5 Port C I/O Registers H and L (PCIORH, PCIORL) | | | | | | 23.1.6 Port C Control Registers H1, L2, and L1 (PCCRH1, PCCRL2, PCCRL1) 1020 | | | | | | 23.1.7 Port D I/O Register L (PDIORL) | | | | | | | 23.1.8 | Port D Control Register L1 (PDCRL1) | 1027 | |------|---------|------------------------------------------------------------------|------| | | | Port E I/O Register L (PEIORL) | | | | 23.1.10 | Port E Control Registers L2 and L1 (PECRL2, PECRL1) | 1030 | | | | Port F I/O Register L (PFIORL) | | | | 23.1.12 | Port F Control Registers L2 and L1 (PFCRL2, PFCRL1) | 1035 | | | | Port G I/O Registers H and L (PGIORH, PGIORL) | | | | 23.1.14 | Port G Control Registers H2, L2, and L1 (PGCRH2, PGCRL2, PGCRL1) | 1040 | | Sect | ion 24 | I/O Ports | 1049 | | 24.1 | Port A. | | 1049 | | | | Register Descriptions | | | | 24.1.2 | Port A Data Register H (PADRH) | 1050 | | 24.2 | | | | | | | Register Descriptions | | | | | Port B Data Register L (PBDRL) | | | 24.3 | | | | | | | Register Descriptions | | | | | Port C Data Registers H and L (PCDRH and PCDRL) | | | 24.4 | | | | | | | Register Descriptions | | | | | Port D Data Register L (PDDRL) | | | 24.5 | | | | | | | Register Descriptions | | | | | Port E Data Register L (PEDRL) | | | 24.6 | | | | | | | Register Descriptions | | | | | Port F Data Register L (PFDRL) | | | 24.7 | | | | | | | Register Descriptions | | | | 24.7.2 | Port G Data Registers H and L (PGDRH and PGDRL) | 1069 | | Sect | | User Break Controller (UBC) | | | 25.1 | | 28 | | | 25.2 | _ | er Descriptions | | | | | Break Address Register (BAR) | | | | | Break Address Mask Register (BAMR) | | | | | Break Data Register (BDR) | | | | | Break Data Mask Register (BDMR) | | | | | Break Bus Cycle Register (BBR) | | | | 25.2.6 | Break Control Register (BRCR) | 1082 | | 25.3 | Operation | | |------|-------------------------------------------------------------------|----------| | | 25.3.1 Flow of the User Break Operation | 1084 | | | 25.3.2 Break on Instruction Fetch Cycle | 1085 | | | 25.3.3 Break on Data Access Cycle | 1086 | | | 25.3.4 Value of Saved Program Counter | 1087 | | | 25.3.5 Usage Examples | 1088 | | 25.4 | Usage Notes | 1091 | | Sect | tion 26 High-Performance User Debugging Interface (H-U | JDI)1093 | | 26.1 | Features | 1093 | | 26.2 | Input/Output Pins | 1094 | | 26.3 | Register Descriptions | 1095 | | | 26.3.1 Bypass Register (SDBPR) | 1095 | | | 26.3.2 Instruction Register (SDIR) | 1096 | | 26.4 | Operation | 1097 | | | 26.4.1 TAP Controller | 1097 | | | 26.4.2 Reset Configuration | 1098 | | | 26.4.3 TDO Output Timing | 1099 | | | 26.4.4 H-UDI Reset | 1100 | | | 26.4.5 H-UDI Interrupt | 1100 | | 26.5 | Usage Notes | 1101 | | Sect | tion 27 On-Chip RAM | 1103 | | 27.1 | Features | 1103 | | 27.2 | Usage Notes | 1104 | | | 27.2.1 Page Conflict | 1104 | | | 27.2.2 RAME and RAMWE Bits | 1104 | | Sect | tion 28 List of Registers | 1105 | | 28.1 | Register Addresses | | | | (by Functional Module, in Order of the Manual's Section Numbers). | 1106 | | 28.2 | Register Bits | 1124 | | 28.3 | Register States in Each Operating Mode | 1167 | | Sect | tion 29 Electrical Characteristics | 1181 | | 29.1 | Absolute Maximum Ratings | 1181 | | 29.2 | Power-on/Power-off Sequence | 1182 | | 29.3 | DC Characteristics | 1183 | | 29.4 | AC Characteristics | 1189 | | | 29.4.1 Clock Timing | 1190 | | | 29.4.2 | Control Signal Timing | 1194 | |------------|----------|----------------------------------------------------------------------|------| | | 29.4.3 | Bus Timing | 1195 | | | 29.4.4 | DMAC Module Timing | 1224 | | | 29.4.5 | Watchdog Timer Timing | 1225 | | | 29.4.6 | SCIF Module Timing | 1226 | | | 29.4.7 | IIC3 Module Timing | 1227 | | | 29.4.8 | SSI Module Timing | 1229 | | | 29.4.9 | USB Transceiver Timing | 1231 | | | 29.4.10 | SDHI Module Timing | 1233 | | | 29.4.11 | I/O Port Timing | 1234 | | | 29.4.12 | HIF Module Signal Timing | 1235 | | | 29.4.13 | EtherC Module Signal Timing | 1237 | | | 29.4.14 | H-UDI Related Pin Timing | 1241 | | | 29.4.15 | STIF Module Signal Timing (1) | 1243 | | | 29.4.16 | STIF Module Signal Timing (2) | 1244 | | | 29.4.17 | STIF Module Signal Timing (3) | | | | | (With Stream Input/Output Set Synchronized with STn_CLKIN Rise Time) | 1245 | | | 29.4.18 | STIF Module Signal Timing (4) | | | | | (With Stream Input/Output Set Synchronized with STn_CLKIN Fall Time) | 1247 | | | 29.4.19 | STIF Module Signal Timing (5) | | | | | (With Stream Output Set Synchronized with STn_CLKOUT Rise Time) | 1249 | | | 29.4.20 | STIF Module Signal Timing (6) | | | | | (With Stream Output Set Synchronized with STn_CLKOUT Fall Time) | 1250 | | | 29.4.21 | STIF Module Signal Timing (7) | 1251 | | | 29.4.22 | AC Characteristics Measurement Conditions | 1252 | | | | | | | Appe | endix | | 253 | | <b>4</b> . | Pin Stat | tes | 1253 | | 3. | Product | Lineup | 1258 | | J. | Package | e Dimensions | 1259 | | Э. | Treatme | ent of Unused Pins | 1260 | | Main | Revici | ions and Additions in this Edition | 265 | | v1aili | 100 1131 | ions and Additions in this Edition | 203 | | ndex | ζ. | 1 | 271 | # Section 1 Overview ## 1.1 Features This LSI is a CMOS single-chip microcontroller that integrates a Renesas original RISC (Reduced Instruction Set Computer) CPU core with peripheral functions required for an Ethernet system. The CPU incorporated in this LSI is the SH-2A CPU, which features upward compatibility on the object code level with the SH-1 and SH-2 microcomputers. The CPU has a RISC-type instruction set and employs a superscalar architecture and the Harvard architecture, which greatly improves instruction execution speed. In addition, the 32-bit internal-bus architecture enhances data processing power. This CPU realizes low-cost, high-performance, and high-functioning systems for applications such as high-speed realtime control, which was previously impossible with the conventional microcomputers. This LSI includes an Ethernet controller (EtherC) that incorporates a media access controller (MAC) conforming to the IEEE802.3u standard, which offers the LAN connection in the rate of 10 or 100 Mbps. In addition, this LSI includes on-chip peripheral functions required for systems, such as, cache memory, RAM, a direct memory access controller (DMAC), a host interface (HIF), an USB2.0 host/function module (USB), an SD host interface (SDHI), an interrupt controller (INTC), a compare match timer (CMT), a serial communication interface with FIFO (SCIF), and I/O ports. Moreover, this LSI includes encryption functions (AES, DES and 3DES), message authentication code generating functions (HMAC-SHA-1, HMAC-SHA-224, and HMAC-SHA-256), an AV stream interface (STIF), and a serial sound interface (SSI), which can be applied to digital AV equipment with network features. This LSI also provides an external memory access support function to enable direct connection to various memory devices or peripheral LSIs. These on-chip functions significantly reduce costs of designing and manufacturing application systems. # 1.2 Applications Main applications: Network application equipment, consumer equipment, digital AV equipment # 1.3 Overview of Specifications Table 1.1 shows the overview of the specifications of this LSI. **Table 1.1** Overview of SH7670 Group Specifications | Classification | Module/Function | Description | | |----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--| | Memory | On-chip RAM | RAM size: 32 Kbytes (four 8-Kbyte banks) | | | | Cache memory | Instruction cache: 8 Kbytes | | | | | Operand cache: 8 Kbytes | | | | | <ul> <li>128-entry, 4-way set associative, 16-byte block length<br/>configuration each for the instruction cache and operand<br/>cache</li> </ul> | | | | | Write-back, write-through and LRU replacement algorithm | | | | | <ul> <li>Cache locking function available (only for operand cache);<br/>ways 2 and 3 can be locked</li> </ul> | | | Classification | Module/Function | on Description | | |----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | CPU | CPU | Renesas original SuperH architecture | | | | | Compatible with SH-1, SH-2, and SH-2E at object code level | | | | | 32-bit internal data bus | | | | | General-register architecture | | | | | Sixteen 32-bit general registers | | | | | Four 32-bit control registers | | | | | Four 32-bit system registers | | | | | Register bank for high-speed response to interrupts | | | | | RISC-type instruction set | | | | | (upward compatible with SH series) | | | | | <ul> <li>Instruction length: 16-bit fixed-length basic instructions for<br/>improved code efficiency and 32-bit instructions for high<br/>performance and usability</li> </ul> | | | | | Load/store architecture | | | | | Delayed branch instructions | | | | | Instruction set based on C language | | | | | Superscalar architecture to execute two instructions at one time including FPU | | | | | Instruction execution time: Up to two instructions/cycle | | | | | Address space: 4 Gbytes | | | | | Internal multiplier | | | | | Five-stage pipeline | | | | | Harvard architecture | | | Classification | Module/Function | Description | |----------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------| | CPU | 3 1 | Floating-point co-processor included | | | (FPU) | <ul> <li>Supports single-precision (32-bit) and double-precision<br/>(64-bit)</li> </ul> | | | | <ul> <li>Supports data type and exceptions that conform to<br/>IEEE754 standard</li> </ul> | | | | • Two rounding modes: Round to nearest and round to zero | | | | Denormalization modes: Flush to zero | | | | Floating-point registers | | | | <ul> <li>Sixteen 32-bit floating-point registers (single-precision ×<br/>16 words or double-precision × 8 words)</li> </ul> | | | | Two 32-bit floating-point system registers | | | | <ul> <li>Supports FMAC (multiplication and accumulation)<br/>instructions</li> </ul> | | | | <ul> <li>Supports FDIV (division) and FSQRT (square root) instructions</li> </ul> | | | | Supports FLDI0/FLDI1 (load constant 0/1) instructions | | | | Instruction execution time | | | | Latency (FMAC/FADD/FSUB/FMUL): Three cycles (single-precision), eight cycles (double-precision) | | | | Pitch (FMAC/FADD/FSUB/FMUL): One cycle (single-precision), six cycles (double-precision) | | | | Note: FMAC only supports single-precision. | | | | Five-stage pipeline | | Interrupts | Interrupt controller | Nine external interrupt pins (NMI and IRQ7 to IRQ0) | | (sources) | (INTC) | <ul> <li>On-chip peripheral interrupts: Priority level set for each module</li> </ul> | | | | Sixteen priority levels available | | | | <ul> <li>Register bank enabling fast register saving and restoring<br/>in interrupt handling</li> </ul> | | Classification | Module/Function | Description | |------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | External bus extension | Bus state<br>controller (BSC) | <ul> <li>Address space for five areas (64 Mbytes each) and 32-bit<br/>external bus</li> </ul> | | | | <ul> <li>The following features settable independently for each area:</li> </ul> | | | | <ul> <li>Bus size: 8, 16, or 32 bits (depending on area)</li> </ul> | | | | <ul> <li>Access wait cycle count</li> </ul> | | | | <ul> <li>Idle wait cycle setting (same area/different area)</li> </ul> | | | | <ul> <li>Supports SRAM, SRAM with byte selection, and<br/>SDRAM by specifying memory to be connected for<br/>each area</li> </ul> | | | | <ul> <li>Supports the PCMCIA interface</li> </ul> | | | | <ul> <li>Chip select signal output to an applicable area<br/>(Timings of CS asserting and negating are selectable<br/>by programming)</li> </ul> | | | | SDRAM refreshing function | | | | <ul> <li>Supports auto-refreshing mode and self-refreshing mode</li> </ul> | | | | SDRAM burst access function | | | | For area 0, only big endian is supported | | DMA | Direct memory<br>access controller<br>(DMAC) | Eight channels (External DMA requests available for two of them) | | | | Can be activated by on-chip peripheral modules | | | | Burst mode and cycle steal mode | | | | Supports intermittent mode (16 or 64 cycles) | | | | Auto-reloading of transfer information | | Classification | Module/Function | Description | |----------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | Clock | Clock pulse<br>generator (CPG) | Clock mode: Input clock can be selected from external input (EXTAL or CKIO) or crystal resonator (EXTAL/XTAL or USB_X1/USB_X2). | | | | Three types of clocks generated | | | | — CPU clock: | | | | 200 MHz (maximum) (regular specifications) | | | | 133 MHz (maximum) (wide temperature specifications) | | | | — Bus clock: | | | | 100 MHz (maximum) (regular specifications) | | | | 66 MHz (maximum) (wide temperature specifications) | | | | — Peripheral clock: | | | | 50 MHz (maximum) (regular specifications) | | | | 33 MHz (maximum) (wide temperature specifications) | | | Power-down modes | Three power-down modes provided to reduce the current consumption in this LSI | | | | <ul><li>Sleep mode</li></ul> | | | | <ul> <li>Software standby mode</li> </ul> | | | | <ul> <li>Module standby mode</li> </ul> | | Timer | Compare match timer (CMT) | Two-channel 16-bit counter | | | | <ul> <li>Four types of clocks selectable (Pφ/8, Pφ/32, Pφ/128, or Pφ/512)</li> </ul> | | | | Generates a compare match interrupt | | | Watchdog timer<br>(WDT) | One-channel watchdog timer | | | | A counter overflow can reset this LSI | | Classification | Module/Function | De | scription | |------------------------|---------------------------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Advanced communication | Ethernet controller (EtherC) | | MAC (Media Access Control) function Data frame assembly/deassembly (frame format conforming to IEEE802.3) CSMA/CD link management (for collision avoidance and processing in case of collision) CRC processing | | | | • | <ul> <li>On-chip FIFOs (512 bytes for transmission and reception each)</li> <li>Supports full-duplex data transmission and reception</li> <li>Sends and receives short and long packets</li> <li>Conforms to the MII (Media Independent Interface) standard</li> <li>Converts an 8-bit data stream from the MAC layer to a 4-bit MII nibble stream</li> <li>Station management (STA feature)</li> <li>Eighteen TTL-level signals</li> <li>Transfer rate: 10 or 100 Mbps</li> <li>Magic Packet™ with WOL (Wake On LAN) output</li> </ul> | | | DMAC for<br>Ethernet controller<br>(E-DMAC) | • | Reduces CPU load using the descriptor management system One channel for transfer from the EtherC receive FIFO to the receive buffer One channel for transfer from the transmit buffer to the EtherC transmit FIFO Allows 16-byte burst transfer for efficient use of the system bus Supports single frame and multibuffer Calculates receive data checksum | | Classification | Module/Function | Description | |--------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Advanced interface | Stream interface<br>(STIF) | <ul> <li>Two-channel port in conjunction with A-DMAC</li> <li>Serial mode or parallel mode selectable for each channel</li> <li>Supports MPEG2-TS and MPEG-PS transfer modes</li> <li>Supports push-type transfer and pull-type transfer to each device</li> <li>External VCO control PWM timer and its output provided for each channel</li> <li>Stream clock output common to all channels and stream clock input for each channel</li> </ul> | | | Serial sound interface (SSI) | <ul> <li>Two-channel bidirectional serial transfer</li> <li>Supports various serial audio formats</li> <li>Supports master and slave functions</li> <li>Generates programmable word clock and bit clock</li> <li>Multichannel formats</li> <li>Supports 8-, 16-, 18-, 20-, 22-, 24-, and 32-bit data formats</li> </ul> | | | USB2.0<br>host/function<br>module (USB) | <ul> <li>Conforms to USB version 2.0</li> <li>Supports three transfer rates: 480 Mbps, 12 Mbps, and 1.5 Mbps</li> <li>Software and functions switchable</li> <li>Connectable to multiple peripheral devices through one-stage hub while the software is running</li> <li>Software settable</li> <li>On-chip 8-Kbyte RAM as a communication buffer</li> </ul> | | | SD host interface<br>(SDHI)<br>(Not supported in<br>SH7672 and<br>SH7670) | <ul> <li>SD memory/IO card interface (1-bit/4-bit SD bus)</li> <li>Error check functions: CRC7 (for commands) and CRC16 (for data)</li> <li>Interrupt requests: Card access interrupt, SDIO access interrupt, and card detect interrupt</li> <li>DMAC transfer requests: SD_BUF write and SD_BUF read</li> <li>Supports card detection and write protection functions</li> <li>One channel</li> <li>On-chip master mode and slave mode</li> </ul> | | Classification | Module/Function | Description | |--------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Advanced interface | Host interface<br>(HIF) | <ul> <li>On-chip 4-Kbyte buffer RAM (two 2-Kbyte banks)</li> <li>Parallel connection of buffer RAM and external device with sixteen data pins</li> </ul> | | | | Parallel connection of buffer RAM and the CPU of this LSI with the internal bus | | | | <ul> <li>A connected external device can access desired register<br/>after the register index was specified (However,<br/>addresses can be automatically updated during<br/>continuous buffer RAM access)</li> </ul> | | | | Endian switchable | | | | An interrupt can be requested to a connected external device | | | | <ul> <li>An internal interrupt can be requested to the CPU of this<br/>LSI</li> </ul> | | | | <ul> <li>Allows booting from the buffer RAM by storing the<br/>instruction code beforehand from the external device in<br/>the buffer RAM</li> </ul> | | | Serial<br>communication<br>interface with<br>FIFO (SCIF) | Three channels | | | | <ul> <li>Clock synchronous mode or asynchronous mode selectable</li> </ul> | | | | <ul> <li>Supports simultaneous transmission and reception (full-<br/>duplex communication)</li> </ul> | | | | Dedicated baud rate generator | | | | Separate 16-byte FIFO registers for transmission and reception | | | | Modem control function (asynchronous mode) | | Classification | Module/Function | Description | |----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Encryption, hash, and error correction | Encryption<br>functions (AES,<br>DES and 3DES)<br>(SH7671 and<br>SH7670 support<br>only DMAC<br>function. They do<br>not support<br>encryption<br>function.) | <ul> <li>Encryption/decryption engine can be activated by 2-channel dedicated DMAC (A-DMAC) or CPU</li> <li>By reading the descriptor using the A-DMAC, continuous encryption/decryption available by switching the source address (unprocessed data pointer), destination address (processed data storage address), and various settings (including encryption/decryption algorithm, encryption/decryption, ECB/CBC/OFB, keys, and IV) in real time</li> <li>Block-by-block encryption and decryption enabled by activation from the CPU</li> </ul> | | | Message<br>authentication<br>code generating<br>functions (HMAC-<br>SHA-1, HMAC-<br>SHA-224, and<br>HMAC-SHA-256)<br>(Not supported in<br>SH7671 and<br>SH7670) | By reading the descriptor using the A-DMAC, generation of message authentication codes and checksum calculation in conjunction with encryption/decryption processing are available | | | Forward error correction (FEC) | <ul> <li>By reading the descriptor using the dedicated F-DMAC, missing packets can be restored quickly by switching the source address (read packet pointer), destination address (restoration packet storage address), and packet size in real time</li> <li>Arbitrary values can be used for the read packet pointer, read packet count, restoration packet storage address, and packet size</li> </ul> | | Debugging function | User break<br>controller (UBC) | <ul> <li>Two break channels</li> <li>Addresses, data values, type of access, and data size can be set as break conditions</li> </ul> | | | User debugging interface (H-UDI) | <ul><li>Supports E10A emulator</li><li>JTAG-standard pin assignment</li><li>Supports boundary scan</li></ul> | | I/O ports | | <ul> <li>Eighty-six general input/output pins and eight general input pins</li> <li>Input or output of I/O ports can be selected for each bit</li> </ul> | | Classification Module/Function | Description | |--------------------------------|-----------------------------------------------------------| | Package | <ul> <li>P-FBGA1717-256 (0.8 pitch)</li> </ul> | | Power supply voltage | • I/O: $3.3 \pm (0.2)$ V, internal: $1.2 \pm (0.1)$ V | | Operating temperature (°C) | <ul> <li>-20 to +70°C (regular specifications)</li> </ul> | • -40 to +85°C (wide temperature specifications) Notes: \* Magic Packet<sup>™</sup> is a registered trademark of Advanced Micro Devices, Inc. ## 1.4 Product Lineup Table 1.2 lists the products and figure 1.1 shows how to read their type names. **Table 1.2** Product Lineup | Type Name (Abbreviation) | ROM<br>Size | RAM Size | Package | Encryption | SDHI | Remarks | |--------------------------|-------------|-----------|-------------------------|-------------|-------------|---------| | (Abbieviation) | Oize | TIAM OILC | 1 dokage | Liloryption | ODIII | Hemano | | R5S76700 | - | 32 Kbytes | P-FBGA256 –17 × 17 –0.8 | Not mounted | Not mounted | SH7670 | | R5S76710 | - | 32 Kbytes | P-FBGA256 –17 × 17 –0.8 | Not mounted | Mounted | SH7671 | | R5S76720 | _ | 32 Kbytes | P-FBGA256 –17 × 17 –0.8 | Mounted | Not mounted | SH7672 | | R5S76730 | _ | 32 Kbytes | P-FBGA256 –17 × 17 –0.8 | Mounted | Mounted | SH7673 | Figure 1.1 How to Read Type Names ### Small package | Package | Code | Body Size | Pin Pitch | |-------------------------|--------------|------------|-----------| | P-FBGA256 –17 × 17 –0.8 | PRBG0256GA-A | 17 × 17 mm | 0.8 mm | ## 1.5 Block Diagram Figure 1.2 Block Diagram ## 1.6 Pin Assignments | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | |---|--------------------------|--------------------------|--------------------------------------|--------------------------------------|-------------------------|-----------------------------|-----------------|---------|---------|---------|------|----------------------------|------------------------------|--------------------------|---------------------------|---------------------------------|---------------------------|----------------------------|------------------------------|---------------------| | Α | PA17/<br>A17 | A00 | PB04/<br>CE2A/<br>IRQ2/<br>DACK1 | PB00/<br>WAIT/<br>SDA | PB06/<br>CS4 | WE1/<br>DQMLU/<br>WE | D09 | D12 | D15 | D05 | D02 | A16 | A13 | A10 | A07 | A04 | A01 | RAS | CAS | Vss | | В | PA19/<br>A19 | PA18/<br>A18 | PB05/CS5/<br>CE1A/<br>IRQ3/<br>TEND1 | PB02/<br>CE2B/<br>IRQ0 | RD | PB07/<br>BS | D08 | D10 | D14 | D06 | D03 | D00 | A14 | A11 | A08 | A05 | A02 | CS3 | VssQ | СКІ | | С | PA22/<br>A22 | PA21/<br>A21 | PA20/<br>A20 | PB03/CS6/<br>CE1B/<br>IRQ1/<br>DREQ1 | PB01/<br>IOIS16/<br>SCL | CS0 | WE0/<br>DQMLL | D11 | D13 | D07 | D04 | D01 | A15 | A12 | A09 | A06 | A03 | VssQ | RDWR | CKI | | D | HIFMD/<br>PA25/<br>A25 | PA24/<br>A24 | PA23/<br>A23 | VssQ_14 | Vss_07 | VccQ_14 | Vcc_07 | VssQ_13 | VccQ_13 | VccQ_12 | VssQ | VssQ_12 | Vcc_06 | Vss_06 | VccQ_11 | VssQ_11 | VssQ_10 | WE3/<br>DQMUU/<br>ICIOWR | WE2/<br>DQMUL/<br>ICIORD | D2: | | Ε | PC18/<br>LNKSTA | PC19/<br>EXOUT | PC20/<br>WOL | VssQ_00 | | | | | | | | | | | | | VssQ_09 | D24 | D26 | D2 | | F | PC13/<br>TX_CLK | PC16/<br>MDIO | PC17/<br>MDC | VccQ_00 | | | | | | | | | | | | | VccQ_10 | D27 | D29 | D3 | | G | PC07/<br>MII_TXD3 | PC11/<br>TX_ER | PC12/<br>TX_EN | Vss_00 | | | | | | | | | | | | | VccQ_09 | D31 | D23 | D2 | | Н | PC04/<br>MII_TXD0 | PC05/<br>MII_TXD1 | PC06/<br>MII_TXD2 | Vcc_00 | | | | | | | | | | | | | VccQ_08 | VccQ_07 | D21 | D2 | | J | PC10/<br>RX_CLK | PC14/<br>COL | PC15/<br>CRS | VssQ_01 | | | | | | | | | | | | | VssQ_08 | VssQ_07 | D19 | D1 | | K | PC03/<br>MII_RXD3 | PC08/<br>RX_DV | PC09/<br>RX_ER | VccQ_01 | | SH7673/SH7672/SH7671/SH7670 | | | | | | | | | Vcc_05 | VssQ | D17 | D16 | | | | L | PC00/<br>MII_RXD0 | PC01/<br>MII_RXD1 | PC02/<br>MII_RXD2 | VccQ_02 | | | | | | Тор | view | | | | | | Vss_05 | PF05/<br>ST0_D5/<br>RTS0 | PF06/<br>ST0_D6/<br>SSIDATA0 | STO_<br>SSIW | | M | TESTMD | ASEMD | PD07/<br>IRQ7/<br>SDCLK | VssQ | | | | | | | | | | | | | VssQ | PF02/<br>ST0_D2/<br>RxD0 | PF03/<br>ST0_D3/<br>SCK0 | STO_<br>CTS | | N | PD04/<br>IRQ4/<br>SDWP | PD05/<br>IRQ5/<br>SDCD | PD06/<br>IRQ6/<br>SDCMD | VssQ_02 | | | | | | | | | | | | | VccQ_06 | PF01/<br>ST0_D1/<br>TxD0 | PF10/<br>ST0_SYC/<br>DACK0 | PF0<br>ST0_ | | Р | PD01/<br>IRQ1/<br>SDDAT1 | PD02/<br>IRQ2/<br>SDDAT2 | PD03/<br>IRQ3/<br>SDDAT3 | Vcc_01 | | | | | | | | | | | | | VssQ_06 | PF11/<br>ST0_PWM/<br>TEND0 | PF08/<br>ST0_REQ | PF0<br>ST0_V<br>DRE | | R | PG14/<br>HIFD14 | PG15/<br>HIFD15 | PD00/<br>IRQ0/<br>SDDAT0 | Vcc_02 | | | | | | | | | | | | | Vcc_04 | WDTOVF | STO_<br>CLKIN/<br>SSISCKO | STO<br>VCC<br>CLK | | Т | PG11/<br>HIFD11 | PG12/<br>HIFD12 | PG13/<br>HIFD13 | Vss_01 | | | | | | | | | | | | | Vss_04 | VssQ | MD_BW | ASEB<br>ASEBR | | U | PG09/<br>HIFD09 | PG10/<br>HIFD10 | VssQ | Vss_02 | VssQ_03 | VccQ_03 | VssQ | DG12 | DV12 | UV12 | AV12 | Vcc_03 | | | | | VssQ_05 | MD_CK1 | NMI | PLLV | | ٧ | PG07/<br>HIFD07 | VssQ | PG04/<br>HIFD04 | PG01/<br>HIFD01 | PG22/<br>HIFRS | PG17/<br>HIFRDY | VssQ | VssQ | VssQ | UG12 | AG12 | PE07/<br>ST1_D7/<br>SSIWS1 | PE06/<br>ST1_D6/<br>SSIDATA1 | PE01/<br>ST1_D1/<br>TxD1 | PE03/<br>ST1_D3/<br>SCK1 | ST1_VCO_<br>CLKIN/<br>AUDIO_CLK | TCK | TDI | MD_CK0 | EXT | | W | VssQ | PG06/<br>HIFD06 | PG03/<br>HIFD03 | PG00/<br>HIFD00 | PG21/<br>HIFWR | PG18/<br>HIFDREQ | PG16/<br>HIFEBL | DG33 | VBUS | AG33 | VssQ | USB_X1 | PE05/<br>ST1_D5/<br>RTS1 | PE02/<br>ST1_D2/<br>RxD1 | PE10/<br>ST1_SYC/<br>CTS2 | PE11/<br>ST1_PWM/<br>RTS2 | ST1_<br>CLKIN/<br>SSISCK1 | RES | TDO | XTA | | Υ | PG08/ | PG05/ | PG02/ | PG23/ | PG20/ | PG19/ | 1 | 1 | I | 1 | 1 | 1 | PE04/ | PE09/ | PE00/ | PE08/ | ST | TRST | TMS | PLL | Figure 1.3 Pin Assignments #### **Pin Functions** 1.7 Table 1.3 **Pin Functions** | Classification | Symbol | I/O | Name | Function | |------------------------|-------------------|-----|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power supply | Vcc | I | Power supply | Power supply pin for the internal logic circuit. All the Vcc pins must be connected to the system power supply. This LSI does not operate correctly if there is a pin left open. | | | Vss | I | Ground | Ground pin. All the Vss pins must be connected to the system power supply (0 V). This LSI does not operate correctly if there is a pin left open. | | | VccQ | I | Power supply | Power supply pin for I/O pins. All the VccQ pins must be connected to the system power supply. This LSI does not operate correctly if there is a pin left open. | | | VssQ | I | Ground | Ground pin. All the VssQ pins must be connected to the system power supply (0 V). This LSI does not operate correctly if there is a pin left open. | | | PLLVcc | I | Power supply | Power supply pin for the PLL circuit. This pin must be connected to the system power supply. | | | PLLVss | I | Ground | Ground pin for the PLL circuit. This pin must be connected to the system power supply (0 V). | | Clock | EXTAL | I | External clock | Pin connected to a crystal resonator.<br>An external clock signal may also be<br>input to the EXTAL pin. | | | XTAL | 0 | Crystal resonator | Pin connected to a crystal resonator | | | CKIO | I/O | System clock | Pin to supply the system clock to external devices | | Operating mode control | MD_BW | I | Mode set | Pin to set the operating mode. Do not change signal levels on this pin during operation. | | | MD_CK1,<br>MD_CK0 | I | Clock mode set | Pins to set the clock operating mode. Do not change signal levels on these pins during operation. | | Classification | Symbol | I/O | Name | Function | |----------------|------------------------------------------------------------------------------|-----|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | System control | RES | I | Power-on reset | This LSI enters the power-on reset state when this signal goes low. | | | WDTOVF | 0 | Watchdog timer overflow | An overflow signal from the WDT is output on this pin. | | Interrupts | NMI | I | Non-maskable interrupt | Non-maskable interrupt request pin. Fix it high when not in use. | | | IRQ7 to IRQ0 | I | | Maskable interrupt request pins | | | | | 7 to 0 | Level-input or edge-input detection<br>can be selected. When the edge-input<br>detection is selected, the rising edge<br>or falling edge can also be selected. | | Address bus | A25 to A00 | 0 | Address bus | Addresses are output on these pins. | | Data bus | D31 to D00 | I/O | Data bus | Bidirectional data bus pins | | Bus control | $\overline{\text{CS0}}$ , $\overline{\text{CS3}}$ to $\overline{\text{CS6}}$ | 0 | Chip select 0, 3 to 6 | Chip-select signal pins for external memory or devices | | | RD | 0 | Read | Indicates that data is read from an external device. | | | RD/WR | 0 | Read/write | Read/write signal pin | | | BS | 0 | Bus start | Bus cycle start signal pin | | | WE3 | 0 | Most significant byte write | Indicates that data is written to data bits 31 to 24 of the external memory or device. | | | WE2 | 0 | Second byte write | Indicates that data is written to data bits 23 to 16 of the external memory or device. | | | WE1 | 0 | Third byte write | Indicates that data is written to data bits 15 to 8 of the external memory or device. | | | WE0 | 0 | Least significant byte write | Indicates that data is written to data bits 7 to 0 of the external memory or device. | | | WAIT | I | Wait | Input pin to insert a wait cycle into bus cycles during access to the external space | | | RAS | 0 | RAS | Pin connected to the RAS pin of SDRAM | | | CAS | 0 | CAS | Pin connected to the CAS pin of SDRAM | | Classification | Symbol | I/O | Name | Function | |------------------------|-------------------------|-----|----------------------------------------|------------------------------------------------------------------------------------------------| | Bus control | CKE | 0 | Clock enable | Pin connected to the CKE pin of SDRAM | | | DQMUU | 0 | Most significant byte select | Selects data bus bits 31 to 24 of SDRAM. | | | DQMUL | 0 | Second byte select | Selects data bus bits 23 to 16 of SDRAM. | | | DQMLU | 0 | Third byte select | Selects data bus bits 15 to 8 of SDRAM. | | | DQMLL | 0 | Least significant byte select | Selects data bus bits 7 to 0 of SDRAM. | | | CE1A | 0 | PCMCIA card select (lower) | Chip enable signal pin for PCMCIA connected to area 5 | | | CE1B | 0 | PCMCIA card select (lower) | Chip enable signal pin for PCMCIA connected to area 6 | | | CE2A | 0 | PCMCIA card select (upper) | Chip enable signal pin for PCMCIA connected to area 5 | | | CE2B | 0 | PCMCIA card select (upper) | Chip enable signal pin for PCMCIA connected to area 6 | | | ICIOWR | 0 | PCMCIA I/O write strobe | Pin connected to the PCMCIA I/O write strobe | | | ICIORD | 0 | PCMCIA I/O read strobe | Pin connected to the PCMCIA I/O read strobe | | | WE | 0 | PCMCIA memory write strobe | Pin connected to the PCMCIA memory write strobe | | | IOIS16 | I | PCMCIA dynamic bus sizing | Indicates the 16-bit I/O of PCMCIA in little-endian mode. Fix this pin low in big-endian mode. | | access | DREQ0, DREQ1 | I | DMA-transfer request | Input pins to receive external requests for DMA transfer | | controller<br>(DMAC) | DACK0, DACK1 | 0 | DMA-transfer<br>request<br>acknowledge | Output pins for signals indicating acknowledge of external requests from external devices | | | TEND0, TEND1 | 0 | DMA-transfer end output | Output pins for DMA transfer end | | Ethernet | CRS | I | Carrier sense | Carrier sensing pin | | controller<br>(EtherC) | COL | I | Collision | Collision detecting pin | | (EuleiO) | MII_TXD3 to<br>MII_TXD0 | 0 | Transmit data | 4-bit transmit data pins | | | | | | | | Classification | Symbol | I/O | Name | Function | |---------------------|---------------------------|-----|------------------------|-------------------------------------------------------------------------------| | Ethernet controller | TX_EN | 0 | Transmit enable | Indicates that transmit data is ready on the MII_TXD3 to MII_TXD0 pins. | | (EtherC) | TX_CLK | I | Transmit clock | Input reference timing signal of TX_EN, TX_ER, and MII_TXD3 to MII_TXD0 | | | TX_ER | 0 | Transmit error | Pin to notify the PHY-LSI of an error detected during transmission | | | MII_RXD3 to<br>MII_RXD0 | I | Receive data | 4-bit receive data pins | | | RX_DV | I | Receive data valid | Indicates that valid receive data is present on the MII_RXD3 to MII_RXD0 pins | | | RX_CLK | I | Receive clock | Input reference timing signal of RX_DV, RX_ER, and MII_RXD3 to MII_RXD0 | | | RX_ER | I | Receive error | Pin to recognize the state of an error detected during reception | | | MDC | 0 | Clock for management | Input reference timing signal of transfer data on the MDIO pin | | | MDIO | I/O | Management data I/O | Bidirectional pin to exchange management data | | | WOL | 0 | MAGIC packet reception | Indicates that a Magic Packet <sup>™</sup> * was received. | | | LNKSTA | I | Link status | Input pin to receive the link status signal from the PHY-LSI | | | EXOUT | 0 | General output | External output pin | | Stream | ST_CLKOUT | 0 | | Data clock output pin | | interface<br>(STIF) | ST1_CLKIN,<br>ST0_CLKIN | I | | Data clock input pins | | | ST1_SYC,<br>ST0_SYC | I/O | | Synchronizing signal pins | | | ST1_REQ,<br>ST0_REQ | I/O | | Request signal pins | | | ST1_VLD,<br>ST0_VLD | I/O | | Data enable pins | | | ST1_D[7:0],<br>ST0_D[7:0] | I/O | | Data pins (The value 0 is used in serial mode) | | Classification | Symbol | I/O | Name | Function | |------------------------------|---------------------------------|-----|----------------------------------------------|---------------------------------------------------------------------------------------------------------| | Stream interface | ST1_VCO_CLKIN,<br>ST0_VCO_CLKIN | I | | VCX0 clock pins | | (STIF) | ST1_PWM,<br>ST0_PWM | 0 | | PWM output pins | | Serial sound interface (SSI) | SSIDATA1,<br>SSIDATA0 | I/O | SSI data I/O | Serial data I/O pins | | | SSISCK1,<br>SSISCK0 | I/O | SSI clock I/O | Serial clock I/O pins | | | SSIWS1, SSIWS0 | I/O | SSI clock LR I/O | Word select I/O pins | | | AUDIO_CLK | I | External clock for SSI audio | The external clock for audio is input to this pin. | | USB2.0 | DP | I/O | USB D+ data | USB bus D+ data pin | | host/function module (USB) | DM | I/O | USB D- data | USB bus D- data pin | | modulo (CCD) | VBUS | I | VBUS input | Connect this pin to VBUS of the USB bus. | | | REFRIN | I | Reference input | Connect this pin to AG33 through a resistor of 5.6 k $\Omega$ ±1%. | | | USB_X1 | I | Crystal | Pins connected to the crystal | | | USB_X2 | 0 | resonator/external<br>clock input for<br>USB | resonator for USB. When an external clock is used, connect it to the USB_1 pin with the USB_2 pin open. | | | AV33 | I | Analog power supply for transceiver | Power supply pin for the core (3.3 V (Typ.) supplied) | | | AG33 | I | Analog ground for transceiver | Ground pin for the core | | | AV12 | I | Analog power supply for transceiver | Power supply pin for the core (1.2 V (Typ.) supplied) | | | AG12 | I | Analog ground for transceiver | Ground pin for the core | | | DV33 | I | Power supply for transceiver pins | Power supply pin for pins (3.3 V (Typ.) supplied) | | | DG33 | I | Ground for transceiver pins | Ground pin for transceiver pins | | | DV12 | I | Power supply for transceiver pins | Power supply pin for transceiver pins (1.2 V (Typ.) supplied) | | Classification | Symbol | I/O | Name | Function | |-------------------------|-----------------------|-----|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | USB2.0<br>host/function | DG12 | I | Ground for transceiver pins | Ground pin for transceiver pins | | module (USB) | UV12 | I | Digital power supply for transceiver | Power supply pin for the core (1.2V (Typ.) supplied) | | | UG12 | I | Digital ground for transceiver | Ground pin for the core | | SD host | SDCLK | 0 | SD clock | SD clock output pin | | interface<br>(SDHI) | SDCMD | I/O | SD command | SD command output/response input signal pin | | | SDDATA3 to<br>SDDATA0 | I/O | SD data | SD data bus signal pins | | | SDCD | I | SD card detect | SD card detection pin | | | SDWP | I | SD write protect | SD write protect signal pin | | I <sup>2</sup> C bus | SCL | I/O | Serial clock pin | Serial clock I/O pin | | interface 3<br>(IIC3) | SDA | I/O | Serial data pin | Serial data I/O pin | | Host interface (HIF) | HIFD15 to HIFD00 | I/O | HIF data bus | HIF address, data, and command I/O pins | | | HIFCS | I | HIF chip select | Input pin to receive the HIF chip select signal | | | HIFRS | I | HIF register select | Pin for access type switching instruction to the HIF | | | HIFWR | I | HIF write | Write strobe signal pin | | | HIFRD | I | HIF read | Read strobe signal pin | | | HIFINT | 0 | HIF interrupt | Pin to make an interrupt request from the HIF to the external device | | | HIFMD | I | HIF mode | Pin to specify HIF boot mode | | | HIFDREQ | 0 | HIFDMAC<br>transfer request | Pin to request the external device for DMA transfer to the HIFRAM | | | HIFEBL | I | HIF pin enable | A high-level input on this pin activates all the HIF pins other than this pin. | | | HIFRDY | 0 | HIF boot ready | Indicates that the HIF module reset was canceled in this LSI and that accesses to the HIF module from the external device are acceptable. | | Classification | Symbol | I/O | Name | Function | |------------------------------|-----------------------------|-----|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Serial | TXD2 to TXD0 | 0 | Transmit data | Transmit data pins | | communication interface with | RXD2 to RXD0 | I | Receive data | Receive data pins | | FIFO (SCIF) | SCK2 to SCK0 | I/O | Serial clock | Clock input pins | | | RTS2 to RTS0 | 0 | Request to send | Modem control pins | | | CTS2 to CTS0 | I | Clear to send | Modem control pins | | I/O ports | PA25 to PA17 | I/O | General port | 9-bit general I/O port pins | | | PB07, PB05, PB04 | I/O | General port | 3-bit general I/O port pins | | | PB06, PB03 to<br>PB00 | I | General port | 5-bit general input port pins | | | PC20 to PC01 | I/O | General port | 20-bit general I/O port pins | | | PC00 | I | General port | 1-bit general input port pin | | | PD07, PD06, PD03<br>to PD00 | I/O | General port | 6-bit general I/O port pins | | | PD05, PD04 | I | General port | 2-bit general input port pins | | | PE11 to PE00 | I/O | General port | 12-bit general I/O port pins | | | PF11 to PF00 | I/O | General port | 12-bit general I/O port pins | | | PG23 to PG00 | I/O | General port | 24-bit general I/O port pins | | User | TCK | I | Test clock | Test clock input pin | | debugging<br>interface | TMS | I | Test mode select | Test mode selection signal input pin | | (H-UDI) | TDI | I | Test data input | Serial input pin for instructions and data | | | TDO | 0 | Test data output | Serial output pin for instructions and data | | | TRST | I | Test reset | Initialization signal input pin | | Emulator | ASEMD | I | ASE mode | Pin to set ASE mode | | interface | | | | A low-level input on this pin enables<br>ASE mode, and a high-level input<br>enables normal mode. The emulator-<br>specific functions are available in ASE<br>mode. | | Test mode | TESTMD | I | Test mode | Pin to set test mode. | | | TM. | | | A low-level input on this pin enables test mode. Fix this input pin high. | Note: \* Magic Packet<sup>™</sup> is a registered trademark of Advanced Micro Devices, Inc. Table 1.4 List of I/O Attributes of Each Pin | Pin Number | Function Name | I/O Attribute | |------------|--------------------------|---------------| | A1 | PA17/A17 | 10/0 | | A2 | A00 | 0 | | A3 | PB04/CE2A/IRQ2/DACK1 | 10/0/1/0 | | A4 | PB00/WAIT/SDA | I/I/IO | | A5 | PB06/CS4 | I/O | | A6 | WE1/DQMLU/WE | 0/0/0 | | A7 | D09 | Ю | | A8 | D12 | Ю | | A9 | D15 | 10 | | A10 | D05 | Ю | | A11 | D02 | Ю | | A12 | A16 | 0 | | A13 | A13 | 0 | | A14 | A10 | 0 | | A15 | A07 | 0 | | A16 | A04 | 0 | | A17 | A01 | 0 | | A18 | RAS | 0 | | A19 | CAS | 0 | | A20 | VssQ | Power | | B1 | PA19/A19 | IO/O | | B2 | PA18/A18 | 10/0 | | B3 | PB05/CS5/CE1A/IRQ3/TEND1 | 10/0/0/1/0 | | B4 | PB02/CE2B/IRQ0 | I/O/I | | B5 | RD | 0 | | B6 | PB07/BS | IO/O | | B7 | D08 | Ю | | B8 | D10 | Ю | | B9 | D14 | 10 | | B10 | D06 | 10 | | B11 | D03 | Ю | | Pin Number | Function Name | I/O Attribute | |------------|--------------------------|---------------| | B12 | D00 | 10 | | B13 | A14 | 0 | | B14 | A11 | 0 | | B15 | A08 | 0 | | B16 | A05 | 0 | | B17 | A02 | 0 | | B18 | CS3 | 0 | | B19 | V <sub>ss</sub> Q | Power | | B20 | CKE | 0 | | C1 | PA22/A22 | 10/0 | | C2 | PA21/A21 | 10/0 | | C3 | PA20/A20 | IO/O | | C4 | PB03/CS6/CE1B/IRQ1/DREQ1 | I/O/O/I/I | | C5 | PB01/IOIS16/SCL | I/I/IO | | C6 | CS0 | 0 | | C7 | WE0/DQMLL | 0/0 | | C8 | D11 | 10 | | C9 | D13 | 10 | | C10 | D07 | 10 | | C11 | D04 | 10 | | C12 | D01 | 10 | | C13 | A15 | 0 | | C14 | A12 | 0 | | C15 | A09 | 0 | | C16 | A06 | 0 | | C17 | A03 | 0 | | C18 | $V_{ss}Q$ | Power | | C19 | RDWR | 0 | | C20 | CKIO | 10 | | D1 | HIFMD/PA25/A25 | I/IO/o | | D2 | PA24/A24 | 10/0 | | D3 | PA23/A23 | IO/O | | Pin Number | Function Name | I/O Attribute | |------------|-----------------------|---------------| | D4 | V <sub>ss</sub> Q_14 | Power | | D5 | V <sub>ss</sub> _07 | Power | | D6 | V <sub>cc</sub> Q_14 | Power | | D7 | V <sub>cc</sub> _07 | Power | | D8 | V <sub>ss</sub> Q_13 | Power | | D9 | V <sub>cc</sub> Q_13 | Power | | D10 | V <sub>cc</sub> Q_12 | Power | | D11 | V <sub>ss</sub> Q | Power | | D12 | V <sub>ss</sub> Q _12 | Power | | D13 | V <sub>cc</sub> _06 | Power | | D14 | V <sub>ss</sub> _06 | Power | | D15 | V <sub>cc</sub> Q_11 | Power | | D16 | V <sub>ss</sub> Q_11 | Power | | D17 | V <sub>ss</sub> Q_10 | Power | | D18 | WE3/DQMUU/ICIOWR | 0/0/0 | | D19 | WE2/DQMUL/ICIORD | 0/0/0 | | D20 | D25 | 10 | | E1 | PC18/LNKSTA | IO/I | | E2 | PC19/EXOUT | IO/O | | E3 | PC20/WOL | IO/O | | E4 | V <sub>ss</sub> Q_00 | Power | | E17 | V <sub>ss</sub> Q_09 | Power | | E18 | D24 | Ю | | E19 | D26 | 10 | | E20 | D28 | 10 | | F1 | PC13/TX_CLK | IO/I | | F2 | PC16/MDIO | IO/IO | | F3 | PC17/MDC | IO/I | | F4 | $V_{cc}Q_00$ | Power | | F17 | V <sub>cc</sub> Q_10 | Power | | F18 | D27 | 10 | | F19 | D29 | 10 | | Pin Number | Function Name | I/O Attribute | |------------|----------------------|---------------| | F20 | D30 | 10 | | G1 | PC07/MII_TXD3 | IO/O | | G2 | PC11/TX_ER | IO/O | | G3 | PC12/TX_EN | IO/O | | G4 | V <sub>ss</sub> _00 | Power | | G17 | V <sub>cc</sub> Q_09 | Power | | G18 | D31 | 10 | | G19 | D23 | 10 | | G20 | D22 | 10 | | H1 | PC04/MII_TXD0 | 10/0 | | H2 | PC05/MILL_TXD1 | 10/0 | | H3 | PC06/MII_TXD2 | 10/0 | | H4 | V <sub>cc</sub> _00 | Power | | H17 | V <sub>cc</sub> Q_08 | Power | | H18 | V <sub>cc</sub> Q_07 | Power | | H19 | D21 | 10 | | H20 | D20 | 10 | | J1 | PC10/RX_CLK | IO/I | | J2 | PC14/COL | IO/I | | J3 | PC15/CRS | IO/I | | J4 | V <sub>ss</sub> Q_01 | Power | | J17 | V <sub>ss</sub> Q_08 | Power | | J18 | V <sub>ss</sub> Q_07 | Power | | J19 | D19 | 10 | | J20 | D18 | 10 | | K1 | PC03/MII_RXD3 | IO/I | | K2 | PC08/RX_DV | IO/I | | K3 | PC09/RX_ER | IO/I | | K4 | V <sub>cc</sub> Q_01 | Power | | K17 | V <sub>cc</sub> _05 | Power | | K18 | V <sub>ss</sub> Q | Power | | K19 | D17 | 10 | | Pin Number | Function Name | I/O Attribute | |------------|----------------------|---------------| | K20 | D16 | 10 | | L1 | PC00/MII_RXD0 | 1/1 | | L2 | PC01/MII_RXD1 | IO/I | | L3 | PC02/MII_RXD2 | IO/I | | L4 | V <sub>cc</sub> Q_02 | Power | | L17 | V <sub>ss</sub> _05 | Power | | L18 | PF05/ST0_D5/RTS0 | IO/IO/IO | | L19 | PF06/ST0_D6/SSIDATA0 | IO/IO/IO | | L20 | PF07/ST0_D7/SSIWS0 | 10/10/10 | | M1 | TESTMD | I | | M2 | ASEMD | I | | M3 | PD07/IRQ7/SDCLK | IO/I/O | | M4 | V <sub>ss</sub> Q | Power | | M17 | $V_{ss}Q$ | Power | | M18 | PF02/ST0_D2/RxD0 | IO/IO/I | | M19 | PF03/ST0_D3/SCK0 | IO/IO/IO | | M20 | PF04/ST0_D4/CTS0 | IO/IO/IO | | N1 | PD04/IRQ4/SDWP | 1/1/1 | | N2 | PD05/IRQ5/SDCD | 1/1/1 | | N3 | PD06/IRQ6/SDCMD | IO/I/IO | | N4 | V <sub>ss</sub> Q_02 | Power | | N17 | V <sub>cc</sub> Q_06 | Power | | N18 | PF01/ST0_D1/TxD0 | 10/10/0 | | N19 | PF10/ST0_SYC/DACK0 | 10/0/0 | | N20 | PF00/ST0_D0 | 10/10 | | P1 | PD01/IRQ1/SDDAT1 | IO/I/I | | P2 | PD02/IRQ2/SDDAT2 | IO/I/IO | | P3 | PD03/IRQ3/SDDAT3 | IO/I/IO | | P4 | V <sub>cc</sub> _01 | Power | | P17 | V <sub>ss</sub> Q_06 | Power | | P18 | PF11/ST0_PWM/TEND0 | 10/0/0 | | P19 | PF08/ST0_REQ | IO/IO | | Pin Number | Function Name | I/O Attribute | |------------|----------------------|---------------| | P20 | PF09_ST0_VLD/DREQ0 | IO/IO/I | | R1 | PG14/HIFD14 | IO/IO | | R2 | PG15/HIFD15 | IO/IO | | R3 | PD00/IRQ0/SDDAT0 | IO/I/IO | | R4 | V <sub>cc</sub> _02 | Power | | R17 | V <sub>cc</sub> _04 | Power | | R18 | WDTOVF | 0 | | R19 | ST0_CLKIN/SSISCK0 | I/IO | | R20 | ST0_VCO_CLKIN | I | | T1 | PG11/HIFD11 | IO/IO | | T2 | PG12/HIFD12 | IO/IO | | T3 | PG13/HIFD13 | IO/IO | | T4 | V <sub>ss</sub> _01 | Power | | T17 | V <sub>ss</sub> _04 | Power | | T18 | $V_{ss}Q$ | Power | | T19 | MD_BW | I | | T20 | ASEBRK/ASEBRKAK | I/O | | U1 | PG09/HIFD09 | IO/IO | | U2 | PG10/HIFD10 | IO/IO | | U3 | $V_{ss}Q$ | Power | | U4 | V <sub>ss</sub> _02 | Power | | U5 | $V_{ss}Q_03$ | Power | | U6 | V <sub>cc</sub> Q_03 | Power | | U7 | $V_{\rm ss}Q$ | Power | | U8 | DG12 | Power | | U9 | DV12 | Power | | U10 | UV12 | Power | | U11 | AV12 | Power | | U12 | V <sub>cc</sub> _03 | Power | | U13 | V <sub>ss</sub> _03 | Power | | U14 | V <sub>cc</sub> Q_04 | Power | | U15 | V <sub>cc</sub> Q_05 | Power | | Pin Number | Function Name | I/O Attribute | |------------|-------------------------|---------------| | U16 | V <sub>ss</sub> Q_04 | Power | | U17 | V <sub>ss</sub> Q _05 | Power | | U18 | MD_CK1 | 1 | | U19 | NMI | 1 | | U20 | PLLV <sub>cc</sub> | Power | | V1 | PG07/HIFD07 | IO/IO | | V2 | V <sub>ss</sub> Q | Power | | V3 | PG04/HIFD04 | IO/IO | | V4 | PG01/HIFD01 | IO/IO | | V5 | PG22/HIFRS | IO/I | | V6 | PG17/HIFRDY | IO/O | | V7 | V <sub>ss</sub> Q | Power | | V8 | V <sub>ss</sub> Q | Power | | V9 | V <sub>ss</sub> Q | Power | | V10 | UG12 | Power | | V11 | AG12 | Power | | V12 | PE07/ST1_D7/SSIWS1 | IO/IO/IO | | V13 | PE06/ST1_D6/SSIDATA1 | IO/IO/IO | | V14 | PE01/ST1_D1/TxD1 | IO/IO/O | | V15 | PE03/ST1_D3/SCK1 | 10/0/10 | | V16 | ST1_VCO_CLKIN/AUDIO_CLK | 1/1 | | V17 | TCK | 1 | | V18 | TDI | 1 | | V19 | MD_CK0 | 1 | | V20 | EXTAL | 1 | | W1 | V <sub>ss</sub> Q | Power | | W2 | PG06/HIFD06 | IO/IO | | W3 | PG03/HIFD03 | IO/IO | | W4 | PG00/HIFD00 | IO/IO | | W5 | PG21/HIFWR | IO/I | | W6 | PG18/HIFDREQ | IO/O | | W7 | PG16/HIFEBL | IO/I | | Pin Number | Function Name | I/O Attribute | |------------|--------------------|---------------| | W8 | DG33 | Power | | W9 | VBUS | I | | W10 | AG33 | Power | | W11 | V <sub>ss</sub> Q | Power | | W12 | USB_X1 | I | | W13 | PE05/ST1_D5/RTS1 | IO/IO/IO | | W14 | PE02/ST1_D2/RxD1 | IO/IO/I | | W15 | PE10/ST1_SYC/CTS2 | IO/IO/IO | | W16 | PE11/ST1_PWM/RTS2 | 10/0/10 | | W17 | ST1_CLKIN/SSISCK1 | I/IO | | W18 | RES | 1 | | W19 | TDO | 0 | | W20 | XTAL | 0 | | Y1 | PG08/HIFD08 | IO/IO | | Y2 | PG05/HIFD05 | IO/IO | | Y3 | PG02/HIFD02 | IO/IO | | Y4 | PG23/HIFCS | IO/I | | Y5 | PG20/HIFRD | IO/I | | Y6 | PG19/HIFINT | IO/O | | Y7 | DV33 | Power | | Y8 | DM | Ю | | Y9 | DP | Ю | | Y10 | AV33 | Power | | Y11 | REFRIN | I | | Y12 | USB_X2 | 0 | | Y13 | PE04/ST1_D4/CTS1 | IO/IO/IO | | Y14 | PE09/ST1_VLD/SCK2 | 10/10/10 | | Y15 | PE00/ST1_D0/RxD2 | 10/10/1 | | Y16 | PE08/ST1_REQ/TxD2 | 10/10/0 | | Y17 | ST_CLKOUT | 0 | | Y18 | TRST | <u> </u> | | Y19 | TMS | <u> </u> | | Y20 | PLLV <sub>ss</sub> | Power | ## Section 2 CPU ## 2.1 Register Configuration The register set consists of sixteen 32-bit general registers, four 32-bit control registers, and four 32-bit system registers. #### 2.1.1 General Registers Figure 2.1 shows the general registers. The sixteen 32-bit general registers are numbered R0 to R15. General registers are used for data processing and address calculation. R0 is also used as an index register. Several instructions have R0 fixed as their only usable register. R15 is used as the hardware stack pointer (SP). Saving and restoring the status register (SR) and program counter (PC) in exception handling is accomplished by referencing the stack using R15. | 31 | | 0 | |-------------|------------------------|----| | | R0*1 | | | | R1 | | | | R2 | | | | R3 | | | | R4 | | | | R5 | | | | R6 | | | | R7 | | | | R8 | | | | R9 | | | | R10 | | | | R11 | | | | R12 | | | | R13 | | | | R14 | | | R15, SP (ha | ardware stack pointer) | *2 | Notes: 1. R0 functions as an index register in the indexed register indirect addressing mode and indexed GBR indirect addressing mode. In some instructions, R0 functions as a fixed source register or destination register. 2. R15 functions as a hardware stack pointer (SP) during exception processing. Figure 2.1 General Registers Section 2 CPU SH7670 Group #### 2.1.2 Control Registers The control registers consist of four 32-bit registers: the status register (SR), the global base register (GBR), the vector base register (VBR), and the jump table base register (TBR). The status register indicates instruction processing states. The global base register functions as a base address for the GBR indirect addressing mode to transfer data to the registers of on-chip peripheral modules. The vector base register functions as the base address of the exception handling vector area (including interrupts). The jump table base register functions as the base address of the function table area. Figure 2.2 Control Registers ## (1) Status Register (SR) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |----------------|----|-----|-----|----|-----|----|-----|-----|-----|-----|-----|-----|----|----|-----|-----|--| | | 1 | - | - | 1 | - 1 | - | - | - | - | - | - | - | - | 1 | - | - | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 1 | во | CS | 1 | 1 | - | М | Ø | | 1[3 | :0] | | 1 | 1 | S | Т | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | - | - | 1 | 1 | 1 | 1 | 0 | 0 | - | - | | | R/W: | R | R/W | R/W | R | R | R | R/W | R/W | R/W | R/W | R/W | R/W | R | R | R/W | R/W | | | Bit | Bit Name | Initial Value | R/W | Description | |----------|----------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 15 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 14 | ВО | 0 | R/W | BO Bit | | | | | | Indicates that a register bank has overflowed. | | 13 | CS | 0 | R/W | CS Bit | | | | | | Indicates that, in CLIP instruction execution, the value has exceeded the saturation upper-limit value or fallen below the saturation lower-limit value. | | 12 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | М | _ | R/W | M Bit | | 8 | Q | _ | R/W | Q Bit | | | | | | Used by the DIV0S, DIV0U, and DIV1 instructions. | | 7 to 4 | I[3:0] | 1111 | R/W | Interrupt Mask Level | | 3, 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | S | _ | R/W | S Bit | | | | | | Specifies a saturation operation for a MAC instruction. | | 0 | T | _ | R/W | T Bit | | | | | | True/false condition or carry/borrow bit | ## (2) Global Base Register (GBR) GBR is referenced as the base address in a GBR-referencing MOV instruction. ## (3) Vector Base Register (VBR) VBR is referenced as the branch destination base address in the event of an exception or an interrupt. ## (4) Jump Table Base Register (TBR) TBR is referenced as the start address of a function table located in memory in a JSR/N@@(disp8,TBR) table-referencing subroutine call instruction. Section 2 CPU SH7670 Group #### 2.1.3 System Registers The system registers consist of four 32-bit registers: the high and low multiply and accumulate registers (MACH and MACL), the procedure register (PR), and the program counter (PC). MACH and MACL store the results of multiply or multiply and accumulate operations. PR stores the return address from a subroutine procedure. PC indicates the program address being executed and controls the flow of the processing. Figure 2.3 System Registers # (1) Multiply and Accumulate Register High (MACH) and Multiply and Accumulate Register Low (MACL) MACH and MACL are used as the addition value in a MAC instruction, and store the result of a MAC or MUL instruction. ## (2) Procedure Register (PR) PR stores the return address of a subroutine call using a BSR, BSRF, or JSR instruction, and is referenced by a subroutine return instruction (RTS). ## (3) Program Counter (PC) PC indicates the address of the instruction being executed. ## 2.1.4 Register Banks For the nineteen 32-bit registers comprising general registers R0 to R14, control register GBR, and system registers MACH, MACL, and PR, high-speed register saving and restoration can be carried out using a register bank. The register contents are automatically saved in the bank after the CPU accepts an interrupt that uses a register bank. Restoration from the bank is executed by issuing a RESBANK instruction in an interrupt processing routine. This LSI has 15 banks. For details, see the SH-2A, SH2A-FPU Software Manual and section 6.8, Register Banks. #### 2.1.5 Initial Values of Registers Table 2.1 lists the values of the registers after a reset. **Table 2.1** Initial Values of Registers | ointer in the vector | |-----------------------------------------------| | (H'F), BO and CS are<br>0, and other bits are | | | | | | | | n counter in the vector | | | Section 2 CPU SH7670 Group #### 2.2 Data Formats #### 2.2.1 Data Format in Registers Register operands are always longwords (32 bits). If the size of memory operand is a byte (8 bits) or a word (16 bits), it is changed into a longword by expanding the sign-part when loaded into a register. Figure 2.4 Data Format in Registers #### 2.2.2 Data Formats in Memory Memory data formats are classified into bytes, words, and longwords. Memory can be accessed in 8-bit bytes, 16-bit words, or 32-bit longwords. A memory operand of fewer than 32 bits is stored in a register in sign-extended or zero-extended form. A word operand should be accessed at a word boundary (an even address of multiple of two bytes: address 2n), and a longword operand at a longword boundary (an even address of multiple of four bytes: address 4n). Otherwise, an address error will occur. A byte operand can be accessed at any address. Only big-endian byte order can be selected for the data format. Data formats in memory are shown in figure 2.5. Figure 2.5 Data Formats in Memory #### 2.2.3 Immediate Data Format Byte (8-bit) immediate data is located in an instruction code. Immediate data accessed by the MOV, ADD, and CMP/EQ instructions is sign-extended and handled in registers as longword data. Immediate data accessed by the TST, AND, OR, and XOR instructions is zero-extended and handled as longword data. Consequently, AND instructions with immediate data always clear the upper 24 bits of the destination register. 20-bit immediate data is located in the code of a MOVI20 or MOVI20S 32-bit transfer instruction. The MOVI20 instruction stores immediate data in the destination register in sign-extended form. The MOVI20S instruction shifts immediate data by eight bits in the upper direction, and stores it in the destination register in sign-extended form. Word or longword immediate data is not located in the instruction code, but rather is stored in a memory table. The memory table is accessed by an immediate data transfer instruction (MOV) using the PC relative addressing mode with displacement. See examples given in section 2.3.1 (10), Immediate Data. Section 2 CPU SH7670 Group #### 2.3 Instruction Features #### 2.3.1 RISC-Type Instruction Set Instructions are RISC type. This section details their functions. #### (1) 16-Bit Fixed-Length Instructions Basic instructions have a fixed length of 16 bits, improving program code efficiency. #### (2) 32-Bit Fixed-Length Instructions The SH-2A additionally features 32-bit fixed-length instructions, improving performance and ease of use. #### (3) One Instruction per State Each basic instruction can be executed in one cycle using the pipeline system. #### (4) Data Length Longword is the standard data length for all operations. Memory can be accessed in bytes, words, or longwords. Byte or word data in memory is sign-extended and handled as longword data. Immediate data is sign-extended for arithmetic operations or zero-extended for logic operations. It is also handled as longword data. Table 2.2 Sign Extension of Word Data | SH2-A CP | U | Description | Example of Other CPU | | | | |----------|-----------------|------------------------------------------------|----------------------|--|--|--| | MOV.W | @(disp,PC),R1 | Data is sign-extended to 32 | ADD.W #H'1234,R0 | | | | | ADD | R1,R0 | bits, and R1 becomes<br>H'00001234. It is next | | | | | | | • • • • • • • • | operated upon by an ADD | | | | | | .DATA.W | H'1234 | instruction. | | | | | Note: @(disp, PC) accesses the immediate data. ## (5) Load-Store Architecture Basic operations are executed between registers. For operations that involve memory access, data is loaded to the registers and executed (load-store architecture). Instructions such as AND that manipulate bits, however, are executed directly in memory. #### (6) Delayed Branch Instructions With the exception of some instructions, unconditional branch instructions, etc., are executed as delayed branch instructions. With a delayed branch instruction, the branch is taken after execution of the instruction immediately following the delayed branch instruction. This reduces disturbance of the pipeline control when a branch is taken. In a delayed branch, the actual branch operation occurs after execution of the slot instruction. However, instruction execution such as register updating excluding the actual branch operation, is performed in the order of delayed branch instruction $\rightarrow$ delay slot instruction. For example, even though the contents of the register holding the branch destination address are changed in the delay slot, the branch destination address remains as the register contents prior to the change. **Table 2.3** Delayed Branch Instructions | SH-2A CPU | | Description | Example of Other CPU | | |-----------|-------|-------------------------|----------------------|-------| | BRA | TRGET | Executes the ADD before | ADD.W | R1,R0 | | ADD | R1,R0 | branching to TRGET. | BRA | TRGET | #### (7) Unconditional Branch Instructions with No Delay Slot The SH-2A additionally features unconditional branch instructions in which a delay slot instruction is not executed. This eliminates unnecessary NOP instructions, and so reduces the code size. ## (8) Multiply/Multiply-and-Accumulate Operations 16-bit $\times$ 16-bit $\to$ 32-bit multiply operations are executed in one to two cycles. 16-bit $\times$ 16-bit + 64-bit $\to$ 64-bit multiply-and-accumulate operations are executed in two to three cycles. 32-bit $\times$ 32-bit $\to$ 64-bit multiply and 32-bit $\times$ 32-bit $\to$ 64-bit multiply-and-accumulate operations are executed in two to four cycles. ## (9) T Bit The T bit in the status register (SR) changes according to the result of the comparison. Whether a conditional branch is taken or not taken depends upon the T bit condition (true/false). The number of instructions that change the T bit is kept to a minimum to improve the processing speed. Section 2 CPU SH7670 Group Table 2.4 T Bit | SH-2A CPU | | Description | Example of Other CPU | | |-----------|--------|-------------------------------------------------|----------------------|--------| | CMP/GE | R1,R0 | T bit is set when $R0 \ge R1$ . | CMP.W | R1,R0 | | BT | TRGET0 | The program branches to TRGET0 | BGE | TRGET0 | | BF | TRGET1 | when $R0 \ge R1$ and to TRGET1 when $R0 < R1$ . | BLT | TRGET1 | | ADD | #-1,R0 | T bit is not changed by ADD. | SUB.W | #1,R0 | | CMP/EQ | #0,R0 | T bit is set when $R0 = 0$ . | BEQ | TRGET | | BT | TRGET | The program branches if $R0 = 0$ . | | | #### (10) Immediate Data Byte immediate data is located in an instruction code. Word or longword immediate data is not located in instruction codes but in a memory table. The memory table is accessed by an immediate data transfer instruction (MOV) using the PC relative addressing mode with displacement. With the SH-2A, 17- to 28-bit immediate data can be located in an instruction code. However, for 21- to 28-bit immediate data, an OR instruction must be executed after the data is transferred to a register. Table 2.5 Immediate Data Accessing | Classification | SH-2A CPU | | Exampl | e of Other CPU | |------------------|-----------|---------------|--------|----------------| | 8-bit immediate | MOV | #H'12,R0 | MOV.B | #H'12,R0 | | 16-bit immediate | MOVI20 | #H'1234,R0 | MOV.W | #H'1234,R0 | | 20-bit immediate | MOVI20 | #H'12345,R0 | MOV.L | #H'12345,R0 | | 28-bit immediate | MOVI20S | #H'12345,R0 | MOV.L | #H'1234567,R0 | | | OR | #H'67,R0 | | | | 32-bit immediate | MOV.L | @(disp,PC),R0 | MOV.L | #H'12345678,R0 | | | | | | | | | .DATA.L | Н'12345678 | | | Note: @(disp, PC) accesses the immediate data. #### (11) Absolute Address When data is accessed by an absolute address, the absolute address value should be placed in the memory table in advance. That value is transferred to the register by loading the immediate data during the execution of the instruction, and the data is accessed in register indirect addressing mode. With the SH-2A, when data is referenced using an absolute address not exceeding 28 bits, it is also possible to transfer immediate data located in the instruction code to a register and to reference the data in register indirect addressing mode. However, when referencing data using an absolute address of 21 to 28 bits, an OR instruction must be used after the data is transferred to a register. Table 2.6 Absolute Address Accessing | Classification | SH-2A CPU | | Example of Other CPU | | |-----------------|-----------|---------------|----------------------|----------------| | Up to 20 bits | MOVI20 | #H'12345,R1 | MOV.B | @H'12345,R0 | | | MOV.B | @R1,R0 | | | | 21 to 28 bits | MOVI20S | #H'12345,R1 | MOV.B | @H'1234567,R0 | | | OR | #H'67,R1 | | | | | MOV.B | @R1,R0 | | | | 29 bits or more | MOV.L | @(disp,PC),R1 | MOV.B | @H'12345678,R0 | | | MOV.B | @R1,R0 | | | | | | | | | | | .DATA.L | Н'12345678 | | | ## (12) 16-Bit/32-Bit Displacement When data is accessed by 16-bit or 32-bit displacement, the displacement value should be placed in the memory table in advance. That value is transferred to the register by loading the immediate data during the execution of the instruction, and the data is accessed in the indexed indirect register addressing mode. **Table 2.7 Displacement Accessing** | Classification | SH-2A CPU | Example of Other CPU | | e of Other CPU | |---------------------|-----------|----------------------|-------|-----------------| | 16-bit displacement | MOV.W | @(disp,PC),R0 | MOV.W | @(H'1234,R1),R2 | | | MOV.W | @(R0,R1),R2 | | | | | | | | | | | .DATA.W | Н'1234 | | | Section 2 CPU SH7670 Group ## 2.3.2 Addressing Modes Addressing modes and effective address calculation are as follows: Table 2.8 Addressing Modes and Effective Addresses | Addressing<br>Mode | Instruction Format | Effective Address Calculation | Equation | |------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | Register direct | Rn | The effective address is register Rn. (The operand is the contents of register Rn.) | _ | | Register indirect | @Rn | The effective address is the contents of register Rn. | Rn | | Register indirect with post- | @Rn+ | The effective address is the contents of register Rn. | | | increment | | A constant is added to the contents of Rn after the instruction is executed. 1 is added for a byte operation, 2 for a word operation, and 4 for a longword operation. | | | | | Rn Rn | Byte: $Rn + 1 \rightarrow Rn$ | | | | 1/2/4 | Word: $Rn + 2 \rightarrow Rn$ | | | | 1/2/4 | Longword: $Rn + 4 \rightarrow Rn$ | | Register indirect with pre- | @-Rn | The effective address is the value obtained by subtracting a constant from Rn. 1 is subtracted for | Byte:<br>Rn – 1 → Rn | | decrement | a byte operation, 2 for a word operation, and 4 for | | Word: $Rn - 2 \rightarrow Rn$ | | | | Rn - 1/2/4 - Rn - 1/2/4 | Longword:<br>$Rn - 4 \rightarrow Rn$<br>(Instruction is<br>executed with<br>Rn after this<br>calculation) | | Addressing<br>Mode | Instruction<br>Format | Effective Address Calculation | Equation | |-------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------| | Register indirect with displacement | @(disp:4,<br>Rn) | The effective address is the sum of Rn and a 4-bit displacement (disp). The value of disp is zero-extended, and remains unchanged for a byte operation, is doubled for a word operation, and is quadrupled for a longword operation. Rn disp (zero-extended) Rn + disp 1/2/4 | Byte:<br>Rn + disp<br>Word:<br>Rn + disp × 2<br>Longword:<br>Rn + disp × 4 | | Register indirect with displacement | @(disp:12,<br>Rn) | The effective address is the sum of Rn and a 12-bit displacement (disp). The value of disp is zero-extended. Rn Rn + disp (zero-extended) | Byte:<br>Rn + disp<br>Word:<br>Rn + disp<br>Longword:<br>Rn + disp | | Indexed register indirect | @(R0,Rn) | The effective address is the sum of Rn and R0. Rn Rn + R0 | Rn + R0 | | GBR indirect with displacement | @(disp:8,<br>GBR) | The effective address is the sum of GBR value and an 8-bit displacement (disp). The value of disp is zero-extended, and remains unchanged for a byte operation, is doubled for a word operation, and is quadrupled for a longword operation. GBR disp (zero-extended) GBR disp (zero-extended) | Byte:<br>GBR + disp<br>Word:<br>GBR + disp × 2<br>Longword:<br>GBR + disp × 4 | | Addressing<br>Mode | Instruction<br>Format | Effective Address Calculation | Equation | |------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------| | Indexed GBR indirect | @(R0, GBR) | The effective address is the sum of GBR value and R0. GBR GBR + R0 | GBR + R0 | | TBR duplicate indirect with displacement | @@ (disp:8, TBR) | The effective address is the sum of TBR value and an 8-bit displacement (disp). The value of disp is zero-extended, and is multiplied by 4. TBR disp (zero-extended) TBR TBR + disp 4 | Contents of address (TBR + disp × 4) | | PC indirect with displacement | @(disp:8,<br>PC) | The effective address is the sum of PC value and an 8-bit displacement (disp). The value of disp is zero-extended, and is doubled for a word operation, and quadrupled for a longword operation. For a longword operation, the lowest two bits of the PC value are masked. PC PC + disp 2 or PC & H'FFFFFFFC + disp 4 PC d | Word: PC + disp × 2 Longword: PC & H'FFFFFFFC + disp × 4 | | Addressing<br>Mode | Instruction<br>Format | Effective Address Calculation | Equation | |--------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------| | PC relative | disp:8 | The effective address is the sum of PC value and the value that is obtained by doubling the sign-extended 8-bit displacement (disp). | PC + disp × 2 | | | | disp (sign-extended) PC + disp 2 | | | | disp:12 | The effective address is the sum of PC value and the value that is obtained by doubling the sign-extended 12-bit displacement (disp). | PC + disp × 2 | | | | disp (sign-extended) + PC + disp 2 | | | | Rn | The effective address is the sum of PC value and | PC + Rn | | | KII | Rn. | 10+1111 | | | | PC + Rn | | | | | Rn | | | Addressing<br>Mode | Instruction<br>Format | Effective Address Calculation | Equation | |--------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | Immediate | #imm:20 | The 20-bit immediate data (imm) for the MOVI20 instruction is sign-extended. | _ | | | | 31 19 0 Sign- extended imm (20 bits) | | | | | The 20-bit immediate data (imm) for the MOVI20S instruction is shifted by eight bits to the left, the upper bits are sign-extended, and the lower bits are padded with zero. | _ | | | | 31 27 8 0 imm (20 bits) 00000000 | | | | #imm:8 | The 8-bit immediate data (imm) for the TST, AND, OR, and XOR instructions is zero-extended. | _ | | | #imm:8 | The 8-bit immediate data (imm) for the MOV, ADD, and CMP/EQ instructions is sign-extended. | _ | | | #imm:8 | The 8-bit immediate data (imm) for the TRAPA instruction is zero-extended and then quadrupled. | _ | | | #imm:3 | The 3-bit immediate data (imm) for the BAND, BOR, BXOR, BST, BLD, BSET, and BCLR instructions indicates the target bit location. | _ | #### 2.3.3 Instruction Format The instruction formats and the meaning of source and destination operands are described below. The meaning of the operand depends on the instruction code. The symbols used are as follows: xxxx: Instruction code mmmm: Source register nnnn: Destination register iiii: Immediate data ini: immediate datadddd: Displacement **Table 2.9 Instruction Formats** | Instruction Formats | Source<br>Operand | Destination<br>Operand | Example | | |--------------------------------------------|---------------------------------------------|-----------------------------------------------|---------|----------------| | 0 format 15 0 xxxx xxxx xxxx xxxx | _ | _ | NOP | | | n format | _ | nnnn: Register<br>direct | MOVT | Rn | | xxxx nnnn xxxx xxxx | Control register or system register | nnnn: Register<br>direct | STS | MACH,Rn | | | R0 (Register direct) | nnnn: Register<br>direct | DIVU | R0,Rn | | | Control register or system register | nnnn: Register indirect with pre-decrement | STC.L | SR,@-Rn | | | mmmm: Register direct | R15 (Register indirect with predecrement) | MOVMU. | .L<br>Rm,@-R15 | | | R15 (Register indirect with post-increment) | nnnn: Register<br>direct | MOVMU. | .L<br>@R15+,Rn | | | R0 (Register direct) | nnnn: (Register indirect with post-increment) | MOV.L | R0,@Rn+ | | Instruction Formats | Source<br>Operand | Destination<br>Operand | Example | | | |---------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------|-----------------|-----------|--| | m format | mmmm: Register direct | Control register or system register | LDC | Rm,SR | | | xxxx mmmm xxxx xxxx | mmmm: Register indirect with post-increment | Control register or<br>system register | LDC.L | @Rm+,SR | | | | mmmm: Register indirect | _ | JMP | @Rm | | | | mmmm: Register indirect with predecrement | R0 (Register direct) | MOV.L | @-Rm,R0 | | | | mmmm: PC relative using Rm | _ | BRAF | Rm | | | nm format | mmmm: Register direct | nnnn: Register<br>direct | ADD | Rm,Rn | | | xxxx nnnn mmmm xxxx | mmmm: Register direct | nnnn: Register indirect | MOV.L | Rm,@Rn | | | | mmmm: Register indirect with post-increment (multiply-and-accumulate) | MACH, MACL | MAC.W | @Rm+,@Rn+ | | | | nnnn*: Register<br>indirect with post-<br>increment (multiply-<br>and-accumulate) | | | | | | | mmmm: Register indirect with post-increment | nnnn: Register<br>direct | MOV.L | @Rm+,Rn | | | | mmmm: Register direct | nnnn: Register indirect with pre-decrement | MOV.L | Rm,@−Rn | | | | mmmm: Register direct | nnnn: Indexed register indirect | MOV.L<br>Rm,@(F | R0,Rn) | | | md format 15 0 xxxx xxxxx mmmm dddd | mmmmdddd:<br>Register indirect<br>with displacement | R0 (Register direct) | MOV.B<br>@(disp | o,Rm),R0 | | | Instruction Formats | Source<br>Operand | Destination<br>Operand | Example | |----------------------------------------|----------------------------------------------------------|-----------------------------------------------------|--------------------------| | nd4 format 15 0 xxxx xxxx nnnn dddd | R0 (Register direct) | nnnndddd:<br>Register indirect<br>with displacement | MOV.B<br>R0,@(disp,Rn) | | nmd format 15 0 xxxx nnnn mmmm dddd | mmmm: Register direct | nnnndddd: Register indirect with displacement | MOV.L<br>Rm,@(disp,Rn) | | | mmmmdddd:<br>Register indirect<br>with displacement | nnnn: Register<br>direct | MOV.L<br>@(disp,Rm),Rn | | nmd12 format 32 | mmmm: Register direct | nnnndddd: Register indirect with displacement | MOV.L<br>Rm,@(disp12,Rn) | | 15 0 xxxx dddd dddd dddd | mmmmdddd:<br>Register indirect<br>with displacement | nnnn: Register<br>direct | MOV.L<br>@(disp12,Rm),Rn | | d format 15 0 xxxx xxxx dddd dddd | ddddddd: GBR<br>indirect with<br>displacement | R0 (Register direct) | MOV.L<br>@(disp,GBR),R0 | | | R0 (Register direct) | ddddddd: GBR<br>indirect with<br>displacement | MOV.L<br>R0,@(disp,GBR) | | | ddddddd: PC<br>relative with<br>displacement | R0 (Register direct) | MOVA @(disp,PC),R0 | | | dddddddd: TBR<br>duplicate indirect<br>with displacement | _ | JSR/N<br>@@(disp8,TBR) | | | dddddddd: PC relative | _ | BF label | | d12 format | ddddddddddd: PC | _ | BRA label | | 15 0<br>xxxx dddd dddd dddd | relative | | (label = disp + PC) | | nd8 format 15 0 xxxxx nnnn dddd dddd | ddddddd: PC<br>relative with<br>displacement | nnnn: Register<br>direct | MOV.L<br>@(disp,PC),Rn | | Source<br>Operand | Destination<br>Operand | Example | | | |------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | iiiiiiii: Immediate | | | @(R0,GBR) | | | iiiiiiii: Immediate | R0 (Register direct) | AND | #imm,R0 | | | iiiiiiii: Immediate | _ | TRAPA | #imm | | | iiiiiiii: Immediate | nnnn: Register direct | ADD | #imm,Rn | | | | | | | | | nnnn: Register direct | _ | BLD | #imm3,Rn | | | iii: Immediate | | | | | | _ | nnnn: Register direct | BST | #imm3,Rn | | | | iii: Immediate | | | | | 100000000000000000000000000000000000000 | nnnn: Register direct | | | | | Immediate | | #imm20, | Rn | | | | | | | | | nnnnddddddddddd:<br>Register indirect with<br>displacement<br>iii: Immediate | _ | BLD.B<br>#imm3,@ | disp12,Rn | | | _ | | | disp12,Rn | | | ** | iii: Immediate | | | | | | Operand iiiiiiii: Immediate iiiiiiii: Immediate iiiiiiii: Immediate iiiiiiii: Immediate iiiiiiii: Immediate nnnn: Register direct iii: Immediate nnnnddddddddddddddddddddddddddddddd | Operand iiiiiiii: Immediate Indexed GBR indirect iiiiiiii: Immediate R0 (Register direct) iiiiiiii: Immediate nnnn: Register direct nnnn: Register direct iii: Immediate nnnndddddddddddddddddddddddddddddddd | Operand Operand Example iiiiiiii: Immediate Indexed GBR indirect #imm, @ i iiiiiii: Immediate R0 (Register direct) AND iiiiiiii: Immediate — TRAPA iiiiiiii: Immediate — nnnn: Register direct ADD nnnn: Register direct — BLD iii: Immediate — nnnn: Register direct iii: Immediate iiii: Immediate nnnn: Register direct #OVI20 #imm20, register indirect with displacement iii: Immediate nnnndddddddddddddddddddddddddddddddd | | Note: \* In multiply-and-accumulate instructions, nnnn is the source register. # 2.4 Instruction Set # 2.4.1 Instruction Set by Classification Table 2.10 lists the instructions according to their classification. **Table 2.10 Classification of Instructions** | Classification | Types | Operation<br>Code | Function | No. of<br>Instructions | |----------------|-------|-------------------|-------------------------------------------------|------------------------| | Data transfer | 13 | MOV | Data transfer | 62 | | | | | Immediate data transfer | | | | | | Peripheral module data transfer | | | | | | Structure data transfer | | | | | | Reverse stack transfer | | | | | MOVA | Effective address transfer | - | | | | MOVI20 | 20-bit immediate data transfer | = | | | | MOVI20S | 20-bit immediate data transfer | = | | | | | 8-bit left-shit | | | | | MOVML | R0-Rn register save/restore | <del>-</del> | | | | MOVMU | Rn-R14 and PR register save/restore | = | | | | MOVRT | T bit inversion and transfer to Rn | = | | | | MOVT | T bit transfer | = | | | | MOVU | Unsigned data transfer | - | | | | NOTT | T bit inversion | - | | | | PREF | Prefetch to operand cache | _ | | | | SWAP | Swap of upper and lower bytes | <del>-</del> | | | | XTRCT | Extraction of the middle of registers connected | - | | | | Operation | | No. of | |----------------|-------|-----------|-----------------------------------------------------------------------------|--------------| | Classification | Types | Code | Function | Instructions | | Arithmetic | 26 | ADD | Binary addition | 40 | | operations | | ADDC | Binary addition with carry | _ | | | | ADDV | Binary addition with overflow check | _ | | | | CMP/cond | Comparison | _ | | | | CLIPS | Signed saturation value comparison | _ | | | | CLIPU | Unsigned saturation value comparison | _ | | | | DIVS | Signed division (32 ÷ 32) | _ | | | | DIVU | Unsigned division (32 ÷ 32) | _ | | | | DIV1 | One-step division | = | | | | DIV0S | Initialization of signed one-step division | = | | | | DIV0U | Initialization of unsigned one-step division | _ | | | | DMULS | Signed double-precision multiplication | _ | | | | DMULU | Unsigned double-precision multiplication | _ | | | | DT | Decrement and test | _ | | | | EXTS | Sign extension | = | | | | EXTU | Zero extension | _ | | | | MAC | Multiply-and-accumulate, double-precision multiply-and-accumulate operation | _ | | | | MUL | Double-precision multiply operation | _ | | | | MULR | Signed multiplication with result storage in Rn | = | | | | MULS | Signed multiplication | _ | | | | MULU | Unsigned multiplication | _ | | | | NEG | Negation | _ | | | | NEGC | Negation with borrow | _ | | | | SUB | Binary subtraction | = | | | | SUBC | Binary subtraction with borrow | _ | | | | SUBV | Binary subtraction with underflow | = | | Classification | Types | Operation Code | Function | No. of<br>Instructions | |----------------|-------|----------------|---------------------------------------------------------------------|------------------------| | Logic | 6 | AND | Logical AND | 14 | | operations | | NOT | Bit inversion | _ | | | | OR | Logical OR | = | | | | TAS | Memory test and bit set | <del>-</del> | | | | TST | Logical AND and T bit set | = | | | | XOR | Exclusive OR | = | | Shift | 12 | ROTL | One-bit left rotation | 16 | | | | ROTR | One-bit right rotation | = | | | | ROTCL | One-bit left rotation with T bit | <del>-</del> | | | | ROTCR | One-bit right rotation with T bit | <del>-</del> | | | | SHAD | Dynamic arithmetic shift | = | | | | SHAL | One-bit arithmetic left shift | = | | | | SHAR | One-bit arithmetic right shift | <del>-</del> | | | | SHLD | Dynamic logical shift | = | | | | SHLL | One-bit logical left shift | = | | | | SHLLn | n-bit logical left shift | _ | | | | SHLR | One-bit logical right shift | = | | | | SHLRn | n-bit logical right shift | = | | Branch | 10 | BF | Conditional branch, conditional delayed branch (branch when $T=0$ ) | 15 | | | | ВТ | Conditional branch, conditional delayed branch (branch when T = 1) | - | | | | BRA | Unconditional delayed branch | _ | | | | BRAF | Unconditional delayed branch | <del>-</del> | | | | BSR | Delayed branch to subroutine procedure | <del>-</del> | | | | BSRF | Delayed branch to subroutine procedure | = | | | | JMP | Unconditional delayed branch | _ | | | | JSR | Branch to subroutine procedure | <del>-</del> | | | | | Delayed branch to subroutine procedure | | | | | RTS | Return from subroutine procedure | - | | | | | Delayed return from subroutine procedure | _ | | | | RTV/N | Return from subroutine procedure with Rm $\rightarrow$ R0 transfer | | | Classification | Types | Operation Code | Function | No. of<br>Instructions | |----------------|-------|----------------|---------------------------------------------------------|------------------------| | System | 14 | CLRT | T bit clear | 36 | | control | | CLRMAC | MAC register clear | _ | | | | LDBANK | Register restoration from specified register bank entry | | | | | LDC | Load to control register | _ | | | | LDS | Load to system register | <del>_</del> | | | | NOP | No operation | _ | | | | RESBANK | Register restoration from register bank | <del>_</del> | | | | RTE | Return from exception handling | <del>_</del> | | | | SETT | T bit set | _ | | | | SLEEP | Transition to power-down mode | <del>_</del> | | | | STBANK | Register save to specified register bank entry | <del>_</del> | | | | STC | Store control register data | _ | | | | STS | Store system register data | _ | | | | TRAPA | Trap exception handling | _ | | Floating-point | nt 19 | FABS | Floating-point absolute value | 48 | | instructions | | FADD | Floating-point addition | _ | | | | FCMP | Floating-point comparison | _ | | | | FCNVDS | Conversion from double-precision to single-precision | _ | | | | FCNVSD | Conversion from single-precision to double - precision | _ | | | | FDIV | Floating-point division | _ | | | | FLDI0 | Floating-point load immediate 0 | <del>_</del> | | | | FLDI1 | Floating-point load immediate 1 | <del>_</del> | | | | FLDS | Floating-point load into system register FPUL | <del>_</del> | | | | FLOAT | Conversion from integer to floating-point | _ | | | | FMAC | Floating-point multiply and accumulate operation | _ | | | | FMOV | Floating-point data transfer | _ | | | | FMUL | Floating-point multiplication | _ | | | | FNEG | Floating-point sign inversion | _ | | Classification | Types | Operation<br>Code | Function | No. of<br>Instructions | |---------------------|-------|-------------------|----------------------------------------------------|------------------------| | Floating-point | 19 | FSCHG | SZ bit inversion | 48 | | instructions | | FSQRT | Floating-point square root | = | | | | FSTS | Floating-point store from system register FPUL | _ | | | | FSUB | Floating-point subtraction | - | | | | FTRC | Floating-point conversion with rounding to integer | - | | FPU-related | 2 | LDS | Load into floating-point system register | 8 | | CPU<br>instructions | | STS | Store from floating-point system register | - | | Bit | 10 | BAND | Bit AND | 14 | | manipulation | | BCLR | Bit clear | - | | | | BLD | Bit load | - | | | | BOR | Bit OR | - | | | | BSET | Bit set | <u></u> | | | | BST | Bit store | <u></u> | | | | BXOR | Bit exclusive OR | - | | | | BANDNOT | Bit NOT AND | - | | | | BORNOT | Bit NOT OR | _ | | | | BLDNOT | Bit NOT load | <del>-</del> | | Total: | 112 | | | 253 | The table below shows the format of instruction codes, operation, and execution states. They are described by using this format according to their classification. | Instruction Instru | ction Code | Operation | Execution States | T Bit | |-----------------------------------------|------------------------------------|----------------------------------------------------------------|-------------------------------------------|-----------------------------------------------| | Indicated by mnemonic. Indicate LSB ord | d in MSB $\leftrightarrow$<br>ler. | Indicates summary of operation. | Value when no wait states are inserted.*1 | Value of T bit after instruction is executed. | | [Legend] [Legend | 1] | [Legend] | | Explanation of<br>Symbols | | Rm: Source register mmmm: | : Source register | $\rightarrow$ , $\leftarrow$ : Transfer direction | | —: No change | | • | estination register | (xx): Memory operand | | | | imm: Immediate data 0000: 0001: | | M/Q/T: Flag bits in SR | | | | disp: Displacement*2 | D.1- | &: Logical AND of each bit | | | | 1111: | | l: Logical OR of each bit | | | | | | ^: Exclusive logical OR of each bit | | | | | | ~: Logical NOT of each bit | | | | | | < <n: left="" n-bit="" shift<="" td=""><td></td><td></td></n:> | | | | | | >>n: n-bit right shift | | | - Notes: 1. Instruction execution cycles: The execution cycles shown in the table are minimums. In practice, the number of instruction execution states will be increased in cases such as the following: - a. When there is a conflict between an instruction fetch and a data access - b. When the destination register of a load instruction (memory $\rightarrow$ register) is the same as the register used by the next instruction. - Depending on the operand size, displacement is scaled by ×1, ×2, or ×4. For details, refer to the SH-2A, SH2A-FPU Software Manual. # 2.4.2 Data Transfer Instructions **Table 2.11 Data Transfer Instructions** | Instruction | | | | | | Com | | mpatibility | | |-------------|---------------|------------------|-----------------------------------------------------------------------------|--------|-------|------|-----|-------------|--| | Instruction | | | | tion | | SH2, | | | | | | | Instruction Code | Operation | Cycles | T Bit | SH2E | SH4 | SH-2A | | | MOV # | timm,Rn | 1110nnnniiiiiiii | $imm \to sign \; extension \to Rn$ | 1 | | Yes | Yes | Yes | | | MOV.W @ | @(disp,PC),Rn | 1001nnnndddddddd | $(disp \times 2 + PC) \rightarrow sign$<br>extension $\rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV.L @ | @(disp,PC),Rn | 1101nnnndddddddd | $(disp \times 4 + PC) \to Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV R | Rm,Rn | 0110nnnnmmmm0011 | $Rm \to Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV.B R | Rm,@Rn | 0010nnnnmmmm0000 | $Rm \rightarrow (Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.W R | Rm,@Rn | 0010nnnnmmmm0001 | $Rm \rightarrow (Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.L R | Rm,@Rn | 0010nnnnmmmm0010 | $Rm \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.B | @Rm,Rn | 0110nnnnmmmm0000 | $(Rm) \to sign\ extension \to Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV.W | @Rm,Rn | 0110nnnnmmmm0001 | $(Rm) \to sign\ extension \to Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV.L @ | @Rm,Rn | 0110nnnnmmmm0010 | $(Rm) \to Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV.B R | Rm,@-Rn | 0010nnnnmmmm0100 | $Rn\text{-}1 \to Rn,Rm \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.W R | Rm,@-Rn | 0010nnnnmmmm0101 | $Rn-2 \rightarrow Rn, Rm \rightarrow (Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.L R | Rm,@-Rn | 0010nnnnmmmm0110 | $Rn-4 \rightarrow Rn, Rm \rightarrow (Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.B | @Rm+,Rn | 0110nnnnmmm0100 | $(Rm) \rightarrow sign \ extension \rightarrow Rn,$ $Rm + 1 \rightarrow Rm$ | 1 | _ | Yes | Yes | Yes | | | MOV.W @ | @Rm+,Rn | 0110nnnnmmm0101 | $(Rm) \rightarrow sign \ extension \rightarrow Rn,$ $Rm + 2 \rightarrow Rm$ | 1 | _ | Yes | Yes | Yes | | | MOV.L @ | @Rm+,Rn | 0110nnnnmmmm0110 | $(Rm) \rightarrow Rn, Rm + 4 \rightarrow Rm$ | 1 | _ | Yes | Yes | Yes | | | MOV.B R | R0,@(disp,Rn) | 10000000nnnndddd | $R0 \rightarrow (disp + Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.W R | R0,@(disp,Rn) | 10000001nnnndddd | $R0 \rightarrow (disp \times 2 + Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.L R | Rm,@(disp,Rn) | 0001nnnnmmmmdddd | $Rm \rightarrow (disp \times 4 + Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.B @ | @(disp,Rm),R0 | 10000100mmmmdddd | | 1 | _ | Yes | Yes | Yes | | | MOV.W @ | @(disp,Rm),R0 | 10000101mmmmdddd | | 1 | _ | Yes | Yes | Yes | | | MOV.L @ | @(disp,Rm),Rn | 0101nnnnmmmmdddd | $(disp \times 4 + Rm) \to Rn$ | 1 | _ | Yes | Yes | Yes | | | MOV.B R | Rm,@(R0,Rn) | 0000nnnnmmmm0100 | $Rm \rightarrow (R0 + Rn)$ | 1 | _ | Yes | Yes | Yes | | | MOV.W R | Rm,@(R0,Rn) | 0000nnnnmmmm0101 | $Rm \rightarrow (R0 + Rn)$ | 1 | _ | Yes | Yes | Yes | | | | | | | Execu- | | Compatibility | | | |------------|-----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------|-------|---------------|-----|-------| | | | | | tion | | SH2, | | | | Instructio | n | Instruction Code | Operation | Cycles | T Bit | SH2E | SH4 | SH-2A | | MOV.L | Rm,@(R0,Rn) | 0000nnnnmmm0110 | $Rm \rightarrow (R0 + Rn)$ | 1 | _ | Yes | Yes | Yes | | MOV.B | @ (R0,Rm),Rn | 0000nnnnmmm1100 | $\begin{array}{l} (R0 + Rm) \rightarrow \\ \text{sign extension} \rightarrow Rn \end{array}$ | 1 | _ | Yes | Yes | Yes | | MOV.W | @ (R0,Rm),Rn | 0000nnnnmmm1101 | $(R0 + Rm) \rightarrow$<br>sign extension $\rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | MOV.L | @(R0,Rm),Rn | 0000nnnnmmmm1110 | $(R0 + Rm) \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | MOV.B | R0,@(disp,GBR) | 11000000dddddddd | $R0 \rightarrow (disp + GBR)$ | 1 | _ | Yes | Yes | Yes | | MOV.W | R0,@(disp,GBR) | 11000001dddddddd | $R0 \to (disp \times 2 + GBR)$ | 1 | _ | Yes | Yes | Yes | | MOV.L | R0,@(disp,GBR) | 11000010ddddddd | $R0 \rightarrow (disp \times 4 + GBR)$ | 1 | _ | Yes | Yes | Yes | | MOV.B | @(disp,GBR),R0 | 11000100dddddddd | | 1 | _ | Yes | Yes | Yes | | MOV.W | @(disp,GBR),R0 | 11000101dddddddd | $ (\text{disp} \times 2 + \text{GBR}) \rightarrow \\ \text{sign extension} \rightarrow \text{R0} $ | 1 | _ | Yes | Yes | Yes | | MOV.L | @(disp,GBR),R0 | 11000110dddddddd | $(disp \times 4 + GBR) \to R0$ | 1 | _ | Yes | Yes | Yes | | MOV.B | R0,@Rn+ | 0100nnnn10001011 | $R0 \rightarrow (Rn), Rn+1 \rightarrow Rn$ | 1 | _ | | | Yes | | MOV.W | R0,@Rn+ | 0100nnnn10011011 | $R0 \rightarrow (Rn), Rn + 2 \rightarrow Rn$ | 1 | _ | | | Yes | | MOV.L | R0,@Rn+ | 0100nnnn10101011 | $R0 \rightarrow Rn), Rn + 4 \rightarrow Rn$ | 1 | _ | | | Yes | | MOV.B | @-Rm,R0 | 0100mmmm11001011 | $\begin{array}{c} \text{Rm-1} \rightarrow \text{Rm, (Rm)} \rightarrow \\ \text{sign extension} \rightarrow \text{R0} \end{array}$ | 1 | _ | | | Yes | | MOV.W | @-Rm,R0 | 0100mmm11011011 | $\begin{array}{c} \text{Rm-2} \rightarrow \text{Rm, (Rm)} \rightarrow \\ \text{sign extension} \rightarrow \text{R0} \end{array}$ | 1 | _ | | | Yes | | MOV.L | @-Rm,R0 | 0100mmmm11101011 | $Rm\text{-}4 \to Rm, (Rm) \to R0$ | 1 | _ | | | Yes | | MOV.B | Rm,@(disp12,Rn) | 0011nnnnmmmm0001 | $Rm \rightarrow (disp + Rn)$ | 1 | _ | | | Yes | | | | 0000dddddddddddd | | | | | | | | MOV.W | Rm,@(disp12,Rn) | 0011nnnnmmmm0001 | $Rm \to (disp \times 2 + Rn)$ | 1 | _ | | | Yes | | | | 0001dddddddddddd | | | | | | | | MOV.L | Rm,@(disp12,Rn) | 0011nnnnmmmm0001 | $Rm \to (disp \times 4 + Rn)$ | 1 | _ | | | Yes | | | | 0010dddddddddddd | | | | | | | | MOV.B | @(disp12,Rm),Rn | 0011nnnnmmmm0001 | (disp + Rm) → | 1 | _ | | - | Yes | | | | 0100dddddddddddd | $sign\;extension\toRn$ | | | | | | | MOV.W | @(disp12,Rm),Rn | 0011nnnnmmmm0001 | $(disp \times 2 + Rm) \rightarrow$ | 1 | | | - | Yes | | | | 0101dddddddddddd | sign extension $\rightarrow$ Rn | | | | | | | | | | | Execu- | | Co | ompatil | oility | |-------------|-----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|--------------|---------|--------| | Instruction | n | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | MOV.L | @(disp12,Rm),Rn | 0011nnnnmmmm0001 | $(disp \times 4 + Rm) \to Rn$ | 1 | _ | | | Yes | | | | 0110dddddddddddd | | | | | | | | MOVA | @(disp,PC),R0 | 11000111dddddddd | $disp \times 4 + PC \to R0$ | 1 | _ | Yes | Yes | Yes | | MOVI20 | #imm20,Rn | 0000nnnniiii0000 | $imm \to sign \; extension \to Rn$ | 1 | _ | | | Yes | | | | iiiiiiiiiiiiiiiiiii | | | | | | | | MOVI20S | #imm20,Rn | 0000nnnniiii0001 | imm << 8 → sign extension | 1 | _ | | | Yes | | | | iiiiiiiiiiiiiiiiiiii | $\rightarrow$ Rn | | | | | | | MOVML.L | Rm,@-R15 | 0100mmm11110001 | $R15\text{-}4 \rightarrow R15, Rm \rightarrow (R15)$ $R15\text{-}4 \rightarrow R15, Rm\text{-}1 \rightarrow (R15)$ $\vdots$ | 1 to 16 | _ | | | Yes | | | | | $R15-4 \rightarrow R15, R0 \rightarrow (R15)$ | | | | | | | | | | Note: When Rm = R15, read<br>Rm as PR | | | | | | | MOVML.L | @R15+,Rn | 0100nnnn11110101 | $(R15) \rightarrow R0, R15 + 4 \rightarrow R15$<br>$(R15) \rightarrow R1, R15 + 4 \rightarrow R15$<br>: | 1 to 16 | _ | | | Yes | | | | | $(R15) \rightarrow Rn$ | | | | | | | | | | Note: When Rn = R15, read<br>Rn as PR | | | | | | | MOVMU.L | Rm,@-R15 | 0100mmmm11110000 | R15-4 $\rightarrow$ R15, PR $\rightarrow$ (R15)<br>R15-4 $\rightarrow$ R15, R14 $\rightarrow$ (R15)<br>:<br>R15-4 $\rightarrow$ R15, Rm $\rightarrow$ (R15) | 1 to 16 | _ | | | Yes | | | | | Note: When Rm = R15, read<br>Rm as PR | | | | | | | MOVMU.L | @R15+,Rn | 0100nnnn11110100 | $(R15) \rightarrow Rn, R15 + 4 \rightarrow R15$<br>$(R15) \rightarrow Rn + 1, R15 + 4 \rightarrow$<br>R15<br>: | 1 to 16 | _ | | | Yes | | | | | $(R15) \rightarrow R14, R15 + 4 \rightarrow R15$ | | | | | | | | | | $(R15) \rightarrow PR$ | | | | | | | | | | Note: When Rn = R15, read<br>Rn as PR | | | | | | | MOVRT | Rn | 0000nnnn00111001 | $\sim$ T → Rn | 1 | _ | • | | Yes | | MOVT | Rn | 0000nnnn00101001 | $T \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | | | | | Execu- | | Co | oility | | |------------|-----------------|------------------|----------------------------------------------|----------------|------------------|--------------|--------|-------| | Instructio | n | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | MOVU.B | @(disp12,Rm),Rn | 0011nnnnmmmm0001 | $(disp + Rm) \to$ | 1 | _ | | | Yes | | | | 1000dddddddddddd | zero extension $\rightarrow$ Rn | | | | | | | MOVU.W | @(disp12,Rm),Rn | 0011nnnnmmmm0001 | $(disp \times 2 + Rm) \to$ | 1 | _ | | | Yes | | | | 1001dddddddddddd | zero extension $\rightarrow$ Rn | | | | | | | NOTT | | 000000001101000 | $\sim$ T $\rightarrow$ T | 1 | Ope- | | | Yes | | | | | | | ration<br>result | | | | | PREF | @Rn | 0000nnnn10000011 | $(Rn) \to operand\; cache$ | 1 | _ | | Yes | Yes | | SWAP.B | Rm,Rn | 0110nnnnmmmm1000 | · · · · · · · · · · · · · · · · · · · | 1 | _ | Yes | Yes | Yes | | | | | Rn | | | | | | | SWAP.W | Rm,Rn | 0110nnnnmmm1001 | $Rm \to swap$ upper and lower words $\to Rn$ | 1 | _ | Yes | Yes | Yes | | XTRCT | Rm,Rn | 0010nnnnmmm1101 | Middle 32 bits of Rm:Rn $\rightarrow$ Rn | 1 | | Yes | Yes | Yes | # 2.4.3 Arithmetic Operation Instructions **Table 2.12 Arithmetic Operation Instructions** | | | | | Execu- | | Co | mpatil | oility | |-------------|---------|------------------|----------------------------------------------------------------------------------|----------------|---------------------------|--------------|--------|--------| | Instruction | า | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | ADD | Rm,Rn | 0011nnnnmmmm1100 | $Rn + Rm \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | ADD | #imm,Rn | 0111nnnniiiiiiii | $Rn + imm \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | ADDC | Rm,Rn | 0011nnnnmmmm1110 | $Rn + Rm + T \rightarrow Rn, carry \rightarrow T$ | 1 | Carry | Yes | Yes | Yes | | ADDV | Rm,Rn | 0011nnnnmmmm1111 | $Rn + Rm \rightarrow Rn, overflow \rightarrow T$ | 1 | Over-<br>flow | Yes | Yes | Yes | | CMP/EQ | #imm,R0 | 10001000iiiiiiii | When R0 = imm, $1 \rightarrow T$<br>Otherwise, $0 \rightarrow T$ | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/EQ | Rm,Rn | 0011nnnnmmmm0000 | When Rn = Rm, 1 $\rightarrow$ T Otherwise, 0 $\rightarrow$ T | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/HS | Rm,Rn | 0011nnnnmmmm0010 | When Rn $\geq$ Rm (unsigned), $1 \rightarrow T$ Otherwise, $0 \rightarrow T$ | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/GE | Rm,Rn | 0011nnnnmmmm0011 | When Rn $\geq$ Rm (signed),<br>1 $\rightarrow$ T<br>Otherwise, 0 $\rightarrow$ T | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/HI | Rm,Rn | 0011nnnnmmmm0110 | When Rn > Rm (unsigned), $1 \to T$ Otherwise, $0 \to T$ | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/GT | Rm,Rn | 0011nnnnmmm0111 | When Rn > Rm (signed), $1 \to T$ Otherwise, $0 \to T$ | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/PL | Rn | 0100nnnn00010101 | When Rn > 0, 1 $\rightarrow$ T Otherwise, 0 $\rightarrow$ T | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/PZ | Rn | 0100nnnn00010001 | When Rn $\geq$ 0, 1 $\rightarrow$ T Otherwise, 0 $\rightarrow$ T | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | CMP/STR | Rm,Rn | 0010nnnnmmm1100 | When any bytes are equal, $1 \to T$ Otherwise, $0 \to T$ | 1 | Com-<br>parison<br>result | Yes | Yes | Yes | | | | | | Execu- | | Co | mpatil | bility | |------------|-------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------|--------------|--------|--------| | Instructio | n | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | CLIPS.B | Rn | 0100nnnn10010001 | When Rn > (H'0000007F), (H'0000007F) $\rightarrow$ Rn, 1 $\rightarrow$ CS when Rn < (H'FFFFF80), (H'FFFFF80) $\rightarrow$ Rn, 1 $\rightarrow$ CS | 1 | _ | | | Yes | | CLIPS.W | Rn | 0100nnnn10010101 | When Rn > (H'00007FFF), (H'00007FFF) $\rightarrow$ Rn, 1 $\rightarrow$ CS When Rn < (H'FFFF8000), (H'FFFF8000) $\rightarrow$ Rn, 1 $\rightarrow$ CS | 1 | _ | | | Yes | | CLIPU.B | Rn | 0100nnnn10000001 | When Rn > (H'000000FF), $ (\text{H'000000FF}) \rightarrow \text{Rn, 1} \rightarrow \text{CS} $ | 1 | _ | | | Yes | | CLIPU.W | Rn | 0100nnnn10000101 | When Rn > (H'0000FFFF), $ (\text{H'0000FFFF}) \rightarrow \text{Rn, 1} \rightarrow \text{CS} $ | 1 | _ | | | Yes | | DIV1 | Rm,Rn | 0011nnnnmmmm0100 | 1-step division (Rn + Rm) | 1 | Calcu-<br>lation<br>result | Yes | Yes | Yes | | DIVOS | Rm,Rn | 0010nnnnmmmm0111 | $\label{eq:msb} \begin{split} \text{MSB of Rn} &\to Q, \\ \text{MSB of Rm} &\to M, M \wedge Q \to T \end{split}$ | 1 | Calcu-<br>lation<br>result | Yes | Yes | Yes | | DIV0U | | 000000000011001 | $0 \rightarrow M/Q/T$ | 1 | 0 | Yes | Yes | Yes | | DIVS | R0,Rn | 0100nnnn10010100 | Signed operation of Rn $\div$ R0 $\rightarrow$ Rn 32 $\div$ 32 $\rightarrow$ 32 bits | 36 | _ | | | Yes | | DIVU | R0,Rn | 0100nnnn10000100 | Unsigned operation of Rn $\div$ R0 $\rightarrow$ Rn 32 $\div$ 32 $\rightarrow$ 32 bits | 34 | _ | | | Yes | | DMULS.L | Rm,Rn | 0011nnnnmmmm1101 | Signed operation of Rn $\times$ Rm $\rightarrow$ MACH, MACL $32 \times 32 \rightarrow 64$ bits | 2 | _ | Yes | Yes | Yes | | DMULU.L | Rm,Rn | 0011nnnnmmmm0101 | Unsigned operation of Rn $\times$ Rm $\rightarrow$ MACH, MACL $32 \times 32 \rightarrow 64$ bits | 2 | _ | Yes | Yes | Yes | | DT | Rn | 0100nnnn00010000 | $Rn - 1 \rightarrow Rn$ When Rn is 0, 1 $\rightarrow$ T When Rn is not 0, 0 $\rightarrow$ T | 1 | Compa-<br>rison<br>result | Yes | Yes | Yes | | EXTS.B | Rm,Rn | 0110nnnnmmm1110 | Byte in Rm is $sign\text{-}extended \rightarrow Rn$ | 1 | | Yes | Yes | Yes | | EXTS.W | Rm,Rn | 0110nnnnmmm1111 | Word in Rm is $sign\text{-extended} \to Rn$ | 1 | _ | Yes | Yes | Yes | | | | | | Execu- | | Co | mpati | bility | |------------|-----------|------------------|----------------------------------------------------------------------------------------------------------|----------------|---------------|--------------|-------|--------| | Instructio | n | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | EXTU.B | Rm,Rn | 0110nnnnmmm1100 | Byte in Rm is $zero\text{-}extended \to Rn$ | 1 | _ | Yes | Yes | Yes | | EXTU.W | Rm,Rn | 0110nnnnmmm1101 | Word in Rm is $zero\text{-}extended \to Rn$ | 1 | _ | Yes | Yes | Yes | | MAC.L | @Rm+,@Rn+ | 0000nnnnmmmm1111 | Signed operation of (Rn) $\times$ (Rm) + MAC $\rightarrow$ MAC $32 \times 32 + 64 \rightarrow 64$ bits | 4 | _ | Yes | Yes | Yes | | MAC.W | @Rm+,@Rn+ | 0100nnnnmmmm1111 | Signed operation of (Rn) $\times$ (Rm) + MAC $\rightarrow$ MAC 16 $\times$ 16 + 64 $\rightarrow$ 64 bits | 3 | | Yes | Yes | Yes | | MUL.L | Rm,Rn | 0000nnnnmmm0111 | $Rn \times Rm \rightarrow MACL$ $32 \times 32 \rightarrow 32 \text{ bits}$ | 2 | _ | Yes | Yes | Yes | | MULR | R0,Rn | 0100nnnn10000000 | $R0 \times Rn \rightarrow Rn$<br>$32 \times 32 \rightarrow 32 \text{ bits}$ | 2 | | | | Yes | | MULS.W | Rm,Rn | 0010nnnnmmmm1111 | Signed operation of Rn $\times$ Rm $\rightarrow$ MACL $16 \times 16 \rightarrow 32$ bits | 1 | _ | Yes | Yes | Yes | | MULU.W | Rm,Rn | 0010nnnnmmmm1110 | Unsigned operation of Rn $\times$ Rm $\rightarrow$ MACL 16 $\times$ 16 $\rightarrow$ 32 bits | 1 | _ | Yes | Yes | Yes | | NEG | Rm,Rn | 0110nnnnmmmm1011 | $0\text{-Rm} \to \text{Rn}$ | 1 | _ | Yes | Yes | Yes | | NEGC | Rm,Rn | 0110nnnnmmmm1010 | $0\text{-Rm-T} \to Rn, borrow \to T$ | 1 | Borrow | Yes | Yes | Yes | | SUB | Rm,Rn | 0011nnnnmmmm1000 | $Rn\text{-}Rm\toRn$ | 1 | _ | Yes | Yes | Yes | | SUBC | Rm,Rn | 0011nnnnmmmm1010 | $Rn\text{-}Rm\text{-}T \to Rn,borrow \to T$ | 1 | Borrow | Yes | Yes | Yes | | SUBV | Rm,Rn | 0011nnnnmmm1011 | $Rn\text{-}Rm \to Rn, underflow \to T$ | 1 | Over-<br>flow | Yes | Yes | Yes | # 2.4.4 Logic Operation Instructions **Table 2.13 Logic Operation Instructions** | | | | | Execu- | | Co | mpatib | oility | |-------------|----------------|------------------|----------------------------------------------------------------------------------------------------|----------------|----------------|--------------|--------|--------| | Instruction | on | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | AND | Rm,Rn | 0010nnnnmmmm1001 | $Rn \; \& \; Rm \to Rn$ | 1 | _ | Yes | Yes | Yes | | AND | #imm,R0 | 11001001iiiiiiii | R0 & imm $\rightarrow$ R0 | 1 | _ | Yes | Yes | Yes | | AND.B | #imm,@(R0,GBR) | 11001101iiiiiiii | (R0 + GBR) & imm $\rightarrow$ (R0 + GBR) | 3 | _ | Yes | Yes | Yes | | NOT | Rm,Rn | 0110nnnnmmmm0111 | $\sim$ Rm → Rn | 1 | _ | Yes | Yes | Yes | | OR | Rm,Rn | 0010nnnnmmmm1011 | $Rn \mid Rm \to Rn$ | 1 | _ | Yes | Yes | Yes | | OR | #imm,R0 | 11001011iiiiiiii | R0 imm $\rightarrow$ R0 | 1 | _ | Yes | Yes | Yes | | OR.B | #imm,@(R0,GBR) | 110011111iiiiiii | $(R0 + GBR) \mid imm \rightarrow$<br>(R0 + GBR) | 3 | _ | Yes | Yes | Yes | | TAS.B | @Rn | 0100nnnn00011011 | When (Rn) is 0, 1 $\rightarrow$ T Otherwise, 0 $\rightarrow$ T, 1 $\rightarrow$ MSB of(Rn) | 3 | Test<br>result | Yes | Yes | Yes | | TST | Rm,Rn | 0010nnnnmmmm1000 | Rn & Rm $\label{eq:continuous} When the result is 0, 1 \rightarrow T$ $Otherwise, 0 \rightarrow T$ | 1 | Test<br>result | Yes | Yes | Yes | | TST | #imm,R0 | 11001000iiiiiiii | R0 & imm<br>When the result is 0, 1 $\rightarrow$ T<br>Otherwise, 0 $\rightarrow$ T | 1 | Test<br>result | Yes | Yes | Yes | | TST.B | #imm,@(R0,GBR) | 11001100iiiiiiii | (R0 + GBR) & imm When the result is 0, 1 $\rightarrow$ T Otherwise, 0 $\rightarrow$ T | 3 | Test<br>result | Yes | Yes | Yes | | XOR | Rm,Rn | 0010nnnnmmmm1010 | $Rn \wedge Rm \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | XOR | #imm,R0 | 11001010iiiiiiii | R0 ^ imm $\rightarrow$ R0 | 1 | _ | Yes | Yes | Yes | | XOR.B | #imm,@(R0,GBR) | 11001110iiiiiiii | $(R0 + GBR) \land imm \rightarrow$<br>(R0 + GBR) | 3 | _ | Yes | Yes | Yes | ## 2.4.5 Shift Instructions **Table 2.14 Shift Instructions** | | | | | Execu- | | Co | ompatik | oility | |-------------|-------|------------------|----------------------------------------------------------------------------------------------------------------|----------------|-------|--------------|---------|--------| | Instruction | n | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | ROTL | Rn | 0100nnnn00000100 | $T \leftarrow Rn \leftarrow MSB$ | 1 | MSB | Yes | Yes | Yes | | ROTR | Rn | 0100nnnn00000101 | $LSB \to Rn \to T$ | 1 | LSB | Yes | Yes | Yes | | ROTCL | Rn | 0100nnnn00100100 | $T \leftarrow Rn \leftarrow T$ | 1 | MSB | Yes | Yes | Yes | | ROTCR | Rn | 0100nnnn00100101 | $T \to Rn \to T$ | 1 | LSB | Yes | Yes | Yes | | SHAD | Rm,Rn | 0100nnnnmmmm1100 | When Rm $\geq$ 0, Rn $<<$ Rm $\rightarrow$ Rn When Rm $<$ 0, Rn $>>$ IRml $\rightarrow$ [MSB $\rightarrow$ Rn] | 1 | _ | | Yes | Yes | | SHAL | Rn | 0100nnnn00100000 | $T \leftarrow Rn \leftarrow 0$ | 1 | MSB | Yes | Yes | Yes | | SHAR | Rn | 0100nnnn00100001 | $MSB \to Rn \to T$ | 1 | LSB | Yes | Yes | Yes | | SHLD | Rm,Rn | 0100nnnnmmmm1101 | When Rm $\geq$ 0, Rn $<<$ Rm $\rightarrow$ Rn When Rm $<$ 0, Rn $>>$ IRmI $\rightarrow$ [0 $\rightarrow$ Rn] | 1 | _ | | Yes | Yes | | SHLL | Rn | 0100nnnn00000000 | $T \leftarrow Rn \leftarrow 0$ | 1 | MSB | Yes | Yes | Yes | | SHLR | Rn | 0100nnnn00000001 | $0 \to Rn \to T$ | 1 | LSB | Yes | Yes | Yes | | SHLL2 | Rn | 0100nnnn00001000 | $Rn \ll 2 \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | SHLR2 | Rn | 0100nnnn00001001 | $Rn >> 2 \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | SHLL8 | Rn | 0100nnnn00011000 | $Rn \ll 8 \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | SHLR8 | Rn | 0100nnnn00011001 | $Rn >> 8 \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | SHLL16 | Rn | 0100nnnn00101000 | $Rn \ll 16 \rightarrow Rn$ | 1 | _ | Yes | Yes | Yes | | SHLR16 | Rn | 0100nnnn00101001 | Rn >> 16 → Rn | 1 | _ | Yes | Yes | Yes | ## 2.4.6 Branch Instructions **Table 2.15 Branch Instructions** | | | | | Execu- | | Co | ompatil | oility | |-------------|-----------------|-------------------|-----------------------------------------------------------------------------------|--------|-------|------|---------|--------| | | | | | tion | | SH2, | | | | Instruction | on | Instruction Code | Operation | Cycles | T Bit | SH2E | SH4 | SH-2A | | BF | label | 10001011dddddddd | When T = 0, disp $\times$ 2 + PC $\rightarrow$ PC, When T = 1, nop | 3/1* | _ | Yes | Yes | Yes | | BF/S | label | 100011111dddddddd | Delayed branch When T = 0, disp $\times$ 2 + PC $\rightarrow$ PC, When T = 1, nop | 2/1* | _ | Yes | Yes | Yes | | ВТ | label | 10001001dddddddd | When T = 1, disp $\times$ 2 + PC $\rightarrow$ PC, When T = 0, nop | 3/1* | _ | Yes | Yes | Yes | | BT/S | label | 10001101dddddddd | Delayed branch When T = 1, disp $\times$ 2 + PC $\rightarrow$ PC, When T = 0, nop | 2/1* | | Yes | Yes | Yes | | BRA | label | 1010dddddddddddd | Delayed branch, $disp \times 2 + PC \to PC$ | 2 | _ | Yes | Yes | Yes | | BRAF | Rm | 0000mmmm00100011 | Delayed branch, $Rm + PC \to PC$ | 2 | _ | Yes | Yes | Yes | | BSR | label | 1011dddddddddddd | Delayed branch, PC $\rightarrow$ PR, disp $\times$ 2 + PC $\rightarrow$ PC | 2 | _ | Yes | Yes | Yes | | BSRF | Rm | 0000mmmm00000011 | Delayed branch, $PC \rightarrow PR$ , $Rm + PC \rightarrow PC$ | 2 | _ | Yes | Yes | Yes | | JMP | @Rm | 0100mmmm00101011 | Delayed branch, $Rm \rightarrow PC$ | 2 | _ | Yes | Yes | Yes | | JSR | @Rm | 0100mmmm00001011 | Delayed branch, $PC \rightarrow PR$ , $Rm \rightarrow PC$ | 2 | _ | Yes | Yes | Yes | | JSR/N | @Rm | 0100mmmm01001011 | $\text{PC-2} \rightarrow \text{PR}, \text{Rm} \rightarrow \text{PC}$ | 3 | _ | | | Yes | | JSR/N | @ @ (disp8,TBR) | 10000011dddddddd | $PC-2 \rightarrow PR$ , $(disp \times 4 + TBR) \rightarrow PC$ | 5 | _ | | | Yes | | RTS | | 0000000000001011 | Delayed branch, $PR \rightarrow PC$ | 2 | _ | Yes | Yes | Yes | | RTS/N | | 000000001101011 | $PR \rightarrow PC$ | 3 | _ | | | Yes | | RTV/N | Rm | 0000mmmm01111011 | $Rm \to R0, PR \to PC$ | 3 | _ | | | Yes | | | | | | | | | | | Note: \* One cycle when the program does not branch. # 2.4.7 System Control Instructions **Table 2.16 System Control Instructions** | | | | | Execu- | | Co | mpatib | oility | |------------|-----------|------------------|----------------------------------------------------------------------------------------------------------|--------|-------|------|--------|--------| | | | | | tion | | SH2, | | | | Instructio | n | Instruction Code | Operation | Cycles | T Bit | SH2E | SH4 | SH-2A | | CLRT | | 000000000001000 | $0 \rightarrow T$ | 1 | 0 | Yes | Yes | Yes | | CLRMAC | | 000000000101000 | $0 \to MACH, MACL$ | 1 | _ | Yes | Yes | Yes | | LDBANK | @Rm,R0 | 0100mmmm11100101 | (Specified register bank entry) $\rightarrow R0$ | 6 | _ | | | Yes | | LDC | Rm,SR | 0100mmmm00001110 | $Rm \to SR$ | 3 | LSB | Yes | Yes | Yes | | LDC | Rm,TBR | 0100mmmm01001010 | $Rm \to TBR$ | 1 | _ | | | Yes | | LDC | Rm,GBR | 0100mmmm00011110 | $Rm \to GBR$ | 1 | _ | Yes | Yes | Yes | | LDC | Rm,VBR | 0100mmmm00101110 | $Rm \to VBR$ | 1 | _ | Yes | Yes | Yes | | LDC.L | @Rm+,SR | 0100mmmm00000111 | $(Rm) \rightarrow SR, Rm + 4 \rightarrow Rm$ | 5 | LSB | Yes | Yes | Yes | | LDC.L | @Rm+,GBR | 0100mmmm00010111 | $(Rm) \rightarrow GBR, Rm + 4 \rightarrow Rm$ | 1 | _ | Yes | Yes | Yes | | LDC.L | @Rm+,VBR | 0100mmmm00100111 | $(Rm) \rightarrow VBR, Rm + 4 \rightarrow Rm$ | 1 | _ | Yes | Yes | Yes | | LDS | Rm,MACH | 0100mmmm00001010 | Rm o MACH | 1 | | Yes | Yes | Yes | | LDS | Rm,MACL | 0100mmmm00011010 | Rm o MACL | 1 | _ | Yes | Yes | Yes | | LDS | Rm,PR | 0100mmmm00101010 | $Rm \to PR$ | 1 | _ | Yes | Yes | Yes | | LDS.L | @Rm+,MACH | 0100mmmm00000110 | $(Rm) \rightarrow MACH, Rm + 4 \rightarrow Rm$ | 1 | | Yes | Yes | Yes | | LDS.L | @Rm+,MACL | 0100mmmm00010110 | $(Rm) \to MACL, \ Rm + 4 \to Rm$ | 1 | _ | Yes | Yes | Yes | | LDS.L | @Rm+,PR | 0100mmmm00100110 | $(Rm) \rightarrow PR, Rm + 4 \rightarrow Rm$ | 1 | _ | Yes | Yes | Yes | | NOP | | 0000000000001001 | No operation | 1 | _ | Yes | Yes | Yes | | RESBANK | ( | 000000001011011 | $\begin{aligned} \text{Bank} &\rightarrow \text{R0 to R14, GBR,} \\ \text{MACH, MACL, PR} \end{aligned}$ | 9* | _ | | | Yes | | RTE | | 000000000101011 | Delayed branch,<br>stack area → PC/SR | 6 | _ | Yes | Yes | Yes | | SETT | | 000000000011000 | $1 \to T$ | 1 | 1 | Yes | Yes | Yes | | SLEEP | | 000000000011011 | Sleep | 5 | _ | Yes | Yes | Yes | | STBANK | R0,@Rn | 0100nnnn11100001 | R0 → (specified register bank entry) | 7 | _ | | | Yes | | STC | SR,Rn | 0000nnnn00000010 | $SR \rightarrow Rn$ | 2 | _ | Yes | Yes | Yes | | STC | TBR,Rn | 0000nnnn01001010 | $TBR \to Rn$ | 1 | _ | | | Yes | | | | | | | | | | | | | | | | Execu- | | Co | ompatik | oility | |-------------|-----------|------------------|---------------------------------------------------------------------|----------------|-------|--------------|---------|--------| | Instruction | on | Instruction Code | Operation | tion<br>Cycles | T Bit | SH2,<br>SH2E | SH4 | SH-2A | | STC | GBR,Rn | 0000nnnn00010010 | $GBR \to Rn$ | 1 | _ | Yes | Yes | Yes | | STC | VBR,Rn | 0000nnnn00100010 | $VBR \to Rn$ | 1 | _ | Yes | Yes | Yes | | STC.L | SR,@-Rn | 0100nnnn00000011 | $Rn-4 \rightarrow Rn, SR \rightarrow (Rn)$ | 2 | _ | Yes | Yes | Yes | | STC.L | GBR,@-Rn | 0100nnnn00010011 | $Rn\text{-}4 \to Rn,GBR \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | STC.L | VBR,@-Rn | 0100nnnn00100011 | $Rn\text{-}4 \to Rn,VBR \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | STS | MACH,Rn | 0000nnnn00001010 | $MACH \to Rn$ | 1 | _ | Yes | Yes | Yes | | STS | MACL,Rn | 0000nnnn00011010 | $MACL \to Rn$ | 1 | _ | Yes | Yes | Yes | | STS | PR,Rn | 0000nnnn00101010 | $PR \to Rn$ | 1 | _ | Yes | Yes | Yes | | STS.L | MACH,@-Rn | 0100nnnn00000010 | $Rn\text{-}4 \to Rn,MACH \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | STS.L | MACL,@-Rn | 0100nnnn00010010 | $Rn\text{-}4 \to Rn,MACL \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | STS.L | PR,@-Rn | 0100nnnn00100010 | $Rn-4 \rightarrow Rn, PR \rightarrow (Rn)$ | 1 | _ | Yes | Yes | Yes | | TRAPA | #imm | 11000011iiiiiiii | $PC/SR \rightarrow stack area,$<br>(imm × 4 + VBR) $\rightarrow PC$ | 5 | _ | Yes | Yes | Yes | Notes: 1. Instruction execution cycles: The execution cycles shown in the table are minimums. In practice, the number of instruction execution states in cases such as the following: - a. When there is a conflict between an instruction fetch and a data access - b. When the destination register of a load instruction (memory $\rightarrow$ register) is the same as the register used by the next instruction. - \* In the event of bank overflow, the number of cycles is 19. # **2.4.8** Floating-Point Operation Instructions **Table 2.17 Floating-Point Operation Instructions** | | | | | | | C | ompatib | ility | |-------------|-------------|------------------|----------------------------------------|--------------------------|---------------------------|------|---------|------------------------| | Instruction | 1 | Instruction Code | Operation | Execu-<br>tion<br>Cycles | | SH2E | SH4 | SH-2A/<br>SH2A-<br>FPU | | FABS | FRn | 1111nnnn01011101 | $ FRn \to FRn$ | 1 | _ | Yes | Yes | Yes | | FABS | DRn | 1111nnn001011101 | $ DRn \to DRn$ | 1 | _ | | Yes | Yes | | FADD | FRm, FRn | 1111nnnnmmmm0000 | $FRn + FRm \rightarrow FRn$ | 1 | _ | Yes | Yes | Yes | | FADD | DRm, DRn | 1111nnn0mmm00000 | $DRn + DRm \to DRn$ | 6 | _ | | Yes | Yes | | FCMP/EQ | FRm, FRn | 1111nnnnmmmm0100 | (FRn = FRm)? $1:0 \rightarrow T$ | 1 | Compa-<br>rison<br>result | Yes | Yes | Yes | | FCMP/EQ | DRm, DRn | 1111nnn0mmm00100 | (DRn = DRm)? 1:0 → T | 2 | Compa-<br>rison<br>result | | Yes | Yes | | FCMP/GT | FRm, FRn | 1111nnnnmmmm0101 | (FRn > FRm)? $1:0 \rightarrow T$ | 1 | Compa<br>-rison<br>result | Yes | Yes | Yes | | FCMP/GT | DRm, DRn | 1111nnn0mmm00101 | (DRn > DRm)? $1:0 \rightarrow T$ | 2 | Compa-<br>rison<br>result | | Yes | Yes | | FCNVDS | DRm, FPUL | 1111mmm010111101 | (float) DRm $\rightarrow$ FPUL | 2 | _ | | Yes | Yes | | FCNVSD | FPUL, DRn | 1111nnn010101101 | (double) $FPUL \to DRn$ | 2 | _ | | Yes | Yes | | FDIV | FRm, FRn | 1111nnnnmmmm0011 | $FRn/FRm \to FRn$ | 10 | _ | Yes | Yes | Yes | | FDIV | DRm, DRn | 1111nnn0mmm00011 | $DRn/DRm \to DRn$ | 23 | _ | | Yes | Yes | | FLDI0 | FRn | 1111nnnn10001101 | $0\times00000000\to FRn$ | 1 | _ | Yes | Yes | Yes | | FLDI1 | FRn | 1111nnnn10011101 | $0\times3F800000\to FRn$ | 1 | _ | Yes | Yes | Yes | | FLDS | FRm, FPUL | 1111mmmm00011101 | $FRm \to FPUL$ | 1 | _ | Yes | Yes | Yes | | FLOAT | FPUL,FRn | 1111nnnn00101101 | $(float)FPUL \to FRn$ | 1 | _ | Yes | Yes | Yes | | FLOAT | FPUL,DRn | 1111nnn000101101 | $(double)FPUL \to DRn$ | 2 | _ | | Yes | Yes | | FMAC | FR0,FRm,FRn | 1111nnnnmmmm1110 | $FR0 \times FRm+FRn \rightarrow$ $FRn$ | 1 | _ | Yes | Yes | Yes | | FMOV | FRm, FRn | 1111nnnnmmmm1100 | $FRm \to FRn$ | 1 | _ | Yes | Yes | Yes | | FMOV | DRm, DRn | 1111nnn0mmm01100 | $DRm \to DRn$ | 2 | _ | | Yes | Yes | | | | | | | | Co | ompatib | ility | |---------------------|------------------|--------------------------------------|-------------------------------------------------------------|--------------------------|-------|------|---------|------------------------| | Instructio | n | Instruction Code | Operation | Execu-<br>tion<br>Cycles | T Bit | SH2E | SH4 | SH-2A/<br>SH2A-<br>FPU | | FMOV.S | @(R0, Rm), FRn | 1111nnnnmmmm0110 | $(R0+Rm)\to FRn$ | 1 | _ | Yes | Yes | Yes | | FMOV.D | @(R0, Rm), DRn | 1111nnn0mmmm0110 | $(R0+Rm)\to DRn$ | 2 | _ | | Yes | Yes | | FMOV.S | @Rm+, FRn | 1111nnnnmmmm1001 | $(Rm) \rightarrow FRn, Rm += 4$ | 1 | _ | Yes | Yes | Yes | | FMOV.D | @Rm+, DRn | 1111nnn0mmmm1001 | $(Rm) \rightarrow DRn, Rm += 8$ | 2 | _ | | Yes | Yes | | FMOV.S | @Rm, FRn | 1111nnnnmmmm1000 | $(Rm) \to FRn$ | 1 | _ | Yes | Yes | Yes | | FMOV.D | @Rm, DRn | 1111nnn0mmmm1000 | $(Rm) \to DRn$ | 2 | _ | | Yes | Yes | | FMOV.S | @(disp12,Rm),FRn | 0011nnnnmmmm0001 | $(disp \times 4 + Rm) \to FRn$ | 1 | _ | | | Yes | | | | 0111dddddddddddd | | | | | | | | FMOV.D | @(disp12,Rm),DRn | 0011nnn0mmmm0001 | $(\text{disp} \times \text{8 + Rm}) \rightarrow \text{DRn}$ | 2 | _ | | | Yes | | | | 0111dddddddddddd | | | | | | | | FMOV.S | FRm, @(R0,Rn) | 1111nnnnmmmm0111 | $FRm \rightarrow (R0 + Rn)$ | 1 | _ | Yes | Yes | Yes | | FMOV.D | DRm, @(R0,Rn) | 1111nnnnmmm00111 | $DRm \to (R0 + Rn)$ | 2 | | | Yes | Yes | | FMOV.S | FRm, @-Rn | 1111nnnnmmmm1011 | $Rn\text{-=}4,FRm\to(Rn)$ | 1 | _ | Yes | Yes | Yes | | FMOV.D | DRm, @-Rn | 1111nnnnmmm01011 | Rn-=8, DRm $\rightarrow$ (Rn) | 2 | _ | | Yes | Yes | | FMOV.S | FRm, @Rn | 1111nnnnmmmm1010 | $FRm \to (Rn)$ | 1 | _ | Yes | Yes | Yes | | FMOV.D | DRm, @Rn | 1111nnnnmmm01010 | $DRm \to (Rn)$ | 2 | _ | | Yes | Yes | | FMOV.S<br>@(disp12, | FRm,<br>Rn) | 0011nnnnmmmm0001<br>0011dddddddddddd | $FRm \to (disp \times 4 + Rn)$ | 1 | _ | | | Yes | | FMOV.D | DRm, | 0011nnnnmmm00001 | $DRm \to (disp \times 8 + Rn)$ | 2 | _ | | | Yes | | @(disp12, | Rn) | 0011dddddddddddd | | | | | | | | FMUL | FRm, FRn | 1111nnnnmmmm0010 | $FRn \times FRm \rightarrow FRn$ | 1 | _ | Yes | Yes | Yes | | FMUL | DRm, DRn | 1111nnn0mmm00010 | $DRn \times DRm \to DRn$ | 6 | _ | | Yes | Yes | | FNEG | FRn | 1111nnnn01001101 | -FRn → FRn | 1 | _ | Yes | Yes | Yes | | FNEG | DRn | 1111nnn001001101 | -DRn → DRn | 1 | _ | | Yes | Yes | | FSCHG | | 11110011111111101 | FPSCR.SZ=~FPSCR.S<br>Z | 1 | _ | | Yes | Yes | | FSQRT | FRn | 1111nnnn01101101 | $\sqrt{FRn} \to FRn$ | 9 | _ | | Yes | Yes | | FSQRT | DRn | 1111nnn001101101 | $\sqrt{DRn} \rightarrow DRn$ | 22 | _ | | Yes | Yes | | FSTS | FPUL,FRn | 1111nnnn00001101 | $FPUL \to FRn$ | 1 | _ | Yes | Yes | Yes | | FSUB | FRm, FRn | 1111nnnnmmmm0001 | $FRn ext{-}FRm \to FRn$ | 1 | | Yes | Yes | Yes | | | | | | | | | | | | | | | | | | Compatibility | | | |-------------|-----------|------------------|------------------------|--------------------------------|---|---------------|-----|------------------------| | Instruction | | Instruction Code | Operation | Execu-<br>tion<br>Cycles T Bit | | SH2E | SH4 | SH-2A/<br>SH2A-<br>FPU | | FSUB | DRm, DRn | 1111nnn0mmm00001 | $DRn\text{-}DRm\toDRn$ | 6 | _ | | Yes | Yes | | FTRC | FRm, FPUL | 1111mmmm00111101 | $(long)FRm \to FPUL$ | 1 | _ | Yes | Yes | Yes | | FTRC | DRm, FPUL | 1111mmm000111101 | $(long)DRm \to FPUL$ | 2 | _ | | Yes | Yes | ## 2.4.9 FPU-Related CPU Instructions **Table 2.18 FPU-Related CPU Instructions** | | | | | | | Co | ompatib | ility | |-------------|-------------|------------------|-----------------------------------|--------------------------|---|------|---------|------------------------| | Instruction | on | Instruction Code | Operation | Execu-<br>tion<br>Cycles | | SH2E | SH4 | SH-2A/<br>SH2A-<br>FPU | | LDS | Rm,FPSCR | 0100mmmm01101010 | $Rm \to FPSCR$ | 1 | _ | Yes | Yes | Yes | | LDS | Rm,FPUL | 0100mmmm01011010 | $Rm \to FPUL$ | 1 | _ | Yes | Yes | Yes | | LDS.L | @Rm+, FPSCR | 0100mmmm01100110 | $(Rm) \rightarrow FPSCR, Rm+=4$ | 1 | _ | Yes | Yes | Yes | | LDS.L | @Rm+, FPUL | 0100mmmm01010110 | $(Rm) \rightarrow FPUL, Rm += 4$ | 1 | _ | Yes | Yes | Yes | | STS | FPSCR, Rn | 0000nnnn01101010 | $FPSCR \to Rn$ | 1 | _ | Yes | Yes | Yes | | STS | FPUL,Rn | 0000nnnn01011010 | $FPUL \to Rn$ | 1 | _ | Yes | Yes | Yes | | STS.L | FPSCR,@-Rn | 0100nnnn01100010 | Rn-=4, FPCSR $\rightarrow$ (Rn) | 1 | _ | Yes | Yes | Yes | | STS.L | FPUL,@-Rn | 0100nnnn01010010 | Rn-=4, FPUL $\rightarrow$ (Rn) | 1 | _ | Yes | Yes | Yes | # 2.4.10 Bit Manipulation Instructions # **Table 2.19 Bit Manipulation Instructions** | | | | | Execu- | | Compatibility | | bility | |-------------|---------------------------|-------------------|--------------------------------------------------|--------|------------------|---------------|-----|--------| | | | | | tion | | SH2, | | | | Instruction | | Instruction Code | Operation | Cycles | T Bit | SH2E | SH4 | SH-2A | | BAND.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | (imm of (disp + Rn)) & T $\rightarrow$ | 3 | Ope- | | | Yes | | | | 0100dddddddddddd | | | ration<br>result | | | | | BANDNOT.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | ~(imm of (disp + Rn)) & T $\rightarrow$ T | 3 | Ope- | | | Yes | | | | 1100dddddddddddd | | | ration<br>result | | | | | BCLR.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | $0 \rightarrow \text{(imm of (disp + Rn))}$ | 3 | _ | | | Yes | | | | 0000dddddddddddd | | | | | | | | BCLR | #imm3,Rn | 10000110nnnn0iii | $0 \to imm \ of \ Rn$ | 1 | _ | | | Yes | | BLD.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | $(imm\;of\;(disp+Rn))\to$ | 3 | Ope- | | | Yes | | | | 0011ddddddddddddd | | | ration<br>result | | | | | BLD | #imm3,Rn | 10000111nnnn1iii | imm of Rn $\rightarrow$ T | 1 | Ope- | | | Yes | | | | | | | ration<br>result | | | | | BLDNOT.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | ~(imm of (disp + Rn)) | 3 | Ope- | | | Yes | | DEDITO1.D | ######O, @ (disp12,1##) | 1011dddddddddddd | $\rightarrow$ T | 3 | ration | | | 163 | | | | TUTTAGAGAGAGAGA | | | result | | | | | BOR.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | ( imm of (disp + Rn)) T $\rightarrow$ T | 3 | Ope- | | | Yes | | | | 0101dddddddddddd | | | ration<br>result | | | | | BORNOT.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | $\sim$ ( imm of (disp + Rn)) T $\rightarrow$ T | 3 | Ope- | | | Yes | | 20111101.2 | #####O, @ (diop 12,1 iii) | 1101dddddddddddd | ( initial catalog + rini)) + 1 × 1 | Ü | ration | | | 100 | | | | TTOTAGAGAGAGAGA | | | result | | | | | BSET.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | $1 \rightarrow \text{( imm of (disp + Rn))}$ | 3 | _ | | | Yes | | | | 0001ddddddddddddd | | | | | | | | BSET | #imm3,Rn | 10000110nnnn1iii | $1 \rightarrow \text{imm of Rn}$ | 1 | | | | Yes | | BST.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | $T \rightarrow \text{(imm of (disp + Rn))}$ | 3 | _ | | | Yes | | | | 0010dddddddddddd | | | | | | | | BST | #imm3,Rn | 10000111nnnn0iii | $T \to imm \; of \; Rn$ | 1 | _ | | | Yes | | | | | | | | | | | | | | | | Execu- | | Con | npatik | oility | |-------------|--------------------|-------------------|----------------------------------------------------|--------|------------------|-----|--------|--------| | Instruction | | Instruction Code | Operation | Cycles | T Bit | - , | SH4 | SH-2A | | BXOR.B | #imm3,@(disp12,Rn) | 0011nnnn0iii1001 | (imm of (disp + Rn)) $^{\wedge}$ T $\rightarrow$ T | 3 | Ope- | | | Yes | | | | 0110ddddddddddddd | | | ration<br>result | | | | # 2.5 Processing States The CPU has five processing states: reset, exception handling, bus-released, program execution, and power-down. Figure 2.6 shows the transitions between the states. Figure 2.6 Transitions between Processing States #### (1) Reset State In the reset state, the CPU is reset. There are two kinds of reset, power-on reset and manual reset. #### (2) Exception Handling State The exception handling state is a transient state that occurs when exception handling sources such as resets or interrupts alter the CPU's processing state flow. For a reset, the initial values of the program counter (PC) (execution start address) and stack pointer (SP) are fetched from the exception handling vector table and stored; the CPU then branches to the execution start address and execution of the program begins. For an interrupt, the stack pointer (SP) is accessed and the program counter (PC) and status register (SR) are saved to the stack area. The exception service routine start address is fetched from the exception handling vector table; the CPU then branches to that address and the program starts executing, thereby entering the program execution state. #### (3) Program Execution State In the program execution state, the CPU sequentially executes the program. #### (4) Power-Down State In the power-down state, the CPU stops operating to reduce power consumption. The SLEEP instruction places the CPU in sleep mode or software standby mode. # (5) Bus-Released State In the bus-released state, the CPU releases bus to a device that has requested it. # Section 3 Floating-Point Unit (FPU) #### 3.1 **Features** The FPU has the following features. - Conforms to IEEE754 standard - 16 single-precision floating-point registers (can also be referenced as eight double-precision registers) - Two rounding modes: Round to nearest and round to zero - Denormalization modes: Flush to zero - Five exception sources: Invalid operation, divide by zero, overflow, underflow, and inexact - Comprehensive instructions: Single-precision, double-precision, and system control #### 3.2 Data Formats #### 3.2.1 Floating-Point Format A floating-point number consists of the following three fields: - Sign (s) - Exponent (e) - Fraction (f) This LSI can handle single-precision and double-precision floating-point numbers, using the formats shown in figures 3.1 and 3.2. Figure 3.1 Format of Single-Precision Floating-Point Number Figure 3.2 Format of Double-Precision Floating-Point Number The exponent is expressed in biased form, as follows: $$e = E + bias$$ The range of unbiased exponent E is $E_{\text{min}}-1$ to $E_{\text{max}}+1$ . The two values $E_{\text{min}}-1$ and $E_{\text{max}}+1$ are distinguished as follows. $E_{\text{min}}-1$ indicates zero (both positive and negative sign) and a denormalized number, and $E_{\text{max}}+1$ indicates positive or negative infinity or a non-number (NaN). Table 3.1 shows $E_{\text{min}}$ and $E_{\text{max}}$ values. **Table 3.1** Floating-Point Number Formats and Parameters | Parameter | Single-Precision | Double-Precision | | |------------------|------------------|------------------|--| | Total bit width | 32 bits | 64 bits | | | Sign bit | 1 bit | 1 bit | | | Exponent field | 8 bits | 11 bits | | | Fraction field | 23 bits | 52 bits | | | Precision | 24 bits | 53 bits | | | Bias | +127 | +1023 | | | E <sub>max</sub> | +127 | +1023 | | | E <sub>min</sub> | -126 | -1022 | | Floating-point number value v is determined as follows: If $E = E_{max} + 1$ and $f \ne 0$ , v is a non-number (NaN) irrespective of sign s If $E = E_{max} + 1$ and f = 0, $v = (-1)^s$ (infinity) [positive or negative infinity] If $E_{min} \le E \le E_{max}$ , $v = (-1)^s 2^E (1.f)$ [normalized number] If $E = E_{min} - 1$ and $f \neq 0$ , $v = (-1)^s 2^{Emin}$ (0.f) [denormalized number] If $E = E_{min} - 1$ and f = 0, $v = (-1)^{s}0$ [positive or negative zero] Table 3.2 shows the ranges of the various numbers in hexadecimal notation. **Table 3.2** Floating-Point Ranges | Туре | Single-Precision | Double-Precision | | | | |------------------------------|----------------------------|---------------------------------------------------|--|--|--| | Signaling non-number | H'7FFF FFFF to H'7FC0 0000 | H'7FFF FFFF FFFF FFFF to<br>H'7FF8 0000 0000 0000 | | | | | Quiet non-number | H'7FBF FFFF to H'7F80 0001 | H'7FF7 FFFF FFFF FFFF to<br>H'7FF0 0000 0000 0001 | | | | | Positive infinity | H'7F80 0000 | H'7FF0 0000 0000 0000 | | | | | Positive normalized number | H'7F7F FFFF to H'0080 0000 | H'7FEF FFFF FFFF FFFF to<br>H'0010 0000 0000 0000 | | | | | Positive denormalized number | H'007F FFFF to H'0000 0001 | H'000F FFFF FFFF FFFF to<br>H'0000 0000 0000 0001 | | | | | Positive zero | H'0000 0000 | H'0000 0000 0000 0000 | | | | | Negative zero | H'8000 0000 | H'8000 0000 0000 0000 | | | | | Negative denormalized number | H'8000 0001 to H'807F FFFF | H'8000 0000 0000 0001 to<br>H'800F FFFF FFFF FFFF | | | | | Negative normalized number | H'8080 0000 to H'FF7F FFFF | H'8010 0000 0000 0000 to<br>H'FFEF FFFF FFFF | | | | | Negative infinity | H'FF80 0000 | H'FFF0 0000 0000 0000 | | | | | Quiet non-number | H'FF80 0001 to H'FFBF FFFF | H'FFF0 0000 0000 0001 to<br>H'FFF7 FFFF FFFF | | | | | Signaling non-number | H'FFC0 0000 to H'FFFF FFFF | H'FFF8 0000 0000 0000 to<br>H'FFFF FFFF FFFF | | | | #### 3.2.2 Non-Numbers (NaN) Figure 3.3 shows the bit pattern of a non-number (NaN). A value is NaN in the following case: • Sign bit: Don't care • Exponent field: All bits are 1 • Fraction field: At least one bit is 1 The NaN is a signaling NaN (sNaN) if the MSB of the fraction field is 1, and a quiet NaN (qNaN) if the MSB is 0. Figure 3.3 Single-Precision NaN Bit Pattern An sNaN is input in an operation, except copy, FABS, and FNEG, that generates a floating-point value. - When the EN.V bit in FPSCR is 0, the operation result (output) is a qNaN. - When the EN.V bit in FPSCR is 1, an invalid operation exception will be generated. In this case, the contents of the operation destination register are unchanged. If a qNaN is input in an operation that generates a floating-point value, and an sNaN has not been input in that operation, the output will always be a qNaN irrespective of the setting of the EN.V bit in FPSCR. An exception will not be generated in this case. The qNAN values as operation results are as follows: • Single-precision qNaN: H'7FBF FFFF Double-precision qNaN: H'7FF7 FFFF FFFF See the individual instruction descriptions for details of floating-point operations when a non-number (NaN) is input. #### 3.2.3 Denormalized Numbers For a denormalized number floating-point value, the exponent field is expressed as 0, and the fraction field as a non-zero value. In the SH2A-FPU, the DN bit in the status register FPSCR is always set to 1, therefore a denormalized number (source operand or operation result) is always flushed to 0 in a floating-point operation that generates a value (an operation other than copy, FNEG, or FABS). When the DN bit in FPSCR is 0, a denormalized number (source operand or operation result) is processed as it is. See the individual instruction descriptions for details of floating-point operations when a denormalized number is input. # 3.3 Register Descriptions #### 3.3.1 Floating-Point Registers Figure 3.4 shows the floating-point register configuration. There are sixteen 32-bit floating-point registers FPR0 to FPR15, referenced by specifying FR0 to FR15, DR0/2/4/6/8/10/12/14. The correspondence between FRPn and the reference name is determined by the PR and SZ bits in FPSCR. Refer figure 3.4. - 1. Floating-point registers, FPRi (16 registers) FPR0 to FPR15 - Single-precision floating-point registers, FRi (16 registers) FR0 to FR15 indicate FPR0 to FPR15 - 3. Double-precision floating-point registers or single-precision floating-point vector registers in pairs, DRi (8 registers) A DR register comprises two FR registers. $$DR0 = \{FR0, FR1\}, DR2 = \{FR2, FR3\}, DR4 = \{FR4, FR5\}, DR6 = \{FR6, FR7\}, DR8 = \{FR8, FR9\}, DR10 = \{FR10, FR11\}, DR12 = \{FR12, FR13\}, DR14 = \{FR14, FR15\}$$ Figure 3.4 Floating-Point Registers # 3.3.2 Floating-Point Status/Control Register (FPSCR) FPSCR is a 32-bit register that controls floating-point instructions, sets FPU exceptions, and selects the rounding mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|--------|-----|-----|-----|-----|------|-----|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | QIS | - | SZ | PR | DN | Cau | use | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R/W | R | R/W | R/W | R | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Ca | use | | | | Enable | | | | | Flag | | | RM1 | RM0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | R/W: | R/W | | | Initial | | | |----------|----------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 23 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 22 | QIS | 0 | R/W | Nonnunerical Processing Mode | | | | | | 0: Processes qNaN or ±∞ as such | | | | | | 1: Treats qNaN or $\pm \infty$ as the same as sNaN (valid only when FPSCR.Enable.V = 1) | | 21 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 20 | SZ | 0 | R/W | Transfer Size Mode | | | | | | 0: Data size of FMOV instruction is 32-bits | | | | | | 1: Data size of FMOV instruction is a 32-bit register pair (64 bits) | | 19 | PR | 0 | R/W | Precision Mode | | | | | | Floating-point instructions are executed as single-<br>precision operations | | | | | | <ol> <li>Floating-point instructions are executed as double-<br/>precision operations (graphics support instructions<br/>are undefined)</li> </ol> | | 18 | DN | 1 | R | Denormalization Mode (Always fixed to 1 in SH2A-FPU) | | | | | | 1: Denormalized number is treated as zero | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | | |----------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 17 to 12 | Cause | All 0 | R/W | FPU Exception Cause Field | | | | | | | 11 to 7 | Enable | All 0 | R/W | FPU Exception Enable Field | | | | | | | 6 to 2 | Flag | All 0 | R/W | FPU Exception Flag Field | | | | | | | | | | | When an FPU exception occurs, the bits corresponding to the FPU exception cause field and FPU exception flag field are set to 1. Each time an FPU operation instruction is executed, the FPU exception cause field is cleared to 0. The FPU exception flag field remains set to 1 until it is cleared to 0 by software. | | | | | | | | | | | For bit allocations of each field, see table 3.3. | | | | | | | 1 | RM1 | 0 | R/W | Rounding Mode | | | | | | | 0 | RM0 | 1 | R/W | These bits select the rounding mode. | | | | | | | | | | | 00: Round to Nearest | | | | | | | | | | | 01: Round to Zero | | | | | | | | | | | 10: Reserved | | | | | | | - | | | | 11: Reserved | | | | | | Table 3.3 Bit Allocation for FPU Exception Handling | Field Nam | ne | FPU<br>Error (E) | Invalid<br>Operation (V) | Division<br>by Zero (Z) | Overflow<br>(O) | Underflow<br>(U) | Inexact<br>(I) | |-----------|----------------------------|------------------|--------------------------|-------------------------|-----------------|------------------|----------------| | Cause | FPU exception cause field | Bit 17 | Bit 16 | Bit 15 | Bit 14 | Bit 13 | Bit 12 | | Enable | FPU exception enable field | None | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | | Flag | FPU exception flag field | None | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Note: No FPU error occurs in the SH2A-FPU. # **3.3.3** Floating-Point Communication Register (FPUL) Information is transferred between the FPU and CPU via FPUL. FPUL is a 32-bit system register that is accessed from the CPU side by means of LDS and STS instructions. For example, to convert the integer stored in general register R1 to a single-precision floating-point number, the processing flow is as follows: $\text{R1} \rightarrow \text{(LDS instruction)} \rightarrow \text{FPUL} \rightarrow \text{(single-precision FLOAT instruction)} \rightarrow \text{FR1}$ # 3.4 Rounding In a floating-point instruction, rounding is performed when generating the final operation result from the intermediate result. Therefore, the result of combination instructions such as FMAC will differ from the result when using a basic instruction such as FADD, FSUB, or FMUL. Rounding is performed once in FMAC, but twice in FADD, FSUB, and FMUL. Which of the two rounding methods is to be used is determined by the RM bits in FPSCR. FPSCR.RM[1:0] = 00: Round to Nearest FPSCR.RM[1:0] = 01: Round to Zero #### (1) Round to Nearest The operation result is rounded to the nearest expressible value. If there are two nearest expressible values, the one with an LSB of 0 is selected. If the unrounded value is $2^{\text{Emax}} (2 - 2^{-P})$ or more, the result will be infinity with the same sign as the unrounded value. The values of Emax and P, respectively, are 127 and 24 for single-precision, and 1023 and 53 for double-precision. ### (2) Round to Zero The digits below the round bit of the unrounded value are discarded. If the unrounded value is larger than the maximum expressible absolute value, the value will become the maximum expressible absolute value. #### **Floating-Point Exceptions** 3.5 #### 3.5.1 **FPU Exception Sources** The exception sources are as follows: - FPU error (E): When FPSCR.DN = 0 and a denormalized number is input (No error occurs in the SH2A-FPU) - Invalid operation (V): In case of an invalid operation, such as NaN input - Division by zero (Z): Division with a zero divisor - Overflow (O): When the operation result overflows - Underflow (U): When the operation result underflows - Inexact exception (I): When overflow, underflow, or rounding occurs The FPU exception cause field in FPSCR contains bits corresponding to all of above sources E, V, Z, O, U, and I, and the FPU exception flag and enable fields in FPSCR contain bits corresponding to sources V, Z, O, U, and I, but not E. Thus, FPU errors cannot be disabled. When an FPU exception occurs, the corresponding bit in the FPU exception cause field is set to 1, and 1 is added to the corresponding bit in the FPU exception flag field. When an FPU exception does not occur, the corresponding bit in the FPU exception cause field is cleared to 0, but the corresponding bit in the FPU exception flag field remains unchanged. # 3.5.2 FPU Exception Handling FPU exception handling is initiated in the following cases: - FPU error (E): FPSCR.DN = 0 and a denormalized number is input (No error occurs in the SH2A-FPU) - Invalid operation (V): FPSCR.Enable.V = 1 and invalid operation - Division by zero (Z): FPSCR.Enable.Z = 1 and division with a zero divisor - Overflow (O): FPSCR.Enable.O = 1 and instruction with possibility of operation result overflow - Underflow (U): FPSCR.Enable.U = 1 and instruction with possibility of operation result underflow - Inexact exception (I): FPSCR.Enable.I = 1 and instruction with possibility of inexact operation result These possibilities are shown in the individual instruction descriptions. All exception events that originate in the FPU are assigned as the same exception event. The meaning of an exception is determined by software by reading from FPSCR and interpreting the information it contains. If no bits are set in the FPU exception cause field of FPSCR when one or more of bits O, U, I, and V are set in the FPU exception enable field, this indicates that an actual exception source is not generated. Also, the destination register is not changed by any FPU exception handling operation. Except for the above, the FPU disables exception handling. In every processing, the bit corresponding to source V, Z, O, U, or I is set to 1, and a default value is generated as the operation result. - Invalid operation (V): qNaN is generated as the result. - Division by zero (Z): Infinity with the same sign as the unrounded value is generated. - Overflow (O): - When rounding mode = RZ, the maximum normalized number, with the same sign as the unrounded value, is generated. - When rounding mode = RN, infinity with the same sign as the unrounded value is generated. - Underflow (U): - Zero with the same sign as the unrounded value is generated. - Inexact exception (I): An inexact result is generated. # Section 4 Cache #### 4.1 Features Capacity Instruction cache: 8 Kbytes Operand cache: 8 Kbytes • Structure: Instructions/data separated, 4-way set associative • Cache lock function (only for operand cache): Way 2 and way 3 are lockable • Line size: 16 bytes • Number of entries: 128 entries/way • Write system: Write-back/write-through selectable • Replacement method: Least-recently-used (LRU) algorithm #### 4.1.1 Cache Structure The cache separates data and instructions and uses a 4-way set associative system. It is composed of four ways (banks), each of which is divided into an address section and a data section. Each of the address and data sections is divided into 128 entries. The data section of the entry is called a line. Each line consists of 16 bytes (4 bytes $\times$ 4). The data capacity per way is 2 Kbytes (16 bytes $\times$ 128 entries), with a total of 8 Kbytes in the cache as a whole (4 ways). Figure 4.1 shows the operand cache structure. The instruction cache structure is the same as the operand cache structure except for not having the U bit. Figure 4.1 Operand Cache Structure #### (1) Address Array The V bit indicates whether the entry data is valid. When the V bit is 1, data is valid; when 0, data is not valid. The U bit (only for operand cache) indicates whether the entry has been written to in write-back mode. When the U bit is 1, the entry has been written to; when 0, it has not. The tag address holds the physical address used in the external memory access. It consists of 21 bits (address bits 31 to 11) used for comparison during cache searches. In this LSI, the addresses of the cache-enabled space are H'000000000 to H'1FFFFFFF (see section 7, Bus State Controller (BSC)), and therefore the upper three bits of the tag address are cleared to 0. The V and U bits are initialized to 0 by a power-on reset but not initialized by a manual reset or in software standby mode. The tag address is not initialized by a power-on reset or manual reset or in software standby mode. # (2) Data Array Holds a 16-byte instruction or data. Entries are registered in the cache in line units (16 bytes). The data array is not initialized by a power-on reset or manual reset or in software standby mode. ### (3) LRU With the 4-way set associative system, up to four instructions or data with the same entry address can be registered in the cache. When an entry is registered, LRU shows which of the four ways it is recorded in. There are six LRU bits, controlled by hardware. A least-recently-used (LRU) algorithm is used to select the way that has been least recently accessed. Six LRU bits indicate the way to be replaced in case of a cache miss. The relationship between LRU and way replacement is shown in table 4.1 when the cache lock function (only for operand cache) is not used (concerning the case where the cache lock function is used, see section 4.2.2, Cache Control Register 2 (CCR2)). If a bit pattern other than those listed in table 4.1 is set in the LRU bits by software, the cache will not function correctly. When modifying the LRU bits by software, set one of the patterns listed in table 4.1. The LRU bits are initialized to B'000000 by a power-on reset but not initialized by a manual reset or in software standby mode. Table 4.1 LRU and Way Replacement (Cache Lock Function Not Used) | LRU (Bits 5 to 0) | Way to be Replaced | |------------------------------------------------|--------------------| | 000000, 000100, 010100, 100000, 110000, 110100 | 3 | | 000001, 000011, 001011, 100001, 101001, 101011 | 2 | | 000110, 000111, 001111, 010110, 011110, 011111 | 1 | | 111000, 111001, 111011, 111100, 111110, 111111 | 0 | # 4.2 Register Descriptions The cache has the following registers. **Table 4.2** Register Configuration | Register Name | Abbreviation | R/W | Initial Value | Address | Access Size | |--------------------------|--------------|-----|---------------|------------|-------------| | Cache control register 1 | CCR1 | R/W | H'00000000 | H'FFFC1000 | 32 | | Cache control register 2 | CCR2 | R/W | H'00000000 | H'FFFC1004 | 32 | ### 4.2.1 Cache Control Register 1 (CCR1) The instruction cache is enabled or disabled using the ICE bit. The ICF bit controls disabling of all instruction cache entries. The operand cache is enabled or disabled using the OCE bit. The OCF bit controls disabling of all operand cache entries. The WT bit selects either write-through mode or write-back mode for operand cache. Programs that change the contents of CCR1 should be placed in a cache-disabled space, and a cache-enabled space should be accessed after reading the contents of CCR1. CCR1 is initialized to H'00000000 by a power-on reset but not initialized by a manual reset or in software standby mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|-----|----|----|-----|----|----|----|----|-----|----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | - | - | ICF | - | - | ICE | - | - | 1 | - | OCF | - | WT | OCE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R | R | R/W | R | R | R | R | R/W | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 12 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11 | ICF | 0 | R/W | Instruction Cache Flush | | | | | | Writing 1 flushes all instruction cache entries (clears the V and LRU bits of all instruction cache entries to 0). Always reads 0. Write-back to external memory is not performed when the instruction cache is flushed. | | 10, 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 | ICE | 0 | R/W | Instruction Cache Enable | | | | | | Indicates whether the instruction cache function is enabled/disabled. | | | | | | 0: Instruction cache disable | | | | | | 1: Instruction cache enable | | 7 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 3 | OCF | 0 | R/W | Operand Cache Flush | | | | | | Writing 1 flushes all operand cache entries (clears the V, U, and LRU bits of all operand cache entries to 0). Always reads 0. Write-back to external memory is not performed when the operand cache is flushed. | | 2 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 1 | WT | 0 | R/W | Write Through | | | | | | Selects write-back mode or write-through mode. | | | | | | 0: Write-back mode | | | | | | 1: Write-through mode | | 0 | OCE | 0 | R/W | Operand Cache Enable | | | | | | Indicates whether the operand cache function is enabled/disabled. | | | | | | 0: Operand cache disable | | | | | | 1: Operand cache enable | ### 4.2.2 Cache Control Register 2 (CCR2) CCR2 is used to enable or disable the cache locking function for operand cache and is valid in cache locking mode only. In cache locking mode, the lock enable bit (the LE bit) in CCR2 is set to 1. In non-cache-locking mode, the cache locking function is invalid. When a cache miss occurs in cache locking mode by executing the prefetch instruction (PREF @Rn), the line of data pointed to by Rn is loaded into the cache according to bits 9 and 8 (the W3LOAD and W3LOCK bits) and bits 1 and 0 (the W2LOAD and W2LOCK bits) in CCR2. The relationship between the setting of each bit and a way, to be replaced when the prefetch instruction is executed, are listed in table 4.3. On the other hand, when the prefetch instruction is executed and a cache hit occurs, new data is not fetched and the entry which is already enabled is held. For example, when the prefetch instruction is executed with W3LOAD = 1 and W3LOCK = 1 specified in cache locking mode while one-line data already exists in way 0 which is specified by Rn, a cache hit occurs and data is not fetched to way 3. In the cache access other than the prefetch instruction in cache locking mode, ways to be replaced by bits W3LOCK and W2LOCK are restricted. The relationship between the setting of each bit in CCR2 and ways to be replaced are listed in table 4.4. Programs that change the contents of CCR2 should be placed in a cache-disabled space, and a cache-enabled space should be accessed after reading the contents of CCR2. CCR2 is initialized to H'00000000 by a power-on reset but not initialized by a manual reset or in software standby mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|-------------|------------|----|----|----|----|----|----|-------------|------------| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | LE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | - | - | - | W3<br>LOAD* | W3<br>LOCK | - | - | - | - | - | - | W2<br>LOAD* | W2<br>LOCK | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | R/W | R | R | R | R | R | R | R/W | R/W | Note: \* The W3LOAD and W2LOAD bits should not be set to 1 at the same time. | | | Initial | | | |----------|----------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 17 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 16 | LE | 0 | R/W | Lock Enable | | | | | | Controls the cache locking function. | | | | | | 0: Not cache locking mode | | | | | | 1: Cache locking mode | | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | W3LOAD* | 0 | R/W | Way 3 Load | | 8 | W3LOCK | 0 | R/W | Way 3 Lock | | | | | | When a cache miss occurs by the prefetch instruction while W3LOAD = 1 and W3LOCK = 1 in cache locking mode, the data is always loaded into way 3. Under any other condition, the cache miss data is loaded into the way to which LRU points. | | 7 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | W2LOAD* | 0 | R/W | Way 2 Load | | 0 | W2LOCK | 0 | R/W | Way 2 Lock | | | | | | When a cache miss occurs by the prefetch instruction while W2LOAD = 1 and W2LOCK =1 in cache locking mode, the data is always loaded into way 2. Under any other condition, the cache miss data is loaded into the way to which LRU points. | Note: \* The W3LOAD and W2LOAD bits should not be set to 1 at the same time. Table 4.3 Way to be Replaced when a Cache Miss Occurs in PREF Instruction | LE | W3LOAD* | W3LOCK | W2LOAD* | W2LOCK | Way to be Replaced | |----|---------|--------|---------|--------|----------------------------| | 0 | Х | Х | Х | Х | Decided by LRU (table 4.1) | | 1 | х | 0 | Х | 0 | Decided by LRU (table 4.1) | | 1 | Х | 0 | 0 | 1 | Decided by LRU (table 4.5) | | 1 | 0 | 1 | Х | 0 | Decided by LRU (table 4.6) | | 1 | 0 | 1 | 0 | 1 | Decided by LRU (table 4.7) | | 1 | 0 | Х | 1 | 1 | Way 2 | | 1 | 1 | 1 | 0 | Х | Way 3 | [Legend] x: Don't care Note: \* The W3LOAD and W2LOAD bits should not be set to 1 at the same time. Table 4.4 Way to be Replaced when a Cache Miss Occurs in Other than PREF Instruction | LE | W3LOAD* | W3LOCK | W2LOAD* | W2LOCK | Way to be Replaced | |----|---------|--------|---------|--------|----------------------------| | 0 | Х | Х | Х | Х | Decided by LRU (table 4.1) | | 1 | х | 0 | Х | 0 | Decided by LRU (table 4.1) | | 1 | х | 0 | Х | 1 | Decided by LRU (table 4.5) | | 1 | х | 1 | Х | 0 | Decided by LRU (table 4.6) | | 1 | Х | 1 | Х | 1 | Decided by LRU (table 4.7) | [Legend] x: Don't care Note: \* The W3LOAD and W2LOAD bits should not be set to 1 at the same time. Table 4.5 LRU and Way Replacement (when W2LOCK=1 and W3LOCK=0) | LRU (Bits 5 to 0) | Way to be Replaced | |----------------------------------------------------------------|--------------------| | 000000, 000001, 000100, 010100, 100000, 100001, 110000, 110100 | 3 | | 000011, 000110, 000111, 001011, 001111, 010110, 011110, 011111 | 1 | | 101001, 101011, 111000, 111001, 111011, 111100, 111110, 111111 | 0 | # Table 4.6 LRU and Way Replacement (when W2LOCK=0 and W3LOCK=1) | LRU (Bits 5 to 0) | Way to be Replaced | |----------------------------------------------------------------|--------------------| | 000000, 000001, 000011, 001011, 100000, 100001, 101001, 101011 | 2 | | 000100, 000110, 000111, 001111, 010100, 010110, 011110, 011111 | 1 | | 110000, 110100, 111000, 111001, 111011, 111100, 111110, 111111 | 0 | # Table 4.7 LRU and Way Replacement (when W2LOCK=1 and W3LOCK=1) | LRU (Bits 5 to 0) | Way to be Replaced | |---------------------------------------------------------------------------------------------------|--------------------| | 000000, 000001, 000011, 000100, 000110, 000111, 001011, 001111, 010100, 010110, 0111111 | 1 | | 100000, 100001, 101001, 101011, 110000, 110100, 111000, 111001, 111011, 1111100, 1111110, 1111111 | 0 | # 4.3 Operation Operations for the operand cache are described here. Operations for the instruction cache are similar to those for the operand cache except for the address array not having the U bit, and there being no prefetch operation or write operation, or a write-back buffer. # 4.3.1 Searching Cache If the operand cache is enabled (OCE bit in CCR1 is 1), whenever data in a cache-enabled area is accessed, the cache will be searched to see if the desired data is in the cache. Figure 4.2 illustrates the method by which the cache is searched. Entries are selected using bits 10 to 4 of the address used to access memory and the tag address of that entry is read. At this time, the upper three bits of the tag address are always cleared to 0. Bits 31 to 11 of the address used to access memory are compared with the read tag address. The address comparison uses all four ways. When the comparison shows a match and the selected entry is valid (V = 1), a cache hit occurs. When the comparison does not show a match or the selected entry is not valid (V = 0), a cache miss occurs. Figure 4.2 shows a hit on way 1. Figure 4.2 Cache Search Scheme #### 4.3.2 Read Access #### (1) Read Hit In a read access, data is transferred from the cache to the CPU. LRU is updated so that the hit way is the latest. #### (2) Read Miss An external bus cycle starts and the entry is updated. The way replaced follows table 4.4. Entries are updated in 16-byte units. When the desired data that caused the miss is loaded from external memory to the cache, the data is transferred to the CPU in parallel with being loaded to the cache. When it is loaded in the cache, the V bit is set to 1, and LRU is updated so that the replaced way becomes the latest. In operand cache, the U bit is additionally cleared to 0. When the U bit of the entry to be replaced by updating the entry in write-back mode is 1, the cache update cycle starts after the entry is transferred to the write-back buffer. After the cache completes its update cycle, the write-back buffer writes the entry back to the memory. The write-back unit is 16 bytes. # **4.3.3** Prefetch Operation (Only for Operand Cache) #### (1) Prefetch Hit LRU is updated so that the hit way becomes the latest. The contents in other caches are not modified. No data is transferred to the CPU. #### (2) Prefetch Miss No data is transferred to the CPU. The way to be replaced follows table 4.3. Other operations are the same in case of read miss. ### 4.3.4 Write Operation (Only for Operand Cache) #### (1) Write Hit In a write access in write-back mode, the data is written to the cache and no external memory write cycle is issued. The U bit of the entry written is set to 1 and LRU is updated so that the hit way becomes the latest. In write-through mode, the data is written to the cache and an external memory write cycle is issued. The U bit of the written entry is not updated and LRU is updated so that the replaced way becomes the latest. #### (2) Write Miss In write-back mode, an external bus cycle starts when a write miss occurs, and the entry is updated. The way to be replaced follows table 4.4. When the U bit of the entry to be replaced is 1, the cache update cycle starts after the entry is transferred to the write-back buffer. Data is written to the cache, the U bit is set to 1, and the V bit is set to 1. LRU is updated so that the replaced way becomes the latest. After the cache completes its update cycle, the write-back buffer writes the entry back to the memory. The write-back unit is 16 bytes. In write-through mode, no write to cache occurs in a write miss; the write is only to the external memory. # 4.3.5 Write-Back Buffer (Only for Operand Cache) When the U bit of the entry to be replaced in the write-back mode is 1, it must be written back to the external memory. To increase performance, the entry to be replaced is first transferred to the write-back buffer and fetching of new entries to the cache takes priority over writing back to the external memory. After the cache completes to fetch the new entry, the write-back buffer writes the entry back to external memory. During the write-back cycles, the cache can be accessed. The write-back buffer can hold one line of cache data (16 bytes) and its physical address. Figure 4.3 shows the configuration of the write-back buffer. Figure 4.3 Write-Back Buffer Configuration Page 101 of 1278 Operations in sections 4.3.2 to 4.3.5 are compiled in table 4.8. **Table 4.8** Cache Operations | Cache | CPU Cycle | Hit/<br>miss | Write-back mode/<br>write through mode | U Bit | External Memory<br>Accession<br>(through internal bus) | Cache Contents | |-----------------------|-------------------|--------------|----------------------------------------|-------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------| | Instructio<br>n cache | Instruction fetch | Hit | _ | _ | Not generated | Not renewed | | | | Miss | _ | _ | Cache renewal cycle is generated | Renewed to new values by cache renewal cycle | | Operand cache | Prefetch/<br>read | Hit | Either mode is available | х | Not generated | Not renewed | | | | Miss | Write-through mode | _ | Cache renewal cycle is generated | Renewed to new values by cache renewal cycle | | | | | Write-back mode | 0 | Cache renewal cycle is generated | Renewed to new values by cache renewal cycle | | | | | | 1 | Cache renewal cycle is generated. Succeedingly write-back cycle in write-back buffer is generated. | Renewed to new values by cache renewal cycle | | | Write | Hit | Write-through mode | _ | Write cycle CPU issues is generated. | Renewed to new values by write cycle the CPU issues | | | | | Write-back mode | х | Not generated | Renewed to new values by write cycle the CPU issues | | | | Miss | Write-through mode | _ | Write cycle CPU issues is generated. | Not renewed* | | | | | Write-back mode | 0 | Cache renewal cycle is generated | Renewed to new values by cache renewal cycle. Subsequently renewed again to new values in write cycle CPU issues. | | | | | | 1 | Cache renewal cycle is generated. Succeedingly write-back cycle in write-back buffer is generated. | Renewed to new values by cache renewal cycle. Subsequently renewed again to new values in write cycle CPU issues. | ### [Legend] x: Don't care. Note: Cache renewal cycle: 16-byte read access, write-back cycle in write-back buffer: 16-byte write access \* Neither LRU renewed. LRU is renewed in all other cases. # 4.3.6 Coherency of Cache and External Memory Use software to ensure coherency between the cache and the external memory. When memory shared by this LSI and another device is mapped in the cache-enabled space, operate the memory-mapped cache to invalidate and write back as required. # 4.4 Memory-Mapped Cache To allow software management of the cache, cache contents can be read and written by means of MOV instructions. The instruction cache address array is mapped onto addresses H'F0000000 to H'F07FFFFF, and the data array onto addresses H'F1000000 to H'F17FFFFF. The operand cache address array is mapped onto addresses H'F0800000 to H'F0FFFFFF, and the data array onto addresses H'F1800000 to H'F1FFFFFF. Only longword can be used as the access size for the address array and data array, and instruction fetches cannot be performed. ### 4.4.1 Address Array To access an address array, the 32-bit address field (for read/write accesses) and 32-bit data field (for write accesses) must be specified. In the address field, specify the entry address selecting the entry, The W bit for selecting the way, and the A bit for specifying the existence of associative operation. In the W bit, B'00 is way 0, B'01 is way 1, B'10 is way 2, and B'11 is way 3. Since the access size of the address array is fixed at longword, specify B'00 for bits 1 and 0 of the address. The tag address, LRU bits, U bit (only for operand cache), and V bit are specified as data. Always specify 0 for the upper three bits (bits 31 to 29) of the tag address. For the address and data formats, see figure 4.4. The following three operations are possible for the address array. # (1) Address Array Read The tag address, LRU bits, U bit (only for operand cache), and V bit are read from the entry address specified by the address and the entry corresponding to the way. For the read operation, associative operation is not performed regardless of whether the associative bit (A bit) specified by the address is 1 or 0. # (2) Address-Array Write (Non-Associative Operation) When the associative bit (A bit) in the address field is cleared to 0, write the tag address, LRU bits, U bit (only for operand cache), and V bit, specified by the data field, to the entry address specified by the address and the entry corresponding to the way. When writing to a cache line for which the U bit = 1 and the V bit = 1 in the operand cache address array, write the contents of the cache line back to memory, then write the tag address, LRU bits, U bit, and V bit specified by the data field. When 0 is written to the V bit, 0 must also be written to the U bit of that entry. ### (3) Address-Array Write (Associative Operation) When writing with the associative bit (A bit) of the address field set to 1, the addresses in the four ways for the entry specified by the address field are compared with the tag address that is specified by the data field. Write the U bit (only for operand cache) and the V bit specified by the data field to the entry of the way that has a hit. However, the tag address and LRU bits remain unchanged. When there is no way that has a hit, nothing is written and there is no operation. This function is used to invalidate a specific entry in the cache. When the U bit of the entry that has had a hit is 1 in the operand cache, writing back should be performed. However, when 0 is written to the V bit, 0 must also be written to the U bit of that entry. ### 4.4.2 Data Array To access a data array, the 32-bit address field (for read/write accesses) and 32-bit data field (for write accesses) must be specified. The address field specifies information for selecting the entry to be accessed; the data field specifies the longword data to be written to the data array. Specify the entry address for selecting the entry, the L bit indicating the longword position within the (16-byte) line, and the W bit for selecting the way. In the L bit, B'00 is longword 0, B'01 is longword 1, B'10 is longword 2, and B'11 is longword 3. In the W bit, B'00 is way 0, B'01 is way 1, B'10 is way 2, and B'11 is way 3. Since the access size of the data array is fixed at longword, specify B'00 for bits 1 and 0 of the address. For the address and data formats, see figure 4.4. The following two operations are possible for the data array. Information in the address array is not modified by this operation. # (1) Data Array Read The data specified by the L bit in the address is read from the entry address specified by the address and the entry corresponding to the way. # (2) Data Array Write The longword data specified by the data is written to the position specified by the L bit in the address from the entry address specified by the address and the entry corresponding to the way. Figure 4.4 Specifying Address and Data for Memory-Mapped Cache Access ### 4.4.3 Usage Examples ### (1) Invalidating Specific Entries Specific cache entries can be invalidated by writing 0 to the entry's V bit in the memory mapping cache access. When the A bit is 1, the tag address specified by the write data is compared to the tag address within the cache selected by the entry address, and data is written to the bits V and U specified by the write data when a match is found. If no match is found, there is no operation. When the V bit of an entry in the address array is set to 0, the entry is written back if the entry's U bit is 1. An example when a write data is specified in R0 and an address is specified in R1 is shown below. ``` ; R0=H'0110 0010; tag address(28-11)=B'0 0001 0001 0000 0000 0, U=0, V=0 ; R1=H'F080 0088; operand cache address array access, entry=B'000 1000, A=1 ; MOV.L R0,@R1 ``` ### (2) Reading the Data of a Specific Entry The data section of a specific cache entry can be read by the memory mapping cache access. The longword indicated in the data field of the data array in figure 4.4 is read into the register. An example when an address is specified in R0 and data is read in R1 is shown below. ``` ; R0=H'F100 004C; instruction cache data array access, entry=B'000 0100, ; Way=0, longword address=3 ; MOV.L @R0,R1 ``` #### **4.4.4** Notes Programs that access memory-mapped operand cache should be placed in a cache-disabled space. Programs that access memory-mapped instruction cache should also be placed in a cache-disabled space and an on-chip peripheral module or an external address space (a cachedisabled address) should be read at least twice each at the beginning and end of the programs. - Rewriting the address array contents so that two or more ways are hit simultaneously is prohibited. Operation is not guaranteed if the address array contents are changed so that two or more ways are hit simultaneously. - 3. Memory-mapped cache can be accessed only by the CPU and not by the DMAC. Registers can be accessed by the CPU and the DMAC. # Section 5 Exception Handling # 5.1 Overview # 5.1.1 Types of Exception Handling and Priority Exception handling is started by sources, such as resets, address errors, register bank errors, interrupts, and instructions. Table 5.1 shows their priorities. When several exception handling sources occur at once, they are processed according to the priority shown. Table 5.1 Types of Exception Handling and Priority Order | Туре | Exception Handling | | | | | | |-------------|---------------------------------|-----------------------------------------------------------------------------------|--------------|--|--|--| | Reset | Power-on reset | | | | | | | | Manual reset | | _ | | | | | Address | CPU address error | | | | | | | error | DMAC address error | | _ | | | | | Instruction | FPU exception | | _ | | | | | | Integer division exception (div | vision by zero) | _ | | | | | | Integer division exception (ov | rerflow) | _ | | | | | Register | Bank underflow | | _ | | | | | bank error | Bank overflow | | _ | | | | | Interrupt | NMI | | | | | | | | User break | | | | | | | | H-UDI | | | | | | | | IRQ | | | | | | | | On-chip peripheral modules | Direct memory access controller (DMAC) | _ | | | | | | | USB2.0 host/function module (USB) | _ | | | | | | | Compare match timer (CMT) | _ | | | | | | | Bus state controller (BSC) | _ | | | | | | | Watchdog timer (WDT) | _ | | | | | | | Host interface (HIF) | _ | | | | | | | Encryption/decryption and forward error correction core conjunction DMAC (A-DMAC) | <br>↓<br>Low | | | | | Туре | <b>Exception Handling</b> | | Priority | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|----------|--|--| | Interrupt | On-chip peripheral modules | Ethernet controller (EtherC) | High | | | | | | I <sup>2</sup> C bus interface 3 (IIC3) | _ 🛉 | | | | | | Stream interface (STIF) | _ | | | | | | Serial communication interface with FIFO (SCIF) | _ | | | | | | Serial sound interface_0 (SSI_0) | _ | | | | | | Serial sound interface_1 (SSI_1) | _ | | | | | | SD host interface (SDHI) | _ | | | | Instruction | Trap instruction (TRAPA instruction) | | | | | | | General illegal instructions (undefined code) | | | | | | | Slot illegal instructions (undefined code placed directly after a delayed branch instruction* (including an FPU instruction or FPU-related CPU instruction in FPU module standby mode), instructions that rewrite the PC*2, 32-bit instructions*3, RESBANK instruction, DIVS instruction, and DIVU instruction) | | | | | - Notes: 1. Delayed branch instructions: JMP, JSR, BRA, BSR, RTS, RTE, BF/S, BT/S, BSRF, BRAF. - 2. Instructions that rewrite the PC: JMP, JSR, BRA, BSR, RTS, RTE, BT, BF, TRAPA, BF/S, BT/S, BSRF, BRAF, JSR/N, RTV/N. - 3. 32-bit instructions: BAND.B, BANDNOT.B, BCLR.B, BLD.B, BLDNOT.B, BOR.B, BORNOT.B, BSET.B, BST.B, BXOR.B, MOV.B@disp12, MOV.W@disp12, MOV.L@disp12, MOVI20, MOVI20S, MOVU.B, MOVU.W. # 5.1.2 Exception Handling Operations The exception handling sources are detected and begin processing according to the timing shown in table 5.2. Table 5.2 Timing of Exception Source Detection and Start of Exception Handling | Exception | Source | Timing of Source Detection and Start of Handling | |---------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reset | Power-on reset | Starts when the RES pin changes from low to high, when the H-UDI reset negate command is set after the H-UDI reset assert command has been set, or when the WDT overflows. | | | Manual reset | Starts when the WDT overflows. | | Address error | | Detected when instruction is decoded and starts when the previous executing instruction finishes executing. | | Interrupts | | Detected when instruction is decoded and starts when the previous executing instruction finishes executing. | | Register bank error | Bank underflow | Starts upon attempted execution of a RESBANK instruction when saving has not been performed to register banks. | | | Bank overflow | In the state where saving has been performed to all register bank areas, starts when acceptance of register bank overflow exception has been set by the interrupt controller (the BOVE bit in IBNR of the INTC is 1) and an interrupt that uses a register bank has occurred and been accepted by the CPU. | | Instructions | Trap instruction | Starts from the execution of a TRAPA instruction. | | | General illegal instructions | Starts from the decoding of an undefined code (including an FPU instruction or FPU-related CPU instruction in FPU module standby mode) anytime except immediately after a delayed branch instruction (delay slot). | | | Slot illegal instructions | Starts from the decoding of an undefined code placed (including an FPU instruction or FPU-related CPU instruction in FPU module standby mode) immediately after a delayed branch instruction (delay slot), of instructions that rewrite the PC, of 32-bit instructions, of the RESBANK instruction, of the DIVS instruction, or of the DIVU instruction. | | | Integer division instructions | Starts when detecting division-by-zero exception or overflow exception caused by division of the negative maximum value (H'80000000) by -1. | When exception handling starts, the CPU operates as follows: ## (1) Exception Handling Triggered by Reset The initial values of the program counter (PC) and stack pointer (SP) are fetched from the exception handling vector table (PC and SP are respectively the H'00000000 and H'00000004 addresses for power-on resets and the H'00000008 and H'0000000C addresses for manual resets). See section 5.1.3, Exception Handling Vector Table, for more information. The vector base register (VBR) is then initialized to H'00000000, the interrupt mask level bits (I3 to I0) of the status register (SR) are initialized to H'F (B'1111), and the BO and CS bits are initialized. The BN bit in IBNR of the interrupt controller (INTC) is also initialized to 0. The program begins running from the PC address fetched from the exception handling vector table. # (2) Exception Handling Triggered by Address Errors, Register Bank Errors, Interrupts, and Instructions SR and PC are saved to the stack indicated by R15. In the case of interrupt exception handling other than NMI or user breaks with usage of the register banks enabled, general registers R0 to R14, control register GBR, system registers MACH, MACL, and PR, and the vector table address offset of the interrupt exception handling to be executed are saved to the register banks. In the case of exception handling due to an address error, register bank error, NMI interrupt, user break interrupt, or instruction, saving to a register bank is not performed. When saving is performed to all register banks, automatic saving to the stack is performed instead of register bank saving. In this case, an interrupt controller setting must have been made so that register bank overflow exceptions are not accepted (the BOVE bit in IBNR of the INTC is 0). If a setting to accept register bank overflow exceptions has been made (the BOVE bit in IBNR of the INTC is 1), register bank overflow exception will be generated. In the case of interrupt exception handling, the interrupt priority level is written to the I3 to I0 bits in SR. In the case of exception handling due to an address error or instruction, the I3 to I0 bits are not affected. The exception service routine start address is then fetched from the exception handling vector table and the program begins running from that address. ## 5.1.3 Exception Handling Vector Table Before exception handling begins running, the exception handling vector table must be set in memory. The exception handling vector table stores the start addresses of exception service routines. (The reset exception handling table holds the initial values of PC and SP.) All exception sources are given different vector numbers and vector table address offsets, from which the vector table addresses are calculated. During exception handling, the start addresses of the exception service routines are fetched from the exception handling vector table, which is indicated by this vector table address. Table 5.3 shows the vector numbers and vector table address offsets. Table 5.4 shows how vector table addresses are calculated. **Table 5.3** Exception Handling Vector Table | Exception Sources | | Vector<br>Numbers | Vector Table Address Offset | |--------------------------|----------------------|-------------------|-----------------------------| | Power-on reset | PC | 0 | H'00000000 to H'00000003 | | | SP | 1 | H'00000004 to H'00000007 | | Manual reset | PC | 2 | H'00000008 to H'0000000B | | | SP | 3 | H'0000000C to H'0000000F | | General illegal instru | ction | 4 | H'00000010 to H'00000013 | | (Reserved by system | n) | 5 | H'00000014 to H'00000017 | | Slot illegal instruction | 1 | 6 | H'00000018 to H'0000001B | | (Reserved by system | (Reserved by system) | | H'0000001C to H'0000001F | | | | 8 | H'00000020 to H'00000023 | | CPU address error | | 9 | H'00000024 to H'00000027 | | DMAC address error | | 10 | H'00000028 to H'0000002B | | Interrupts | NMI | 11 | H'0000002C to H'0000002F | | | User break | 12 | H'00000030 to H'00000033 | | FPU exception | | 13 | H'00000034 to H'00000037 | | H-UDI | | 14 | H'00000038 to H'0000003B | | Bank overflow | | 15 | H'0000003C to H'0000003F | | Bank underflow | | 16 | H'00000040 to H'00000043 | | Exception Sources | Vector<br>Numbers | Vector Table Address Offset | |-----------------------------------------------|-------------------|-----------------------------| | Integer division exception (division by zero) | 17 | H'00000044 to H'00000047 | | Integer division exception (overflow) | 18 | H'00000048 to H'0000004B | | (Reserved by system) | 19 | H'0000004C to H'0000004F | | | : | : | | | 31 | H'0000007C to H'0000007F | | Trap instruction (user vector) | 32 | H'00000080 to H'00000083 | | | : | : | | | 63 | H'000000FC to H'000000FF | | External interrupts (IRQ), | 64 | H'00000100 to H'00000103 | | on-chip peripheral module interrupts* | : | : | | | 511 | H'000007FC to H'000007FF | Note: \* The vector numbers and vector table address offsets for each external interrupt and onchip peripheral module interrupt are given in table 6.4 in section 6, Interrupt Controller (INTC). Table 5.4 Calculating Exception Handling Vector Table Addresses | Exception Source | Vector Table Address Calculation | |----------------------------------------------------------------|-------------------------------------------------------------------------------------------| | Resets | Vector table address = (vector table address offset)<br>= (vector number) $\times$ 4 | | Address errors, register bank errors, interrupts, instructions | Vector table address = VBR + (vector table address offset)<br>= VBR + (vector number) × 4 | Notes: 1. Vector table address offset: See table 5.3. 2. Vector number: See table 5.3. #### 5.2 Resets # 5.2.1 Input/Output Pins Table 5.5 shows the reset-related pin configuration. **Table 5.5** Pin Configuration | Pin Name | Symbol | I/O | Function | |----------------|--------|-------|-----------------------------------------------------------------------------------| | Power-on reset | RES | Input | When this pin is driven low, this LSI shifts to the power-<br>on reset processing | ## 5.2.2 Types of Reset A reset is the highest-priority exception handling source. There are two kinds of reset, power-on and manual. As shown in table 5.6, the CPU state is initialized in both a power-on reset and a manual reset. The FPU state is initialized by a power-on reset, but not by a manual reset. On-chip peripheral module registers are initialized by a power-on reset, but not by a manual reset. Table 5.6 Reset States | | Co | nditions for Transiti | on to Re | set State | Internal States | | | | |-----------------|------|----------------------------------------------------|----------|-----------------|-----------------|--------------------------------------------|----------------------------------|--| | Туре | RES | H-UDI Command | MRES | WDT<br>Overflow | СРИ | On-Chip<br>Peripheral<br>Modules, I/O Port | WRCSR of<br>WDT, FRQCR of<br>CPG | | | Power-on | Low | _ | _ | _ | Initialized | Initialized | Initialized | | | reset | High | H-UDI reset assert command is set | _ | _ | Initialized | Initialized | Initialized | | | | High | Command other<br>than H-UDI reset<br>assert is set | _ | Power-on reset | Initialized | Initialized | Not initialized | | | Manual<br>reset | High | Command other<br>than H-UDI reset<br>assert is set | Low | _ | Initialized | Not initialized* | Not initialized | | | | High | Command other<br>than H-UDI reset<br>assert is set | High | Manual<br>reset | Initialized | Not initialized* | Not initialized | | Note: \* The BN bit in IBNB of the INTC is initialized. #### 5.2.3 Power-On Reset # (1) Power-On Reset by Means of RES Pin When the RES pin is driven low, this LSI enters the power-on reset state. To reliably reset this LSI, the RES pin should be kept at the low level for the duration of the oscillation settling time at power-on or when in software standby mode (when the clock is halted), or at least 20-tcyc (unfixed) when the clock is running. In the power-on reset state, the internal state of the CPU and all the on-chip peripheral module registers are initialized. See appendix A, Pin States, for the status of individual pins during the power-on reset state. In the power-on reset state, power-on reset exception handling starts when the $\overline{RES}$ pin is first driven low for a fixed period and then returned to high. The CPU operates as follows: - 1. The initial value (execution start address) of the program counter (PC) is fetched from the exception handling vector table. - 2. The initial value of the stack pointer (SP) is fetched from the exception handling vector table. - 3. The vector base register (VBR) is cleared to H'00000000, the interrupt mask level bits (I3 to I0) of the status register (SR) are initialized to H'F (B'1111), and the BO and CS bits are initialized. The BN bit in IBNR of the INTC is also initialized to 0. - 4. The values fetched from the exception handling vector table are set in the PC and SP, and the program begins executing. Be certain to always perform power-on reset processing when turning the system power on. # (2) Power-On Reset by Means of H-UDI Reset Assert Command When the H-UDI reset assert command is set, this LSI enters the power-on reset state. Power-on reset by means of an H-UDI reset assert command is equivalent to power-on reset by means of the $\overline{RES}$ pin. Setting the H-UDI reset negate command cancels the power-on reset state. The time required between an H-UDI reset assert command and H-UDI reset negate command is the same as the time to keep the $\overline{RES}$ pin low to initiate a power-on reset. In the power-on reset state generated by an H-UDI reset assert command, setting the H-UDI reset negate command starts power-on reset exception handling. The CPU operates in the same way as when a power-on reset was caused by the $\overline{RES}$ pin. #### **(3) Power-On Reset Initiated by WDT** When a setting is made for a power-on reset to be generated in the WDT's watchdog timer mode, and WTCNT of the WDT overflows, this LSI enters the power-on reset state. In this case, WRCSR of the WDT and FRQCR of the CPG are not initialized by the reset signal generated by the WDT. If a reset caused by the $\overline{RES}$ pin or the H-UDI reset assert command occurs simultaneously with a reset caused by WDT overflow, the reset caused by the RES pin or the H-UDI reset assert command has priority, and the WOVF bit in WRCSR is cleared to 0. When power-on reset exception processing is started by the WDT, the CPU operates in the same way as when a poweron reset was caused by the $\overline{RES}$ pin. #### 5.2.4 Manual Reset #### (1) Manual Reset by Means of WDT When a manual reset is set to occur in the WDT's watchdog timer mode, if the WDT's WTCNT overflows, the manual reset state is established. In the manual reset state, the internal state of the CPU is initialized, but the registers in on-chip peripheral modules are not initialized. When manual reset exception handling is started, the CPU operates as follows. - 1. The initial value (execution start address) of the program counter (PC) is fetched from the exception handling vector table. - 2. The initial value of the stack pointer (SP) is fetched from the exception handling vector table. - 3. The vector base register (VBR) is cleared to H'00000000, the interrupt mask level bits (I3 to I0) of the status register (SR) are initialized to H'F (B'1111), and the BO and CS bits are initialized. The BN bit in IBNR of the INTC is also initialized to 0. - 4. The values fetched from the exception handling vector table are set in the PC and SP, and the program begins executing. When a manual reset is generated, the bus cycle is retained, but if a manual reset occurs while the bus is released or during DMAC burst transfer, manual reset exception handling will be deferred until the CPU acquires the bus. However, if the interval from generation of the manual reset until the end of the bus cycle is equal to or longer than the fixed internal manual reset interval cycles, the internal manual reset source is ignored instead of being deferred, and manual reset exception handling is not executed. The FPU and other modules are not initialized. # **5.3** Address Errors # **5.3.1** Address Error Sources Address errors occur when instructions are fetched or data read or written, as shown in table 5.7. Table 5.7 Bus Cycles and Address Errors | _ | | | |-----|-----|---| | Bus | Cvc | e | | Buo oyolo | | | | |-------------|---------------|------------------------------------------------------------------------------------------------------------------------|----------------------| | Туре | Bus<br>Master | Bus Cycle Description | Address Errors | | Instruction | CPU | Instruction fetched from even address | None (normal) | | fetch | | Instruction fetched from odd address | Address error occurs | | | | Instruction fetched from other than on-chip peripheral module space* or H'F0000000 to H'F5FFFFFF in on-chip RAM space* | None (normal) | | | | Instruction fetched from on-chip peripheral module space* or H'F0000000 to H'F5FFFFFF in on-chip RAM space* | Address error occurs | | Data | CPU or | Word data accessed from even address | None (normal) | | read/write | DMAC | Word data accessed from odd address | Address error occurs | | | | Longword data accessed from a longword boundary | None (normal) | | | | Longword data accessed from other than a long-word boundary | Address error occurs | | | | Byte or word data accessed in on-chip peripheral module space* | None (normal) | | | | Longword data accessed in 16-bit on-chip peripheral module space* | None (normal) | | | | Longword data accessed in 8-bit on-chip peripheral module space* | None (normal) | Note: \* See section 7, Bus State Controller (BSC), for details of the on-chip peripheral module space and on-chip RAM space. ### 5.3.2 Address Error Exception Handling When an address error occurs, the bus cycle in which the address error occurred ends.\* When the executing instruction then finishes, address error exception handling starts. The CPU operates as follows: - 1. The exception service routine start address which corresponds to the address error that occurred is fetched from the exception handling vector table. - 2. The status register (SR) is saved on the stack. - 3. The program counter (PC) is saved on the stack. The PC value saved is the start address of the instruction to be executed after the last executed instruction. - 4. After jumping to the exception service routine start address fetched from the exception handling vector table, program execution starts. The jump that occurs is not a delayed branch. Note: This sequence only applies to address errors in the reading and writing of data. In case of an address error due to instruction fetching, if the bus cycle in which the address error occurred is not completed by the end of step 3 above, address-error exception handling by the CPU is restarted. This continues until the bus cycle is complete. # 5.4 Register Bank Errors #### 5.4.1 Register Bank Error Sources #### (1) Bank Overflow In the state where saving has already been performed to all register bank areas, bank overflow occurs when acceptance of register bank overflow exception has been set by the interrupt controller (the BOVE bit in IBNR of the INTC is set to 1) and an interrupt that uses a register bank has occurred and been accepted by the CPU. #### (2) Bank Underflow Bank underflow occurs when an attempt is made to execute a RESBANK instruction while saving has not been performed to register banks. ## 5.4.2 Register Bank Error Exception Handling When a register bank error occurs, register bank error exception handling starts. The CPU operates as follows: - 1. The exception service routine start address which corresponds to the register bank error that occurred is fetched from the exception handling vector table. - 2. The status register (SR) is saved to the stack. - 3. The program counter (PC) is saved to the stack. The PC value saved is the start address of the instruction to be executed after the last executed instruction for a bank overflow, and the start address of the executed RESBANK instruction for a bank underflow. - To prevent multiple interrupts from occurring at a bank overflow, the interrupt priority level that caused the bank overflow is written to the interrupt mask level bits (I3 to I0) of the status register (SR). - 4. After jumping to the exception service routine start address fetched from the exception handling vector table, program execution starts. The jump that occurs is not a delayed branch. # 5.5 Interrupts # 5.5.1 Interrupt Sources Table 5.8 shows the sources that start up interrupt exception handling. These are divided into NMI, user breaks, H-UDI, IRQ, PINT, and on-chip peripheral modules. **Table 5.8** Interrupt Sources | Туре | Request Source | Number of<br>Sources | |---------------------------|-----------------------------------------------------------------------------------|----------------------| | NMI | NMI pin (external input) | 1 | | User break | User break controller (UBC) | 1 | | H-UDI | High-performance user debugging interface (H-UDI) | 1 | | IRQ | IRQ0 to IRQ7 pins (external input) | 8 | | On-chip peripheral module | Direct memory access controller (DMAC) | 16 | | | Ethernet controller (EtherC) | 1 | | | Compare match timer (CMT) | 2 | | | Bus state controller (BSC) | 1 | | | Watchdog timer (WDT) | 1 | | | Encryption/decryption and forward error correction core conjunction DMAC (A-DMAC) | 7 | | | Stream interface (STIF) | 2 | | | Host interface (HIF) | 2 | | | Serial sound interface_0 (SSI_0) | 1 | | | Serial sound interface_1 (SSI_1) | 1 | | | SD host interface (SDHI) | 3 | | | USB2.0 host/function module (USB) | 1 | | | I <sup>2</sup> C bus interface 3 (IIC3) | 5 | | | Serial communication interface with FIFO (SCIF) | 16 | Each interrupt source is allocated a different vector number and vector table offset. See table 6.4 in section 6, Interrupt Controller (INTC), for more information on vector numbers and vector table address offsets. #### 5.5.2 Interrupt Priority Level The interrupt priority order is predetermined. When multiple interrupts occur simultaneously (overlap), the interrupt controller (INTC) determines their relative priorities and starts processing according to the results. The priority order of interrupts is expressed as priority levels 0 to 16, with priority 0 the lowest and priority 16 the highest. The NMI interrupt has priority 16 and cannot be masked, so it is always accepted. The user break interrupt and H-UDI interrupt priority level is 15. Priority levels of IRQ interrupts, and on-chip peripheral module interrupts can be set freely using the interrupt priority registers 01, 02, and 06 to 16 (IPR01, IPR02, and IPR06 to IPR16) of the INTC as shown in table 5.9. The priority levels that can be set are 0 to 15. Level 16 cannot be set. See section 6.3.1, Interrupt Priority Registers 01, 02, 06 to 16 (IPR01, IPR02, IPR06 to IPR16), for details of IPR01, IPR02, and IPR06 to IPR16. **Table 5.9 Interrupt Priority Order** | Туре | Priority Level | Comment | | | | | |---------------------------|----------------|------------------------------------------------------|--|--|--|--| | NMI | 16 | Fixed priority level. Cannot be masked. | | | | | | User break | 15 | Fixed priority level. | | | | | | H-UDI | 15 | Fixed priority level. | | | | | | IRQ 0 to 15 | | Set with interrupt priority registers 01, 02, and 06 | | | | | | On-chip peripheral module | _ | to 16 (IPR01, IPR02, and IPR06 to IPR16). | | | | | ### 5.5.3 Interrupt Exception Handling When an interrupt occurs, its priority level is ascertained by the interrupt controller (INTC). NMI is always accepted, but other interrupts are only accepted if they have a priority level higher than the priority level set in the interrupt mask level bits (I3 to I0) of the status register (SR). When an interrupt is accepted, interrupt exception handling begins. In interrupt exception handling, the CPU fetches the exception service routine start address which corresponds to the accepted interrupt from the exception handling vector table, and saves SR and the program counter (PC) to the stack. In the case of interrupt exception handling other than NMI or user breaks with usage of the register banks enabled, general registers R0 to R14, control register GBR, system registers MACH, MACL, and PR, and the vector table address offset of the interrupt exception handling to be executed are saved in the register banks. In the case of exception handling due to an address error, NMI interrupt, user break interrupt, or instruction, saving is not performed to the register banks. If saving has been performed to all register banks (0 to 14), automatic saving to the stack is performed instead of register bank saving. In this case, an interrupt controller setting must have been made so that register bank overflow exceptions are not accepted (the BOVE bit in IBNR of the INTC is 0). If a setting to accept register bank overflow exceptions has been made (the BOVE bit in IBNR of the INTC is 1), register bank overflow exception occurs. Next, the priority level value of the accepted interrupt is written to the I3 to I0 bits in SR. For NMI, however, the priority level is 16, but the value set in the I3 to I0 bits is H'F (level 15). Then, after jumping to the start address fetched from the exception handling vector table, program execution starts. The jump that occurs is not a delayed branch. See section 6.6, Operation, for further details of interrupt exception handling. # **5.6** Exceptions Triggered by Instructions # **5.6.1** Types of Exceptions Triggered by Instructions Exception handling can be triggered by trap instructions, general illegal instructions, slot illegal instructions, and integer division exceptions, as shown in table 5.10. Table 5.10 Types of Exceptions Triggered by Instructions | Type Source Instruction | | Comment | | | | |--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Trap instruction | TRAPA | | | | | | Slot illegal instructions | Undefined code placed immediately after a delayed branch instruction (delay slot) (including the FPU instruction and FPU-related CPU instruction in FPU module standby mode), instructions that rewrite the PC, 32-bit instructions, RESBANK instruction, DIVS instruction, and DIVU instruction | Delayed branch instructions: JMP, JSR, BRA, BSR, RTS, RTE, BF/S, BT/S, BSRF, BRAF Instructions that rewrite the PC: JMP, JSR, BRA, BSR, RTS, RTE, BT, BF, TRAPA, BF/S, BT/S, BSRF, BRAF, JSR/N, RTV/N 32-bit instructions: BAND.B, BANDNOT.B, BCLR.B, BLD.B, BLDNOT.B, BOR.B, BORNOT.B, BSET.B, BST.B, BXOR.B, MOV.B@disp12, MOV.W@disp12, MOV.L@disp12, MOVI20S, MOVU.B, MOVU.W. | | | | | General illegal instructions | Undefined code anywhere<br>besides in a delay slot (including<br>the FPU instruction and FPU-<br>related CPU instruction in FPU<br>module standby mode) | | | | | | Integer division exceptions | Division by zero | DIVU, DIVS | | | | | | Negative maximum value ÷ (-1) | DIVS | | | | | Floating-point operation instruction | Instructions that will cause Invalid Operation Exception or Divide by Zero Exception defined in the IEEE754 standard, and instructions that may cause Overflow Exception, Underflow Exception, or Incorrectness Exception | FADD, FSUB, FMUL, FDIV, FMAC,<br>FCMP/EQ, FCMP/GT, FLOAT,<br>FTRC,FCNVDS, FCNVSD, FSQRT | | | | #### **5.6.2** Trap Instructions When a TRAPA instruction is executed, trap instruction exception handling starts. The CPU operates as follows: - 1. The exception service routine start address which corresponds to the vector number specified in the TRAPA instruction is fetched from the exception handling vector table. - 2. The status register (SR) is saved to the stack. - 3. The program counter (PC) is saved to the stack. The PC value saved is the start address of the instruction to be executed after the TRAPA instruction. - 4. After jumping to the exception service routine start address fetched from the exception handling vector table, program execution starts. The jump that occurs is not a delayed branch. #### 5.6.3 Slot Illegal Instructions An instruction placed immediately after a delayed branch instruction is said to be placed in a delay slot. When the instruction placed in the delay slot is an undefined code (including an FPU instruction or FPU-related CPU instruction in FPU module standby mode), an instruction that rewrites the PC, a 32-bit instruction, an RESBANK instruction, a DIVS instruction, or a DIVU instruction, slot illegal exception handling starts if such kind of instruction is decoded. When the FPU is in the module standby state, the floating-point operation instruction and FPU-related CPU instruction are handled as an undefined code; when such an instruction is placed in the delay slot, slot illegal exception handling starts if the instruction is decoded. The CPU operates as follows: - 1. The exception service routine start address is fetched from the exception handling vector table. - 2. The status register (SR) is saved to the stack. - 3. The program counter (PC) is saved to the stack. The PC value saved is the jump address of the delayed branch instruction immediately before the undefined code, the instruction that rewrites the PC, the 32-bit instruction, the RESBANK instruction, the DIVS instruction, or the DIVU instruction. - 4. After jumping to the exception service routine start address fetched from the exception handling vector table, program execution starts. The jump that occurs is not a delayed branch. # 5.6.4 General Illegal Instructions When an undefined code (including an FPU instruction or FPU-related CPU instruction in FPU module standby mode) placed anywhere other than immediately after a delayed branch instruction (i.e., in a delay slot) is decoded, general illegal instruction exception handling starts. When the FPU is in the module standby state, the floating-point operation instruction and FPU-related CPU instruction are handled as an undefined code; when such an instruction is placed anywhere other than immediately after a delayed branch instruction (i.e., in a delay slot), general illegal instruction exception handling starts if the instruction is decoded. The CPU handles general illegal instruction exception in the same way as slot illegal instruction exception. Unlike processing of slot illegal instruction exception, however, the program counter value stored is the start address of the undefined code. #### 5.6.5 Integer Division Instructions When an integer division instruction performs division by zero or the result of integer division overflows, integer division instruction exception handling starts. The instructions that may become the source of division-by-zero exception are DIVU and DIVS. The only source instruction of overflow exception is DIVS, and overflow exception occurs only when the negative maximum value is divided by -1. The CPU operates as follows: - 1. The exception service routine start address which corresponds to the integer division instruction exception that occurred is fetched from the exception handling vector table. - 2. The status register (SR) is saved to the stack. - 3. The program counter (PC) is saved to the stack. The PC value saved is the start address of the integer division instruction at which the exception occurred. - 4. After jumping to the exception service routine start address fetched from the exception handling vector table, program execution starts. The jump that occurs is not a delayed branch. ### **5.6.6** Floating-Point Operation Instruction In the floating-point status/control register (FPSCR), FPU exception occurs if the V, Z, O, U, or I bit in the FPU exception enable field (Enable) is set. This indicates that a floating-point operation instruction has caused any of the exceptions defined in the IEEE754 standard: invalid operation exception, overflow exception (likely instruction), underflow exception (likely instruction), or incorrectness exception (likely instruction). The following floating-point operation instructions may become exception sources: FADD, FSUB, FMUL, FDIV, FMAC, FCMP/EQ, FCMP/GT, FLOAT, FTRC, FCNVDS, FCNVSD, FSQRT An FPU exception occurs only when the corresponding enable bit is set. When the FPU detects an exception source, the FPU discontinues its operation and notifies the CPU of the occurrence of an exception. When exception handling is started, the CPU operates as follows: - 1. The start address of the exception service routine corresponding to the FPU exception that has occurred is fetched from the exception handling vector table. - 2. The status register (SR) is saved in the stack. - 3. The program counter (PC) is saved in the stack. The start address of the instruction following the instruction executed last is the value to be saved in the PC. - 4. To start executing the program, a jump occurs to the start address of the exception service routine fetched from the exception handling vector table. This jump is not a delayed branch. The FPU exception flag filed (Flag) in the FPSCR is always updated irrespective of whether it is capable of accepting FPU exceptions and remains set until it is cleared explicitly by an instruction from the user. The FPU exception source field (Cause) in the FPSCR changes each time an FPU instruction is executed. When the FPU exception enable field (Enable) in the FPSCR is set and when the QIS bit in the FPSCR is set, FPU exception starts if qNaN or $\pm \infty$ is entered into the source of the floating-point operation instruction. # 5.7 When Exception Sources Are Not Accepted When an address error, FPU exception, register bank error (overflow), or interrupt is generated immediately after a delayed branch instruction, it is sometimes not accepted immediately but stored instead, as shown in table 5.11. When this happens, it will be accepted when an instruction that can accept the exception is decoded. **Table 5.11 Exception Source Generation Immediately after Delayed Branch Instruction** | Point of Occurrence | Address Error | FPU exception | Register Bank<br>Error (Overflow) | Interrupt | |-------------------------------------------------|---------------|---------------|-----------------------------------|--------------| | Immediately after a delayed branch instruction* | Not accepted | Not accepted | Not accepted | Not accepted | Note: \* Delayed branch instructions: JMP, JSR, BRA, BSR, RTS, RTE, BF/S, BT/S, BSRF, BRAF # 5.8 Stack Status after Exception Handling Ends The status of the stack after exception handling ends is as shown in table 5.12. Table 5.12 Stack Status After Exception Handling Ends | <b>Exception Type</b> | Stack Status | | | | | | | | |------------------------------|--------------|---------------------------------------------------------------|---------------|--|--|--|--|--| | General illegal instruction | | 7 | | | | | | | | • | SP → | Start address of general illegal instruction | 32 bits | | | | | | | | | SR | 32 bits | | | | | | | | _ | | | | | | | | | Integer division instruction | ^ | | | | | | | | | <b>G</b> | SP → | Start address of relevant integer division instruction | 32 bits | | | | | | | | | SR | 32 bits | | | | | | | | _ | L | | | | | | | | FPU exception | ^ | | $\overline{}$ | | | | | | | | SP → | Address of the instruction following the instruction executed | 32 bits | | | | | | | | | SR | 32 bits | | | | | | | | _ | | | | | | | | # 5.9 Usage Notes #### 5.9.1 Value of Stack Pointer (SP) The value of the stack pointer must always be a multiple of four. If it is not, an address error will occur when the stack is accessed during exception handling. #### 5.9.2 Value of Vector Base Register (VBR) The value of the vector base register must always be a multiple of four. If it is not, an address error will occur when the stack is accessed during exception handling. #### 5.9.3 Address Errors Caused by Stacking of Address Error Exception Handling When the stack pointer is not a multiple of four, an address error will occur during stacking of the exception handling (interrupts, etc.) and address error exception handling will start up as soon as the first exception handling is ended. Address errors will then also occur in the stacking for this address error exception handling. To ensure that address error exception handling does not go into an endless loop, no address errors are accepted at that point. This allows program control to be shifted to the address error exception service routine and enables error processing. When an address error occurs during exception handling stacking, the stacking bus cycle (write) is executed. During stacking of the status register (SR) and program counter (PC), the SP is decremented by 4 for both, so the value of SP will not be a multiple of four after the stacking either. The address value output during stacking is the SP value, so the address where the error occurred is itself output. This means the write data stacked will be undefined. # Section 6 Interrupt Controller (INTC) The interrupt controller (INTC) ascertains the priority of interrupt sources and controls interrupt requests to the CPU. The INTC registers set the order of priority of each interrupt, allowing the user to process interrupt requests according to the user-set priority. ### 6.1 Features - 16 levels of interrupt priority can be set By setting the nine interrupt priority registers, the priorities of IRQ interrupts, and on-chip peripheral module interrupts can be selected from 16 levels for request sources. - NMI noise canceler function An NMI input-level bit indicates the NMI pin state. By reading this bit in the interrupt exception service routine, the pin state can be checked, enabling it to be used as the noise canceler function. - Register banks This LSI has register banks that enable register saving and restoration required in the interrupt processing to be performed at high speed. Page 134 of 1278 Figure 6.1 shows a block diagram of the INTC. Figure 6.1 Block Diagram of INTC # 6.2 Input/Output Pins Table 6.1 shows the pin configuration of the INTC. **Table 6.1** Pin Configuration | Pin Name | Symbol | I/O | Function | |---------------------------------|--------------|-------|-----------------------------------------------| | Nonmaskable interrupt input pin | NMI | Input | Input of nonmaskable interrupt request signal | | Interrupt request input pins | IRQ7 to IRQ0 | Input | Input of maskable interrupt request signals | # **6.3** Register Descriptions The INTC has the following registers. These registers are used to set the interrupt priorities and control detection of the external interrupt input signal. **Table 6.2** Register Configuration | Register Name | Abbreviation | R/W | Initial<br>Value | Address | Access<br>Size | |--------------------------------|--------------|---------|------------------|------------|----------------| | Interrupt control register 0 | ICR0 | R/W | *1 | H'FFFE0800 | 16, 32 | | Interrupt control register 1 | ICR1 | R/W | H'0000 | H'FFFE0802 | 16, 32 | | IRQ interrupt request register | IRQRR | R/(W)*2 | H'0000 | H'FFFE0806 | 16, 32 | | Bank control register | IBCR | R/W | H'0000 | H'FFFE080C | 16, 32 | | Bank number register | IBNR | R/W | H'0000 | H'FFFE080E | 16, 32 | | Interrupt priority register 01 | IPR01 | R/W | H'0000 | H'FFFE0818 | 16, 32 | | Interrupt priority register 02 | IPR02 | R/W | H'0000 | H'FFFE081A | 16, 32 | | Interrupt priority register 06 | IPR06 | R/W | H'0000 | H'FFFE0C00 | 16, 32 | | Interrupt priority register 07 | IPR07 | R/W | H'0000 | H'FFFE0C02 | 16, 32 | | Interrupt priority register 08 | IPR08 | R/W | H'0000 | H'FFFE0C04 | 16, 32 | | Interrupt priority register 09 | IPR09 | R/W | H'0000 | H'FFFE0C06 | 16, 32 | | Interrupt priority register 10 | IPR10 | R/W | H'0000 | H'FFFE0C08 | 16, 32 | | Interrupt priority register 11 | IPR11 | R/W | H'0000 | H'FFFE0C0A | 16, 32 | | Interrupt priority register 12 | IPR12 | R/W | H'0000 | H'FFFE0C0C | 16, 32 | | Interrupt priority register 13 | IPR13 | R/W | H'0000 | H'FFFE0C0E | 16, 32 | | Interrupt priority register 14 | IPR14 | R/W | H'0000 | H'FFFE0C10 | 16, 32 | | Interrupt priority register 15 | IPR15 | R/W | H'0000 | H'FFFE0C12 | 16, 32 | | Interrupt priority register 16 | IPR16 | R/W | H'0000 | H'FFFE0C14 | 16, 32 | Notes: 1. When the NMI pin is high, becomes H'8000; when low, becomes H'0000. 2. Only 0 can be written after reading 1, to clear the flag. # 6.3.1 Interrupt Priority Registers 01, 02, 06 to 16 (IPR01, IPR02, IPR06 to IPR16) IPR01, IPR02, and IPR06 to IPR16 are 16-bit readable/writable registers in which priority levels from 0 to 15 are set for IRQ interrupts, PINT interrupts, and on-chip peripheral module interrupts. Table 6.3 shows the correspondence between the interrupt request sources and the bits in IPR01, IPR02, and IPR06 to IPR16. Table 6.3 Interrupt Request Sources and IPR01, IPR02, and IPR06 to IPR16 | Register Name | Bits 15 to 12 | Bits 11 to 8 | Bits 7 to 4 | Bits 3 to 0 | |--------------------------------|---------------|--------------|-------------|-------------| | Interrupt priority register 01 | IRQ0 | IRQ1 | IRQ2 | IRQ3 | | Interrupt priority register 02 | IRQ4 | IRQ5 | IRQ6 | IRQ7 | | Interrupt priority register 06 | DMAC0 | DMAC1 | DMAC2 | DMAC3 | | Interrupt priority register 07 | DMAC4 | DMAC5 | DMAC6 | DMAC7 | | Interrupt priority register 08 | USB | Reserved | CMT0 | CMT1 | | Interrupt priority register 09 | BSC | WDT | HIF0 | HIF1 | | Interrupt priority register 10 | ADM1I | C[0]I | C[1]I | Reserved | | Interrupt priority register 11 | Reserved | Reserved | FECI | Reserved | | Interrupt priority register 12 | ETC | IIC3 | Reserved | STIF0 | | Interrupt priority register 13 | STIF1 | SCIF0 | SCIF1 | SCIF2 | | Interrupt priority register 14 | Reserved | Reserved | Reserved | SSI0 | | Register Name | Bits 15 to 12 | Bits 11 to 8 | Bits 7 to 4 | Bits 3 to 0 | | |--------------------------------|---------------|--------------|-------------|-------------|--| | Interrupt priority register 15 | SSI1 | Reserved | Reserved | Reserved | | | Interrupt priority register 16 | Reserved | SDHI | Reserved | Reserved | | As shown in table 6.3, by setting the 4-bit groups (bits 15 to 12, bits 11 to 8, bits 7 to 4, and bits 3 to 0) with values from H'0 (0000) to H'F (1111), the priority of each corresponding interrupt is set. Setting of H'0 means priority level 0 (the lowest level) and H'F means priority level 15 (the highest level). IPR01, IPR02, and IPR06 to IPR16 are initialized to H'0000 by a power-on reset. #### 6.3.2 **Interrupt Control Register 0 (ICR0)** ICR0 is a 16-bit register that sets the input signal detection mode for the external interrupt input pin NMI, and indicates the input level at the NMI pin. ICR0 is initialized by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|----|----|----|----|----|---|------|---|---|---|---|---|---|---|---| | | NMIL | - | - | - | - | - | - | NMIE | - | - | - | - | - | - | - | - | | Initial value: | * | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W | R | R | R | R | R | R | R | R | Note: \* 1 when the NMI pin is high, and 0 when the NMI pin is low. | Bit | Bit Name | Initial<br>Value | DW | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------| | | | | R/W | Description | | 15 | NMIL | * | R | NMI Input Level | | | | | | Sets the level of the signal input at the NMI pin. The NMI pin level can be obtained by reading this bit. This bit cannot be modified. | | | | | | 0: Low level is input to NMI pin | | | | | | 1: High level is input to NMI pin | | 14 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 | NMIE | 0 | R/W | NMI Edge Select | | | | | | Selects whether the falling or rising edge of the interrupt request signal on the NMI pin is detected. | | | | | | <ol> <li>Interrupt request is detected on falling edge of NMI input</li> </ol> | | | | | | <ol> <li>Interrupt request is detected on rising edge of NMI input</li> </ol> | | 7 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | # 6.3.3 Interrupt Control Register 1 (ICR1) ICR1 is a 16-bit register that specifies the detection mode for external interrupt input pins IRQ7 to IRQ0 individually: low level, falling edge, rising edge, or both edges. ICR1 is initialized by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------| | | IRQ71S | IRQ70S | IRQ61S | IRQ60S | IRQ51S | IRQ50S | IRQ41S | IRQ40S | IRQ31S | IRQ30S | IRQ21S | IRQ20S | IRQ11S | IRQ10S | IRQ01S | IRQ00S | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ | D/M | | | Initial | | | |-----|-------------|---------|-----|-----------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 | IRQ71S | 0 | R/W | IRQ Sense Select | | 14 | IRQ70S | 0 | R/W | These bits select whether interrupt signals | | 13 | IRQ61S | 0 | R/W | corresponding to pins IRQ7 to IRQ0 are detected by a low level, falling edge, rising edge, or both edges. | | 12 | IRQ60S | 0 | R/W | _00: Interrupt request is detected on low level of IRQn | | 11 | IRQ51S | 0 | R/W | input | | 10 | IRQ50S | 0 | R/W | 01: Interrupt request is detected on falling edge of IRQn | | 9 | IRQ41S | 0 | R/W | - input | | 8 | IRQ40S | 0 | R/W | <ul> <li>10: Interrupt request is detected on rising edge of IRQn</li> <li>input</li> </ul> | | 7 | IRQ31S | 0 | R/W | _ 11: Interrupt request is detected on both edges of IRQn | | 6 | IRQ30S | 0 | R/W | input | | 5 | IRQ21S | 0 | R/W | _ | | 4 | IRQ20S | 0 | R/W | _ | | 3 | IRQ11S | 0 | R/W | _ | | 2 | IRQ10S | 0 | R/W | _ | | 1 | IRQ01S | 0 | R/W | _ | | 0 | IRQ00S | 0 | R/W | _ | | | <del></del> | | | | [Legend] n = 7 to 0 ## 6.3.4 IRQ Interrupt Request Register (IRQRR) IRQRR is a 16-bit register that indicates interrupt requests from external input pins IRQ7 to IRQ0. If edge detection is set for the IRQ7 to IRQ0 interrupts, writing 0 to the IRQ7F to IRQ0F bits after reading IRQ7F to IRQ0F = 1 cancels the retained interrupts. IRQRR is initialized by a power-on reset. Note: \* Only 0 can be written to clear the flag after 1 is read. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | IRQ7F | 0 | R/(W)* | IRQ Interrupt Request | | 6 | IRQ6F | 0 | R/(W)* | These bits indicate the status of the IRQ7 to IRQ0 | | 5 | IRQ5F | 0 | R/(W)* | - interrupt requests. Level detection: | | 4 | IRQ4F | 0 | R/(W)* | 0: IRQn interrupt request has not occurred | | 3 | IRQ3F | 0 | R/(W)* | <br>[Clearing condition] | | 2 | IRQ2F | 0 | R/(W)* | IRQn input is high | | 1 | IRQ1F | 0 | R/(W)* | 1: IRQn interrupt has occurred | | 0 | IRQ0F | 0 | R/(W)* | [Setting condition] | | | | | | <ul> <li>IRQn input is low</li> <li>Edge detection:</li> <li>0: IRQn interrupt request is not detected</li> <li>[Clearing conditions]</li> <li>Cleared by reading IRQnF while IRQnF = 1, then writing 0 to IRQnF</li> <li>Cleared by executing IRQn interrupt exception handling</li> <li>1: IRQn interrupt request is detected</li> <li>[Setting condition]</li> <li>Edge corresponding to IRQn1S or IRQn0S of ICR1 has occurred at IRQn pin</li> </ul> | [Legend] n = 7 to 0 #### **Bank Control Register (IBCR)** 6.3.5 IBCR is a 16-bit register that enables or disables use of register banks for each interrupt priority level. IBCR is initialized to H'0000 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------| | 15 | E15 | 0 | R/W | Enable | | 14 | E14 | 0 | R/W | These bits enable or disable use of register banks for | | 13 | E13 | 0 | R/W | interrupt priority levels 15 to 1. However, use of register banks is always disabled for the user break interrupts. | | 12 | E12 | 0 | R/W | _0: Use of register banks is disabled | | 11 | E11 | 0 | R/W | _1: Use of register banks is enabled | | 10 | E10 | 0 | R/W | | | 9 | E9 | 0 | R/W | _ | | 8 | E8 | 0 | R/W | | | 7 | E7 | 0 | R/W | _ | | 6 | E6 | 0 | R/W | | | 5 | E5 | 0 | R/W | | | 4 | E4 | 0 | R/W | _ | | 3 | E3 | 0 | R/W | | | 2 | E2 | 0 | R/W | | | 1 | E1 | 0 | R/W | | | 0 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | # 6.3.6 Bank Number Register (IBNR) IBNR is a 16-bit register that enables or disables use of register banks and register bank overflow exception. IBNR also indicates the bank number to which saving is performed next through the bits BN3 to BN0. IBNR is initialized to H'0000 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|------|------|----|----|----|---|---|---|---|---|---|---|-----|------|---| | | BE[ | 1:0] | BOVE | - | - | - | - | - | - | - | - | - | | BN[ | 3:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | Initial | | | |---------|----------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15, 14 | BE[1:0] | 00 | R/W | Register Bank Enable | | | | | | These bits enable or disable use of register banks. | | | | | | 00: Use of register banks is disabled for all interrupts. The<br>setting of IBCR is ignored. | | | | | | 01: Use of register banks is enabled for all interrupts except NMI and user break. The setting of IBCR is ignored. | | | | | | 10: Reserved (setting prohibited) | | | | | | 11: Use of register banks is controlled by the setting of IBCR. | | 13 | BOVE | 0 | R/W | Register Bank Overflow Enable | | | | | | Enables of disables register bank overflow exception. | | | | | | 0: Generation of register bank overflow exception is disabled | | | | | | 1: Generation of register bank overflow exception is enabled | | 12 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 3 to 0 | BN[3:0] | 0000 | R | Bank Number | | | | | | These bits indicate the bank number to which saving is performed next. When an interrupt using register banks is accepted, saving is performed to the register bank indicated by these bits, and BN is incremented by 1. After BN is decremented by 1 due to execution of a RESBANK (restore from register bank) instruction, restoration from the register bank is performed. | #### 6.4 **Interrupt Sources** There are five types of interrupt sources: NMI, user break, H-UDI, IRQ, and on-chip peripheral modules. Each interrupt has a priority level (0 to 16), with 0 the lowest and 16 the highest. When set to level 0, that interrupt is masked at all times. #### 6.4.1 **NMI Interrupt** The NMI interrupt has a priority level of 16 and is accepted at all times. NMI interrupt requests are edge-detected, and the NMI edge select bit (NMIE) in interrupt control register 0 (ICR0) selects whether the rising edge or falling edge is detected. Though the priority level of the NMI interrupt is 16, the NMI interrupt exception handling sets the interrupt mask level bits (I3 to I0) in the status register (SR) to level 15. #### 6.4.2 **User Break Interrupt** A user break interrupt which occurs when a break condition set in the user break controller (UBC) matches has a priority level of 15. The user break interrupt exception handling sets the I3 to I0 bits in SR to level 15. For user break interrupts, see section 25, User Break Controller (UBC). #### 6.4.3 **H-UDI Interrupt** The high-performance user debugging interface (H-UDI) interrupt has a priority level of 15, and occurs at serial input of an H-UDI interrupt instruction. H-UDI interrupt requests are edgedetected and retained until they are accepted. The H-UDI interrupt exception handling sets the I3 to I0 bits in SR to level 15. For H-UDI interrupts, see section 26, High-Performance User Debugging Interface (H-UDI). #### 6.4.4 IRQ Interrupts IRQ interrupts are input from pins IRQ7 to IRQ0. For the IRQ interrupts, low-level, falling-edge, rising-edge, or both-edge detection can be selected individually for each pin by the IRQ sense select bits (IRQ71S to IRQ01S and IRQ70S to IRQ00S) in interrupt control register 1 (ICR1). The priority level can be set individually in a range from 0 to 15 for each pin by interrupt priority registers 01 and 02 (IPR01 and IPR02). When using low-level sensing for IRQ interrupts, an interrupt request signal is sent to the INTC while the IRQ7 to IRQ0 pins are low. An interrupt request signal is stopped being sent to the INTC when the IRQ7 to IRQ0 pins are driven high. The status of the interrupt requests can be checked by reading the IRQ interrupt request bits (IRQ7F to IRQ0F) in the IRQ interrupt request register (IRQRR). When using edge-sensing for IRQ interrupts, an interrupt request is detected due to change of the IRQ7 to IRQ0 pin states, and an interrupt request signal is sent to the INTC. The result of IRQ interrupt request detection is retained until that interrupt request is accepted. Whether IRQ interrupt requests have been detected or not can be checked by reading the IRQ7F to IRQ0F bits in IRQRR. Writing 0 to these bits after reading them as 1 clears the result of IRQ interrupt request detection. The IRQ interrupt exception handling sets the I3 to I0 bits in SR to the priority level of the accepted IRQ interrupt. When returning from IRQ interrupt exception service routine, execute the RTE instruction after confirming that the interrupt request has been cleared by the IRQ interrupt request register (IRQRR) so as not to accidentally receive the interrupt request again. ### 6.4.5 On-Chip Peripheral Module Interrupts On-chip peripheral module interrupts are generated by the following on-chip peripheral modules: - Direct memory access controller (DMAC) - Ethernet controller (EtherC) - Compare match timer (CMT) - Bus state controller (BSC) - Watchdog timer (WDT) - DMAC with encryption/decryption and forward error correction core (A-DMAC) - Stream interface (STIF) - Host interface (HIF) - Serial sound interface (SSI) - SD host interface (SDHI) - USB2.0 host/function module (USB) - I<sup>2</sup>C bus interface 3 (IIC3) - Serial communication interface with FIFO (SCIF) As every source is assigned a different interrupt vector, the source does not need to be identified in the exception service routine. A priority level in a range from 0 to 15 can be set for each module by interrupt priority registers 06 to 16 (IPR06 to IPR16). The on-chip peripheral module interrupt exception handling sets the I3 to I0 bits in SR to the priority level of the accepted on-chip peripheral module interrupt. # 6.5 Interrupt Exception Handling Vector Table and Priority Table 6.4 lists interrupt sources and their vector numbers, vector table address offsets, and interrupt priorities. Each interrupt source is allocated a different vector number and vector table address offset. Vector table addresses are calculated from the vector numbers and vector table address offsets. In interrupt exception handling, the interrupt exception service routine start address is fetched from the vector table indicated by the vector table address. For details of calculation of the vector table address, see table 5.4, Calculating Exception Handling Vector Table Addresses, in section 5, Exception Handling. The priorities of IRQ interrupts, and on-chip peripheral module interrupts can be set freely between 0 and 15 for each pin or module by setting interrupt priority registers 01, 02, and 06 to 16 (IPR01, IPR02, and IPR06 to IPR16). However, if two or more interrupts specified by the same IPR among IPR06 to IPR16 occur, the priorities are defined as shown in the IPR setting unit internal priority of table 6.4, and the priorities cannot be changed. A power-on reset assigns priority level 0 to IRQ interrupts, and on-chip peripheral module interrupts. If the same priority level is assigned to two or more interrupt sources and interrupts from those sources occur simultaneously, they are processed by the default priorities indicated in table 6.4. **Table 6.4** Interrupt Exception Handling Vectors and Priorities | | | Interrup | t Vector | _ | | IPR | | |-----------|-----------------|----------|--------------------------------|------------------------------------------|-------------------------|-----------------------------------------|---------------------| | Interrupt | : Source Number | Vector | Vector Table<br>Address Offset | Interrupt<br>Priority<br>(Initial Value) | Corresponding IPR (Bit) | Setting<br>Unit<br>Internal<br>Priority | Default<br>Priority | | NMI | | 11 | H'0000002C to<br>H'0000002F | 16 | _ | _ | High | | User bre | ak | 12 | H'00000030 to<br>H'00000033 | 15 | _ | _ | _ | | H-UDI | | 14 | H'00000038 to<br>H'0000003B | 15 | _ | _ | _ | | IRQ | IRQ0 | 64 | H'00000100 to<br>H'00000103 | 0 to 15 (0) | IPR01 (15 to 12) | _ | _ | | | IRQ1 | 65 | H'00000104 to<br>H'00000107 | 0 to 15 (0) | IPR01 (11 to 8) | _ | _ | | | IRQ2 | 66 | H'00000108 to<br>H'0000010B | 0 to 15 (0) | IPR01 (7 to 4) | _ | _ | | | IRQ3 | 67 | H'0000010C to<br>H'0000010F | 0 to 15 (0) | IPR01 (3 to 0) | _ | _ | | | IRQ4 | 68 | H'00000110 to<br>H'00000113 | 0 to 15 (0) | IPR02 (15 to 12) | _ | _ | | | IRQ5 | 69 | H'00000114 to<br>H'00000117 | 0 to 15 (0) | IPR02 (11 to 8) | _ | _ | | | IRQ6 | 70 | H'00000118 to<br>H'0000011B | 0 to 15 (0) | IPR02 (7 to 4) | _ | | | | IRQ7 | 71 | H'0000011C to<br>H'0000011F | 0 to 15 (0) | IPR02 (3 to 0) | _ | _ | | DMAC0 | DEI0 | 108 | H'000001B0 to<br>H'000001B3 | 0 to 15 (0) | IPR06 (15 to 12) | 1 | _ | | | HEI0 | 109 | H'000001B4 to<br>H'000001B7 | <del>-</del> | | 2 | | | DMAC1 | DEI1 | 112 | H'000001C0 to<br>H'000001C3 | 0 to 15 (0) | IPR06 (11 to 8) | 1 | _ | | | HEI1 | 113 | H'000001C4 to<br>H'000001C7 | | | 2 | ₩<br>Low | | | | Interrup | t Vector | _ | | IPR | | |-----------|-----------------|----------|--------------------------------|------------------------------------------|-------------------------|-----------------------------------------|---------------------| | Interrupt | t Source Number | Vector | Vector Table<br>Address Offset | Interrupt<br>Priority<br>(Initial Value) | Corresponding IPR (Bit) | Setting<br>Unit<br>Internal<br>Priority | Default<br>Priority | | DMAC2 | DEI2 | 116 | H'000001D0 to<br>H'000001D3 | 0 to 15 (0) | IPR06 (7 to 4) | 1 | High | | | HEI2 | 117 | H'000001D4 to<br>H'000001D7 | - | | 2 | | | DMAC3 | DEI3 | 120 | H'000001E0 to<br>H'000001E3 | 0 to 15 (0) | IPR06 (3 to 0) | 1 | _ | | | HEI3 | 121 | H'000001E4 to<br>H'000001E7 | - | | 2 | | | DMAC4 | DEI4 | 124 | H'000001F0 to<br>H'000001F3 | 0 to 15 (0) | IPR07 (15 to 12) | 1 | _ | | | HEI4 | 125 | H'000001F4 to<br>H'000001F7 | - | | 2 | | | DMAC5 | DEI5 | 128 | H'00000200 to<br>H'00000203 | 0 to 15 (0) | IPR07 (11 to 8) | 1 | _ | | | HEI5 | 129 | H'00000204 to<br>H'00000207 | _ | | 2 | | | DMAC6 | DEI6 | 132 | H'00000210 to<br>H'00000213 | 0 to 15 (0) | IPR07 (7 to 4) | 1 | _ | | | HEI6 | 133 | H'00000214 to<br>H'00000217 | _ | | 2 | | | DMAC7 | DEI7 | 136 | H'00000220 to<br>H'00000223 | 0 to 15 (0) | IPR07 (3 to 0) | 1 | _ | | | HEI7 | 137 | H'00000224 to<br>H'00000227 | _ | | 2 | | | USB | USBI | 140 | H'00000230 to<br>H'00000233 | 0 to 15 (0) | IPR08 (15 to 12) | _ | _ | | CMT | CMI0 | 142 | H'00000238 to<br>H'0000023B | 0 to 15 (0) | IPR08 (7 to 4) | _ | _ | | | CMI1 | 143 | H'0000023C to<br>H'0000023F | 0 to 15 (0) | IPR08 (3 to 0) | _ | _ | | BSC | CMI | 144 | H'00000240 to<br>H'00000243 | 0 to 15 (0) | IPR09 (15 to 12) | _ | _ | | WDT | ITI | 145 | H'00000244 to<br>H'00000247 | 0 to 15 (0) | IPR09 (11 to 8) | _ | Low | | | | Interrup | t Vector | _ | | IPR | | |-----------|---------------|----------|--------------------------------|------------------------------------------|-------------------------|-----------------------------------------|---------------------| | Interrupt | Source Number | Vector | Vector Table<br>Address Offset | Interrupt<br>Priority<br>(Initial Value) | Corresponding IPR (Bit) | Setting<br>Unit<br>Internal<br>Priority | Default<br>Priority | | HIF | HIFI | 146 | H'00000248 to<br>H'0000024B | 0 to 15 (0) | IPR09 (7 to 4) | _ | High | | | HIFBI | 150 | H'00000258 to<br>H'0000025B | 0 to 15 (0) | IPR09 (3 to 0) | _ | | | A-DMAC | ADM1I | 153 | H'00000264 to<br>H'00000267 | 0 to 15 (0) | IPR10 (15 to 12) | _ | _ | | | C[0]I | 155 | H'0000026C to<br>H'0000026F | 0 to 15 (0) | IPR10 (11 to 8) | _ | | | | C[1]I | 157 | H'00000274 to<br>H'00000277 | 0 to 15 (0) | IPR10 (7 to 4) | _ | _ | | | FECI | 159 | H'0000027C to<br>H'0000027F | 0 to 15 (0) | IPR11 (7 to 4) | _ | _ | | ETC | EINT0 | 171 | H'000002AC to<br>H'000002AF | 0 to 15 (0) | IPR12 (15 to 12) | _ | _ | | IIC3-0 | STPI0 | 172 | H'000002B0 to<br>H'000002B3 | 0 to 15 (0) | IPR12 (11 to 8) | 1 | _ | | | NAKI0 | 173 | H'000002B4 to<br>H'000002B7 | - | | 2 | | | | RXI0 | 174 | H'000002B8 to<br>H'000002BB | - | | 3 | | | | TXIO | 175 | H'000002BC to<br>H'000002BF | - | | 4 | | | | TEI0 | 176 | H'000002C0 to<br>H'000002C3 | - | | 5 | | | STIF | STI0 | 182 | H'000002D8 to<br>H'000002DB | 0 to 15 (0) | IPR12 (3 to 0) | _ | _ | | | STI1 | 187 | H'000002EC to<br>H'000002EF | 0 to 15 (0) | IPR13 (15 to 12) | _ | Low | | Interrupt Source Number | | Interrupt Vector | | _ | | IPR | | |-------------------------|-------|------------------|--------------------------------|------------------------------------------|-------------------------|-----------------------------------------|---------------------| | | | Vector | Vector Table<br>Address Offset | Interrupt<br>Priority<br>(Initial Value) | Corresponding IPR (Bit) | Setting<br>Unit<br>Internal<br>Priority | Default<br>Priority | | SCIF0 | BRI0 | 192 | H'00000300 to<br>H'00000303 | 0 to 15 (0) | IPR13 (11 to 8) | 1 | High<br><b>∱</b> | | | ERI0 | 193 | H'00000304 to<br>H'00000307 | - | | 2 | | | | RXI0 | 194 | H'00000308 to<br>H'0000030B | - | | 3 | | | | TXI0 | 195 | H'0000030C to<br>H'0000030F | _ | | 4 | | | SCIF1 | BRI1 | 196 | H'00000310 to<br>H'00000313 | 0 to 15 (0) | IPR13 (7 to 4) | 1 | _ | | | ERI1 | 197 | H'00000314 to<br>H'00000317 | _ | | 2 | | | | RXI1 | 198 | H'00000318 to<br>H'0000031B | _ | | 3 | | | | TXI1 | 199 | H'0000031C to<br>H'0000031F | _ | | 4 | | | SCIF2 | BRI2 | 200 | H'00000320 to<br>H'00000323 | 0 to 15 (0) | IPR13 (3 to 0) | 1 | _ | | | ERI2 | 201 | H'00000324 to<br>H'00000327 | | | 2 | | | | RXI2 | 202 | H'00000328 to<br>H'0000032B | <del>-</del> | | 3 | | | | TXI2 | 203 | H'0000032C to<br>H'0000032F | _ | | 4 | | | SSI0 | SSII0 | 214 | H'00000358 to<br>H'0000035B | 0 to 15 (0) | IPR14 (3 to 0) | _ | - | | SSI1 | SSII1 | 215 | H'0000035C to<br>H'0000035F | 0 to 15 (0) | IPR15 (15 to 12) | _ | | | SDIO | SDII3 | 228 | H'00000390 to<br>H'00000393 | 0 to 15 (0) | IPR16 (11 to 8) | 1 | _ | | | SDII0 | 229 | H'00000394 to<br>H'00000397 | _ | | 2 | | | | SDII1 | 230 | H'00000398 to<br>H'0000039B | | | 3 | Low | # 6.6 Operation ### 6.6.1 Interrupt Operation Sequence The sequence of interrupt operations is described below. Figure 6.2 shows the operation flow. - 1. The interrupt request sources send interrupt request signals to the interrupt controller. - 2. The interrupt controller selects the highest-priority interrupt from the interrupt requests sent, following the priority levels set in interrupt priority registers 01, 02, and 06 to 16 (IPR01, IPR02, and IPR06 to IPR16). Lower priority interrupts are ignored\*. If two of these interrupts have the same priority level or if multiple interrupts occur within a single IPR, the interrupt with the highest priority is selected, according to the default priority and IPR setting unit internal priority shown in table 6.4. - 3. The priority level of the interrupt selected by the interrupt controller is compared with the interrupt level mask bits (I3 to I0) in the status register (SR) of the CPU. If the interrupt request priority level is equal to or less than the level set in bits I3 to I0, the interrupt request is ignored. If the interrupt request priority level is higher than the level in bits I3 to I0, the interrupt controller accepts the interrupt and sends an interrupt request signal to the CPU. - 5. The CPU detects the interrupt request sent from the interrupt controller when the CPU decodes the instruction to be executed. Instead of executing the decoded instruction, the CPU starts interrupt exception handling (figure 6.4). - 6. The interrupt exception service routine start address is fetched from the exception handling vector table corresponding to the accepted interrupt. - 7. The status register (SR) is saved onto the stack, and the priority level of the accepted interrupt is copied to bits I3 to I0 in SR. - 8. The program counter (PC) is saved onto the stack. - 9. The CPU jumps to the fetched interrupt exception service routine start address and starts executing the program. The jump that occurs is not a delayed branch. - 10. A high level is output from the $\overline{IRQOUT}$ pin. However, if the interrupt controller accepts an interrupt with a higher priority than the interrupt just being accepted, the $\overline{IRQOUT}$ pin holds low level. Notes: The interrupt source flag should be cleared in the interrupt handler. After clearing the interrupt source flag, "time from occurrence of interrupt request until interrupt controller identifies priority, compares it with mask bits in SR, and sends interrupt request signal to CPU" shown in table 6.5 is required before the interrupt source sent to the CPU is actually cancelled. To ensure that an interrupt request that should have been cleared is not inadvertently accepted again, read the interrupt source flag after it has been cleared, and then execute an RTE instruction. \* Interrupt requests that are designated as edge-sensing are held pending until the interrupt requests are accepted. IRQ interrupts, however, can be cancelled by accessing the IRQ interrupt request register (IRQRR). For details, see section 6.4.4, IRQ Interrupts. Interrupts held pending due to edge-sensing are cleared by a power-on reset. Figure 6.2 Interrupt Operation Flow # 6.6.2 Stack after Interrupt Exception Handling Figure 6.3 shows the stack after interrupt exception handling. Figure 6.3 Stack after Interrupt Exception Handling # **6.7** Interrupt Response Time Table 6.5 lists the interrupt response time, which is the time from the occurrence of an interrupt request until the interrupt exception handling starts and fetching of the first instruction in the exception service routine begins. The interrupt processing operations differ in the cases when banking is disabled, when banking is enabled without register bank overflow, and when banking is enabled with register bank overflow. Figures 6.4 and 6.5 show examples of pipeline operation when banking is enabled without register bank overflow. Figures 6.8 and 6.9 show examples of pipeline operation when banking is enabled with register bank overflow. **Table 6.5** Interrupt Response Time | | | | | | Number of S | tates | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------------------------------|--------------|--------------------|--------------------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Item | | | NMI | User Break | H-UDI | IRQ, PINT | Peripheral<br>Module | Remarks | | | Time from occurrence of interrupt request until interrupt controller identifies priority, compares it with mask bits in SR, and sends interrupt request signal to CPU | | 2 lcyc +<br>2 Bcyc +<br>1 Pcyc | 3 lcyc | 2 lcyc +<br>1 Pcyc | 2 lcyc +<br>3 Bcyc +<br>1 Pcyc | 2 lcyc +<br>1 Bcyc +<br>1 Pcyc | | | | | Time from No register Min. | | Min. | 3 lcyc + m1 | + m2 | | | | Min. is when the interrupt | | | input of<br>interrupt<br>request signal<br>to CPU until<br>sequence | banking | Max. | 4 lcyc + 2(m | 1 + m2) + m3 | | | | <ul> <li>wait time is zero.</li> <li>Max. is when a higher-priority<br/>interrupt request has<br/>occurred during interrupt<br/>exception handling.</li> </ul> | | | currently being executed is | Register | Min. | _ | | 3 lcyc + m1 | + m2 | Min. is when the interrupt | | | | completed,<br>interrupt<br>exception<br>handling starts,<br>and first | banking<br>without<br>register<br>bank<br>overflow | Max. | _ | | 12 lcyc + m | 1 + m2 | wait time is zero. Max. is when an interrupt request has occurred during execution of the RESBANK instruction. | | | | instruction in | Register | Min. | _ | | 3 lcyc + m1 | + m2 | | Min. is when the interrupt | | | interrupt banking with register service routine is fetched bank overflow | | | _ | | 3 lcyc + m1 | + m2 + 19(m4) | wait time is zero. Max. is when an interrupt request has occurred during execution of the RESBANK instruction. | | | ### **Number of States** | Item | | | NMI | User Break | H-UDI | IRQ, PINT | Peripheral<br>Module | Remarks | |-------------------------|----------------------------------------------------------------|------|--------------------------------------------------------|--------------------------------|--------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------| | Interrupt response time | No register banking | Min. | 5 lcyc +<br>2 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 6 lcyc +<br>m1 + m2 | 1 Pcyc +<br>m1 + m2 | 5 lcyc +<br>3 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 5 lcyc +<br>1 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 200-MHz operation* $^{*1}$ **2: 0.040 to 0.110 $\mu s$ | | | | Max. | 6 lcyc +<br>2 Bcyc +<br>1 Pcyc +<br>2(m1 + m2) +<br>m3 | 7 lcyc +<br>2(m1 + m2) +<br>m3 | 6 lcyc +<br>1 Pcyc +<br>2(m1 + m2) +<br>m3 | 6 lcyc +<br>3 Bcyc +<br>1 Pcyc +<br>2(m1 + m2) +<br>m3 | 6 lcyc +<br>1 Bcyc +<br>1 Pcyc +<br>2(m1 + m2) +<br>m3 | 200-MHz operation* $^{1*^2}$ : 0.060 to 0.130 $\mu s$ | | | Register<br>banking<br>without<br>register<br>bank<br>overflow | Min. | _ | _ | 5 lcyc +<br>1 Pcyc +<br>m1 + m2 | 5 lcyc +<br>3 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 5 lcyc +<br>1 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 200-MHz operation* <sup>1</sup> * <sup>2</sup> :<br>0.040 to 0.110 μs | | | | Max. | _ | _ | 14 lcyc +<br>1 Pcyc +<br>m1 + m2 | 14 lcyc +<br>3 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 14 lcyc +<br>1 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 200-MHz operation* <sup>1</sup> * <sup>2</sup> :<br>0.085 to 0.155 μs | | | Register<br>banking<br>with register<br>bank | Min. | _ | _ | 5 lcyc +<br>1 Pcyc +<br>m1 + m2 | 5 lcyc +<br>3 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 5 lcyc +<br>1 Bcyc +<br>1 Pcyc +<br>m1 + m2 | 200-MHz operation* <sup>1</sup> * <sup>2</sup> : 0.040 to 0.110 μs | | | overflow | Мах. | _ | _ | 5 lcyc +<br>1 Pcyc + m1 +<br>m2 + 19(m4) | • | 5 lcyc +<br>1 Bcyc +<br>1 Pcyc + m1 +<br>m2 + 19(m4) | 200-MHz operation* <sup>1</sup> * <sup>2</sup> :<br>0.135 to 0.205 μs | Notes: m1 to m4 are the number of states needed for the following memory accesses. m1: Vector address read (longword read) m2: SR save (longword write) m3: PC save (longword write) m4: Banked registers (R0 to R14, GBR, MACH, MACL, and PR) are restored from the - 1. In the case that m1 = m2 = m3 = m4 = 1 lcyc. - 2. In the case that $(I\phi, B\phi, P\phi) = (200 \text{ MHz}, 66 \text{ MHz}, 33 \text{ MHz}).$ Figure 6.4 Example of Pipeline Operation when IRQ Interrupt is Accepted (No Register Banking) Figure 6.5 Example of Pipeline Operation for Multiple Interrupts (No Register Banking) Figure 6.6 Example of Pipeline Operation when IRQ Interrupt is Accepted (Register Banking without Register Bank Overflow) Figure 6.7 Example of Pipeline Operation when Interrupt is Accepted during RESBANK Instruction Execution (Register Banking without Register Bank Overflow) Figure 6.8 Example of Pipeline Operation when IRQ Interrupt is Accepted (Register Banking with Register Bank Overflow) Figure 6.9 Example of Pipeline Operation when Interrupt is Accepted during RESBANK Instruction Execution (Register Banking with Register Bank Overflow) ### **Register Banks** 6.8 This LSI has fifteen register banks used to perform register saving and restoration required in the interrupt processing at high speed. Figure 6.10 shows the register bank configuration. Figure 6.10 Overview of Register Bank Configuration ## 6.8.1 Banked Register and Input/Output of Banks ## (1) Banked Register The contents of the general registers (R0 to R14), global base register (GBR), multiply and accumulate registers (MACH and MACL), and procedure register (PR), and the vector table address offset are banked. ## (2) Input/Output of Banks This LSI has fifteen register banks, bank 0 to bank 14. Register banks are stacked in first-in last-out (FILO) sequence. Saving takes place in order, beginning from bank 0, and restoration takes place in the reverse order, beginning from the last bank saved to. # 6.8.2 Bank Save and Restore Operations ## (1) Saving to Bank Page 164 of 1278 Figure 6.11 shows register bank save operations. The following operations are performed when an interrupt for which usage of register banks is allowed is accepted by the CPU: - a. Assume that the bank number bit value in the bank number register (IBNR), BN, is i before the interrupt is generated. - b. The contents of registers R0 to R14, GBR, MACH, MACL, and PR, and the interrupt vector table address offset (VTO) of the accepted interrupt are saved in the bank indicated by BN, bank i. - c. The BN value is incremented by 1. Figure 6.11 Bank Save Operations Figure 6.12 shows the timing for saving to a register bank. Saving to a register bank takes place between the start of interrupt exception handling and the start of fetching the first instruction in the interrupt exception service routine. Figure 6.12 Bank Save Timing # (2) Restoration from Bank The RESBANK (restore from register bank) instruction is used to restore data saved in a register bank. After restoring data from the register banks with the RESBANK instruction at the end of the interrupt exception service routine, execute the RTE instruction to return from interrupt exception service routine. ## 6.8.3 Save and Restore Operations after Saving to All Banks If an interrupt occurs and usage of the register banks is enabled for the interrupt accepted by the CPU in a state where saving has been performed to all register banks, automatic saving to the stack is performed instead of register bank saving if the BOVE bit in the bank number register (IBNR) is cleared to 0. If the BOVE bit in IBNR is set to 1, register bank overflow exception occurs and data is not saved to the stack. Save and restore operations when using the stack are as follows: # (1) Saving to Stack - 1. The status register (SR) and program counter (PC) are saved to the stack during interrupt exception handling. - The contents of the banked registers (R0 to R14, GBR, MACH, MACL, and PR) are saved to the stack. The registers are saved to the stack in the order of MACL, MACH, GBR, PR, R14, R13, ..., R1, and R0. - 3. The register bank overflow bit (BO) in SR is set to 1. - 4. The bank number bit (BN) value in the bank number register (IBNR) remains set to the maximum value of 15. # (2) Restoration from Stack When the RESBANK (restore from register bank) instruction is executed with the register bank overflow bit (BO) in SR set to 1, the CPU operates as follows: - 1. The contents of the banked registers (R0 to R14, GBR, MACH, MACL, and PR) are restored from the stack. The registers are restored from the stack in the order of R0, R1, ..., R13, R14, PR, GBR, MACH, and MACL. - 2. The bank number bit (BN) value in the bank number register (IBNR) remains set to the maximum value of 15. ### 6.8.4 **Register Bank Exception** There are two register bank exceptions (register bank errors): register bank overflow and register bank underflow. #### **(1) Register Bank Overflow** This exception occurs if, after data has been saved to all of the register banks, an interrupt for which register bank use is allowed is accepted by the CPU, and the BOVE bit in the bank number register (IBNR) is set to 1. In this case, the bank number bit (BN) value in the bank number register (IBNR) remains set to the bank count of 15 and saving is not performed to the register bank. ### **(2) Register Bank Underflow** This exception occurs if the RESBANK (restore from register bank) instruction is executed when no data has been saved to the register banks. In this case, the values of R0 to R14, GBR, MACH, MACL, and PR do not change. In addition, the bank number bit (BN) value in the bank number register (IBNR) remains set to 0. ### 6.8.5 **Register Bank Error Exception Handling** When a register bank error occurs, register bank error exception handling starts. When this happens, the CPU operates as follows: - 1. The exception service routine start address which corresponds to the register bank error that occurred is fetched from the exception handling vector table. - 2. The status register (SR) is saved to the stack. - 3. The program counter (PC) is saved to the stack. The PC value saved is the start address of the instruction to be executed after the last executed instruction for a register bank overflow, and the start address of the executed RESBANK instruction for a register bank underflow. To prevent multiple interrupts from occurring at a register bank overflow, the interrupt priority level that caused the register bank overflow is written to the interrupt mask level bits (I3 to I0) of the status register (SR). - 4. Program execution starts from the exception service routine start address. # 6.9 Data Transfer with Interrupt Request Signals Interrupt request signals can be used to activate the DMAC and transfer data. Interrupt sources that are designated to activate the DMAC are masked without being input to the INTC. The mask condition is as follows: Mask condition = DME • (DE0 • interrupt source select 0 + DE1 • interrupt source select 1 + DE2 • interrupt source select 2 + DE3 • interrupt source select 3 + DE4 • interrupt source select 4 + DE5 • interrupt source select 5 + DE6 • interrupt source select 7) Figure 6.13 shows a block diagram of interrupt control. Here, DME is bit 0 in DMAOR of the DMAC, and DEn (n = 0 to 7) is bit 0 in CHCR0 to CHCR7 of the DMAC. For details, see section 8, Direct Memory Access Controller (DMAC). Figure 6.13 Interrupt Control Block Diagram # 6.9.1 Handling Interrupt Request Signals as Sources for CPU Interrupt but Not DMAC Activating - 1. Do not select DMAC activating sources or clear the DME bit to 0. If, DMAC activating sources are selected, clear the DE bit to 0 for the relevant channel of the DMAC. - 2. When interrupts occur, interrupt requests are sent to the CPU. - 3. The CPU clears the interrupt source and performs the necessary processing in the interrupt exception service routine. # 6.9.2 Handling Interrupt Request Signals as Sources for Activating DMAC but Not CPU Interrupt - 1. Select DMAC activating sources and set both the DE and DME bits to 1. This masks CPU interrupt sources regardless of the interrupt priority register settings. - 2. Activating sources are applied to the DMAC when interrupts occur. - 3. The DMAC clears the interrupt sources when starting transfer. # 6.10 Usage Note # 6.10.1 Timing to Clear an Interrupt Source The interrupt source flags should be cleared in the interrupt exception service routine. After clearing the interrupt source flag, "time from occurrence of interrupt request until interrupt controller identifies priority, compares it with mask bits in SR, and sends interrupt request signal to CPU" shown in table 6.5 is required before the interrupt source sent to the CPU is actually cancelled. To ensure that an interrupt request that should have been cleared is not inadvertently accepted again, read the interrupt source flag after it has been cleared, and then execute an RTE instruction. # Section 7 Bus State Controller (BSC) The bus state controller (BSC) outputs control signals for various types of memory and external devices that are connected to the external address space. BSC functions enable this LSI to connect directly with SRAM, SDRAM, and other memory storage devices, and external devices. ## 7.1 Features - 1. External address space - A maximum of 64 Mbytes for each of areas CS0 and CS3 to CS6. - Can specify the normal space interface, SRAM interface with byte selection, SDRAM, and PCMCIA interface for each address space. - Can select the data bus width (8, 16, or 32 bits) for each address space. - Controls insertion of wait cycles for each address space. - Controls insertion of wait cycles for each read access and write access. - Can set independent idle cycles during the continuous access for five cases: read-write (in same space/different spaces), read-read (in same space/different spaces), the first cycle is a write access. - For area 0, only big endian is supported. - 2. Normal space interface - Supports the interface that can directly connect to the SRAM. - 3. SDRAM interface - Multiplex output for row address/column address. - Efficient access by single read/single write. - High-speed access in bank-active mode. - Supports an auto-refresh and self-refresh. - Supports power-down modes. - Issues MRS and EMRS commands. - 4. PCMCIA direct interface - Supports the IC memory card and I/O card interface defined in JEIDA specifications Ver. 4.2 (PCMCIA2.1 Rev. 2.1). - Wait-cycle insertion controllable by program. - 5. SRAM interface with byte selection - Can connect directly to a SRAM with byte selection. - 6. Refresh function - Supports the auto-refresh and self-refresh functions. - Specifies the refresh interval using the refresh counter and clock selection. - Can execute concentrated refresh by specifying the refresh counts (1, 2, 4, 6, or 8). - 7. Usage as interval timer for refresh counter - Generates an interrupt request at compare match. Figure 7.1 shows a block diagram of the BSC. Figure 7.1 Block Diagram of BSC # 7.2 Input/Output Pins Table 7.1 shows the pin configuration of the BSC. **Table 7.1 Pin Configuration** | Name | I/O | Function | | | | | | |---------------|--------|----------------------------------------------------------------------------------------------|--|--|--|--|--| | A25 to A0 | Output | Address bus | | | | | | | D31 to D0 | I/O | Data bus | | | | | | | BS | Output | Bus cycle start | | | | | | | CS0, CS3, CS4 | Output | Chip select | | | | | | | CS5/CE1A, | Output | Chip select | | | | | | | CS6/CE1B | | Function as PCMCIA card select signals for D7 to D0 when PCMCIA is used. | | | | | | | CE2A, CE2B | Output | Function as PCMCIA card select signals for D15 to D8. | | | | | | | RD/WR | Output | Read/write | | | | | | | | | Connects to $\overline{\text{WE}}$ pins when SDRAM or SRAM with byte selection is connected. | | | | | | | RD | Output | Read pulse signal (read data output enable signal) | | | | | | | | | Functions as a strobe signal for indicating memory read cycles when PCMCIA is used. | | | | | | | WE3/DQMUU/ | Output | Indicates that D31 to D24 are being written to. | | | | | | | ĪCIOWR | | Connected to the byte select signal when a SRAM with byte selection is connected. | | | | | | | | | Functions as the select signals for D31 to D24 when SDRAM is connected. | | | | | | | | | Functions as a strobe signal for indicating I/O write cycles when PCMCIA is used. | | | | | | | WE2/DQMUL/ | Output | Indicates that D23 to D16 are being written to. | | | | | | | ĪCIORD | | Connected to the byte select signal when a SRAM with byte selection is connected. | | | | | | | | | Functions as the select signals for D23 to D16 when SDRAM is connected. | | | | | | | | | Functions as a strobe signal for indicating I/O read cycles when PCMCIA is used. | | | | | | | Name | I/O | Function | |--------------|--------|--------------------------------------------------------------------------------------| | WE1/DQMLU/WE | Output | Indicates that D15 to D8 are being written to. | | | | Connected to the byte select signal when a SRAM with byte selection is connected. | | | | Functions as the select signals for D15 to D8 when SDRAM is connected. | | | | Functions as a strobe signal for indicating memory write cycles when PCMCIA is used. | | WE0/DQMLL | Output | Indicates that D7 to D0 are being written to. | | | | Connected to the byte select signal when a SRAM with byte selection is connected. | | | | Functions as the select signals for D7 to D0 when SDRAM is connected. | | RAS | Output | Connects to RAS pin when SDRAM is connected. | | CAS | Output | Connects to CAS pin when SDRAM is connected. | | CKE | Output | Connects to CKE pin when SDRAM is connected. | | WAIT | Input | External wait input | | IOIS16 | Input | Indicates 16-bit I/O of PCMIA. | | | | Enabled only in little endian mode. The pin should be driven low in big endian mode. | | MD_BW | Input | Selects bus width of area 0 and initial bus width of areas 3 to 6. | # 7.3 Area Overview # 7.3.1 Address Map In the architecture, this LSI has a 32-bit address space, which is divided into cache-enabled, cache-disabled, and on-chip spaces (on-chip RAM, on-chip peripheral modules, and reserved areas) according to the upper bits of the address. External address spaces CS0, CS3 to CS6 are cache-enabled when internal address A29 = 0 or cache-disabled when A29 = 1. The kind of memory to be connected and the data bus width are specified in each partial space. The address map for the external address space is listed below. Table 7.2 Address Map | Internal Address | Space | Memory to be Connected | Cache | |--------------------------|-------|---------------------------------------------------------------------------------|----------------| | H'00000000 to H'03FFFFF | CS0 | Normal space, SRAM with byte selection | Cache-enabled | | H'04000000 to H'07FFFFF | Other | Reserved area | - | | H'08000000 to H'0BFFFFF | Other | Reserved area | | | H'0C000000 to H'0FFFFFF | CS3 | Normal space, SRAM with byte selection, SDRAM | _ | | H'10000000 to H'13FFFFF | CS4 | Normal space, SRAM with byte selection | _ | | H'14000000 to H'17FFFFF | CS5 | Normal space, SRAM with byte selection, PCMCIA | _ | | H'18000000 to H'1BFFFFF | CS6 | Normal space, SRAM with byte selection, PCMCIA | _ | | H'1C000000 to H'1FFFFFF | Other | Reserved area | | | H'20000000 to H'23FFFFFF | CS0 | Normal space, SRAM with byte selection, burst ROM (asynchronous or synchronous) | Cache-disabled | | H'24000000 to H'27FFFFF | Other | Reserved area | - | | H'28000000 to H'2BFFFFF | Other | Reserved area | - | | H'2C000000 to H'2FFFFFF | CS3 | Normal space, SRAM with byte selection, SDRAM | | | H'30000000 to H'33FFFFF | CS4 | Normal space, SRAM with byte selection | _ | | H'34000000 to H'37FFFFF | CS5 | Normal space, SRAM with byte selection, PCMCIA | | | H'38000000 to H'3BFFFFF | CS6 | Normal space, SRAM with byte selection, PCMCIA | _ | | H'3C000000 to H'3FFFFFF | Other | Reserved area | | | Internal Address | Space | Memory to be Connected | Cache | |--------------------------|-------|--------------------------------------------|-------| | H'80000000 to H'FFFBFFFF | Other | On-chip RAM, reserved area* | _ | | H'FFFC0000 to H'FFFFFFF | Other | On-chip peripheral modules, reserved area* | _ | Note: For the on-chip RAM space, access the addresses shown in section 27, On-Chip RAM. For the on-chip peripheral module space, access the addresses shown in section 28, List of Registers. Do not access addresses which are not described in these sections. Otherwise, the correct operation cannot be guaranteed. #### 7.3.2 Data Bus Width and Pin Function Setting in Each Area In this LSI, the data bus width of area 0 and the initial data bus width of areas 3 to 6 can be set to 8, or 16 bits through external pins during a power-on reset. The bus width of area 0 cannot be modified after a power-on reset. The initial data bus width of areas 3 to 6 is set to the same size as that of area 0, but can be modified to 8, 16, or 32 bits through register settings during program execution. Note that the selectable data bus widths may be limited depending on the connected memory type. After a power-on reset, the LSI starts execution of the program stored in the external memory allocated in area 0. Since ROM is assumed as the external memory in area 0, minimum pin functions such as the address bus, data bus, CS0, and RD are available. The sample access waveforms shown in this section include other pins such as BS, RD/WR, and WEn, which are available after they are selected through the pin function controller. Do not attempt any form of memory access other than reading of area 0 until the pin function settings have been completed by the program. For details on pin function settings, see section 23, Pin Function Controller (PFC). **Table 7.3** Correspondence between External Pin (MD) and Data Bus Width | MD_BW | Data Bus Width | |-------|----------------| | 1 | 8 bits | | 0 | 16 bits | # 7.4 Register Descriptions The BSC has the following registers. Do not access spaces other than area 0 until settings of the connected memory interface are completed. **Table 7.4** Register Configuration | Register Name | Abbreviation | R/W | Initial Value | Address | Access Size | |-------------------------------------------|--------------|-----|---------------|------------|-------------| | Common control register | CMNCR | R/W | H'00001010 | H'FFFC0000 | 32 | | CS0 space bus control register | CS0BCR | R/W | H'36DB0200* | H'FFFC0004 | 32 | | CS3 space bus control register | CS3BCR | R/W | H'36DB0200* | H'FFFC0010 | 32 | | CS4 space bus control register | CS4BCR | R/W | H'36DB0200* | H'FFFC0014 | 32 | | CS5 space bus control register | CS5BCR | R/W | H'36DB0200* | H'FFFC0018 | 32 | | CS6 space bus control register | CS6BCR | R/W | H'36DB0200* | H'FFFC001C | 32 | | CS0 space wait control register | CS0WCR | R/W | H'00000500 | H'FFFC0028 | 32 | | CS3 space wait control register | CS3WCR | R/W | H'00000500 | H'FFFC0034 | 32 | | CS4 space wait control register | CS4WCR | R/W | H'00000500 | H'FFFC0038 | 32 | | CS5 space wait control register | CS5WCR | R/W | H'00000500 | H'FFFC003C | 32 | | CS6 space wait control register | CS6WCR | R/W | H'00000500 | H'FFFC0040 | 32 | | SDRAM control register | SDCR | R/W | H'00000000 | H'FFFC004C | 32 | | Refresh timer control/status register | RTCSR | R/W | H'00000000 | H'FFFC0050 | 32 | | Refresh timer counter | RTCNT | R/W | H'00000000 | H'FFFC0054 | 32 | | Refresh time constant register | RTCOR | R/W | H'00000000 | H'FFFC0058 | 32 | | Internal bus master bus priority register | IBMPR | R/W | H'12300000 | H'FFFC1818 | 32 | Notes: \* This is an initial value when this LSI is started by the external pin (MD\_BW) with the bus width set to 8 bits. The initial value will be H'36DB0400 when the bus width is set to 16 bits. # 7.4.1 Common Control Register (CMNCR) CMNCR is a 32-bit register that controls the common items for each area. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|-----|---------|-----|------------|----|----|----|------------|------------| | | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | - | _ | D | MAIW[2: | 0] | DMA<br>IWA | _ | _ | _ | HIZ<br>MEM | HIZ<br>CNT | | Initial Value: | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. The write value should always be 1. | | 11 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 to 6 | DMAIW[2:0] | 000 | R/W | Wait states between access cycles when DMA single address transfer is performed. | | | | | | Specify the number of idle cycles to be inserted after an access to an external device with DACK when DMA single address transfer is performed. The method of inserting idle cycles depends on the contents of DMAIWA. | | | | | | 000: No idle cycle inserted | | | | | | 001: 1 idle cycle inserted | | | | | | 010: 2 idle cycles inserted | | | | | | 011: 4 idle cycles inserted | | | | | | 100: 6 idle cycles inserted | | | | | | 101: 8 idle cycles inserted | | | | | | 110: 10 idle cycles inserted | | | | | | 111: 12 idle cycles inserted | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | DMAIWA | 0 | R/W | Method of inserting wait states between access cycles when DMA single address transfer is performed. | | | | | | Specifies the method of inserting the idle cycles specified by the DMAIW[2:0] bit. Clearing this bit will make this LSI insert the idle cycles when another device, which includes this LSI, drives the data bus after an external device with DACK drove it. However, when the external device with DACK drives the data bus continuously, idle cycles are not inserted. Setting this bit will make this LSI insert the idle cycles after an access to an external device with DACK, even when the continuous access cycles to an external device with DACK are performed. | | | | | | <ol> <li>Idle cycles inserted when another device drives the<br/>data bus after an external device with DACK drove<br/>it.</li> </ol> | | | | | | Idle cycles always inserted after an access to an external device with DACK | | 4 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. The write value should always be 1. | | 3, 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | HIZMEM | 0 | R/W | High-Z Memory Control | | | | | | Specifies the pin state in software standby mode for A25 to A0, BS, CSn, CE2x, RD/WR, WEn/DQMxx, and RD. At bus-released state, these pin are high-impedance states regardless of the setting value of the HIZMEM bit. | | | | | | 0: High impedance in software standby mode | | | | | | 1: Driven in software standby mode | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------| | 0 | HIZCNT* | 0 | R/W | High-Z Control | | | | | | Specifies the state of CKE, $\overline{\text{RAS}},$ and $\overline{\text{CAS}}$ in software standby mode. | | | | | | 0: High impedance in software standby mode | | | | | | 1: Driven in software standby mode | Note: \* For High-Z control of CKIO, see section 9, Clock Pulse Generator (CPG). # 7.4.2 CSn Space Bus Control Register (CSnBCR) (n = 0, 3 to 6) CSnBCR is a 32-bit readable/writable register that specifies the function of each area, the number of idle cycles between bus cycles, and the bus width. Do not access external memory other than area 0 until CSnBCR initial setting is completed. Idle cycles may be inserted even when they are not specified. For details, see section 7.5.8, Wait between Access Cycles. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|--------|----------|----------|----------|------------|-----------|------------|----------|----------|----------|----------|----------|------------|----------|----------|----------| | | - | | IWW[2:0] | | IWRWD[2:0] | | IWRWS[2:0] | | | IV | VRRD[2: | 0] | IWRRS[2:0] | | | | | Initial value:<br>R/W: | 0<br>R | 0<br>R/W | 1<br>R/W | 1<br>R/W | 0<br>R/W | 1<br>R/W | 1<br>R/W | 0<br>R/W | 1<br>R/W | 1<br>R/W | 0<br>R/W | 1<br>R/W | 1<br>R/W | 0<br>R/W | 1<br>R/W | 1<br>R/W | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | ٦ | TYPE[2:0 | )] | ENDIAN | BSZ[1:0] | | - | - | - | - | - | - | - | - | - | | Initial value:<br>R/W: | 0<br>R | 0<br>R/W | 0<br>R/W | 0<br>R/W | 0<br>R/W | 1*<br>R/W | 1*<br>R/W | 0<br>R Note: \* CSnBCR samples the external pin (MD) that specify the bus width at power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 31 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | | | Initial | | | |----------|------------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 30 to 28 | IWW[2:0] | 011 | R/W | Idle Cycles between Write-Read Cycles and Write-Write Cycles | | | | | | These bits specify the number of idle cycles to be inserted after the access to a memory that is connected to the space. The target access cycles are the write-read cycle and write-write cycle. | | | | | | 000: No idle cycle inserted | | | | | | 001: 1 idle cycle inserted | | | | | | 010: 2 idle cycles inserted | | | | | | 011: 4 idle cycles inserted | | | | | | 100: 6 idle cycles inserted | | | | | | 101: 8 idle cycles inserted | | | | | | 110: 10 idle cycles inserted | | | | | | 111: 12 idle cycles inserted | | 27 to 25 | IWRWD[2:0] | 011 | R/W | Idle Cycles for Another Space Read-Write | | | | | | Specify the number of idle cycles to be inserted after the access to a memory that is connected to the space. The target access cycle is a read-write one in which continuous access cycles switch between different spaces. | | | | | | 000: No idle cycle inserted | | | | | | 001: 1 idle cycle inserted | | | | | | 010: 2 idle cycles inserted | | | | | | 011: 4 idle cycles inserted | | | | | | 100: 6 idle cycles inserted | | | | | | 101: 8 idle cycles inserted | | | | | | 110: 10 idle cycles inserted | | | | | | 111: 12 idle cycles inserted | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 24 to 22 | IWRWS[2:0] | 011 | R/W | Idle Cycles for Read-Write in the Same Space | | | | | | Specify the number of idle cycles to be inserted after<br>the access to a memory that is connected to the<br>space. The target cycle is a read-write cycle of which<br>continuous access cycles are for the same space. | | | | | | 000: No idle cycle inserted | | | | | | 001: 1 idle cycle inserted | | | | | | 010: 2 idle cycles inserted | | | | | | 011: 4 idle cycles inserted | | | | | | 100: 6 idle cycles inserted | | | | | | 101: 8 idle cycles inserted | | | | | | 110: 10 idle cycles inserted | | | | | | 111: 12 idle cycles inserted | | 21 to 19 | IWRRD[2:0] | 011 | R/W | Idle Cycles for Read-Read in Another Space | | | | | | Specify the number of idle cycles to be inserted after<br>the access to a memory that is connected to the<br>space. The target cycle is a read-read cycle of which<br>continuous access cycles switch between different<br>space. | | | | | | 000: No idle cycle inserted | | | | | | 001: 1 idle cycle inserted | | | | | | 010: 2 idle cycles inserted | | | | | | 011: 4 idle cycles inserted | | | | | | 100: 6 idle cycles inserted | | | | | | 101: 8 idle cycles inserted | | | | | | 110: 10 idle cycles inserted | | | | | | 111: 12 idle cycles inserted | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 to 16 | IWRRS[2:0] | 011 | R/W | Idle Cycles for Read-Read in the Same Space | | | | | | Specify the number of idle cycles to be inserted after<br>the access to a memory that is connected to the<br>space. The target cycle is a read-read cycle of which<br>continuous access cycles are for the same space. | | | | | | 000: No idle cycle inserted | | | | | | 001: 1 idle cycle inserted | | | | | | 010: 2 idle cycles inserted | | | | | | 011: 4 idle cycles inserted | | | | | | 100: 6 idle cycles inserted | | | | | | 101: 8 idle cycles inserted | | | | | | 110: 10 idle cycles inserted | | | | | | 111: 12 idle cycles inserted | | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 to 12 | TYPE[2:0] | 000 | R/W | Specify the type of memory connected to a space. | | | | | | 000: Normal space | | | | | | 001: Setting prohibited | | | | | | 010: Setting prohibited | | | | | | 011: SRAM with byte selection | | | | | | 100: SDRAM | | | | | | 101: PCMCIA | | | | | | 110: Setting prohibited | | | | | | 111: Setting prohibited | | | | | | For details for memory type in each area, see table 7.2. | | 11 | ENDIAN | 0 | R/W | Endian Setting | | | | | | Specifies the arrangement of data in a space. | | | | | | 0: Arranged in big endian | | | | | | 1: Arranged in little endian | | | | | | Note: Area 0 cannot be set to little endian mode. In the case of area 0, this bit is always read as 0, and the write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | | | | | | |--------|----------|------------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 10, 9 | BSZ[1:0] | 11* | R/W | Data Bus Width Specification | | | | | | | | | | | | | | | Specify the data bus widths of spaces. | | | | | | | | | | | | | | | 00: Reserved (setting prohibited) | | | | | | | | | | | | | | | 01: 8-bit size | | | | | | | | | | | | | | | 10: 16-bit size | | | | | | | | | | | | | | | 11: 32-bit size | | | | | | | | | | | | | | For MPX-I/O, selects bus width by address | | | | | | | | | | | | | | | | Notes: 1. The initial data bus width for areas 3 to 6 is specified by external pins. The BSZ[1:0] bits settings in CS0BCR are ignored but the bus width settings in CS1BCR to CS7BCR can be modified. | | | | | | | | | | | | | | | <ol><li>If area 5 or area 6 is specified as PCMCIA<br/>space, the bus width can be specified as<br/>either 8 bits or 16 bits.</li></ol> | | | | | | | | | | | | | | | <ol> <li>If area 3 is specified as SDRAM space,<br/>the bus width can be specified as either 16<br/>bits or 32 bits.</li> </ol> | | | | | | | | | | | 8 to 0 | _ | All 0 | R | Reserved | | | | | | | | | | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | | | | | Note: \* CSnBCR samples the external pins (MD\_BW) that specify the bus width at power-on reset. # 7.4.3 CSn Space Wait Control Register (CSnWCR) (n = 0, 3 to 6) CSnWCR specifies various wait cycles for memory access. The bit configuration of this register varies as shown below according to the memory type (TYPE2 to TYPE0) specified by the CSn space bus control register (CSnBCR). Specify CSnWCR before accessing the target area. Specify CSnBCR first, then specify CSnWCR. # (1) Normal Space, SRAM with Byte Selection ### CS0WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|-----|-------|-----|---------|-----|-----|-----|-----|-----|----|----|-----|-------| | | - | - | - | - | - | - | - | - | - | - | - | BAS | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R | R | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | - | - | SW | [1:0] | | WR[3:0] | | | WM | - | - | - | - | HW | [1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 to 22 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 21 | _ | 0 | R/W | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | BAS | 0 | R/W | Byte Access Selection when SRAM with Byte Selection is Used | | | | | | Specifies the $\overline{\text{WEn}}$ and RD/ $\overline{\text{WR}}$ signal timing when the SRAM interface with byte selection is used. | | | | | | 0: Asserts the WEn signal at the read/write timing and asserts the RD/WR signal during the write access cycle. | | | | | | 1: Asserts the WEn signal during the read/write access cycle and asserts the RD/WR signal at the write timing. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 19, 18 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 17, 16 | _ | All 0 | R/W | Reserved | | | | | | Set this bit to 0 when the interface for normal space or SRAM with byte selection is used. | | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12, 11 | SW[1:0] | 00 | R/W | Number of Delay Cycles from Address, $\overline{\text{CS0}}$ Assertion to $\overline{\text{RD}}$ , $\overline{\text{WEn}}$ Assertion | | | | | | Specify the number of delay cycles from address and $\overline{\text{CSO}}$ assertion to $\overline{\text{RD}}$ and $\overline{\text{WEn}}$ assertion. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | Jun 21, 2011 | | | Initial | | | |---------|----------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 10 to 7 | WR[3:0] | 1010 | R/W | Number of Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for read/write access. | | | | | | 0000: No cycle | | | | | | 0001: 1 cycle | | | | | | 0010: 2 cycles | | | | | | 0011: 3 cycles | | | | | | 0100: 4 cycles | | | | | | 0101: 5 cycles | | | | | | 0110: 6 cycles | | | | | | 0111: 8 cycles | | | | | | 1000: 10 cycles | | | | | | 1001: 12 cycles | | | | | | 1010: 14 cycles | | | | | | 1011: 18 cycles | | | | | | 1100: 24 cycles | | | | | | 1101: Reserved (setting prohibited) | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Reserved (setting prohibited) | | 6 | WM | 0 | R/W | External Wait Mask Specification | | | | | | Specifies whether or not the external wait input is valid. The specification by this bit is valid even when the number of access wait cycle is 0. | | | | | | 0: External wait input is valid | | | | | | 1: External wait input is ignored | | 5 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | HW[1:0] | 00 | R/W | Delay Cycles from RD, WEn Negation to Address, CS0 Negation | | | | | | Specify the number of delay cycles from RD and $\overline{\text{WEn}}$ negation to address and $\overline{\text{CSO}}$ negation. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | # • CS3WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|-----|-----|-------|-----|-----|----|-----|----|----|----|----| | | _ | _ | - | _ | _ | _ | _ | _ | | | _ | BAS | _ | _ | | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | - | _ | _ | | WR[ | [3:0] | | WM | _ | _ | _ | _ | - | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 to 21 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | BAS | 0 | R/W | SRAM with Byte Selection Byte Access Select | | | | | | Specifies the $\overline{\text{WEn}}$ and RD/ $\overline{\text{WR}}$ signal timing when the SRAM interface with byte selection is used. | | | | | | 0: Asserts the WEn signal at the read timing and asserts the RD/WR signal during the write access cycle. | | | | | | 1: Asserts the WEn signal during the read access cycle and asserts the RD/WR signal at the write timing. | | 19 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Jun 21, 2011 | | | Initial | | | |---------|----------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 10 to 7 | WR[3:0] | 1010 | R/W | Number of Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for read/write access. | | | | | | 0000: No cycle | | | | | | 0001: 1 cycle | | | | | | 0010: 2 cycles | | | | | | 0011: 3 cycles | | | | | | 0100: 4 cycles | | | | | | 0101: 5 cycles | | | | | | 0110: 6 cycles | | | | | | 0111: 8 cycles | | | | | | 1000: 10 cycles | | | | | | 1001: 12 cycles | | | | | | 1010: 14 cycles | | | | | | 1011: 18 cycles | | | | | | 1100: 24 cycles | | | | | | 1101: Reserved (setting prohibited) | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Reserved (setting prohibited) | | 6 | WM | 0 | R/W | External Wait Mask Specification | | | | | | Specifies whether or not the external wait input is valid. The specification by this bit is valid even when the number of access wait cycle is 0. | | | | | | 0: External wait input is valid | | | | | | 1: External wait input is ignored | | 5 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | ## • CS4WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|-----|-------|-----|-----|-------|-----|-----|----|-----|----|-----|---------|-------| | | 1 | - | 1 | - | 1 | - | - | 1 | - | - | 1 | BAS | - | | WW[2:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R/W | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | 1 | SW[ | [1:0] | | WR | [3:0] | | WM | 1 | - | - | - | HW | [1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 to 21 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | BAS | 0 | R/W | SRAM with Byte Selection Byte Access Select | | | | | | Specifies the $\overline{\text{WEn}}$ and RD/ $\overline{\text{WR}}$ signal timing when the SRAM interface with byte selection is used. | | | | | | 0: Asserts the WEn signal at the read timing and asserts the RD/WR signal during the write access cycle. | | | | | | 1: Asserts the WEn signal during the read access cycle and asserts the RD/WR signal at the write timing. | | 19 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 18 to 16 | WW[2:0] | 000 | R/W | Number of Write Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for write access. | | | | | | 000: The same cycles as WR[3:0] setting (number of read access wait cycles) | | | | | | 001: No cycle | | | | | | 010: 1 cycle | | | | | | 011: 2 cycles | | | | | | 100: 3 cycles | | | | | | 101: 4 cycles | | | | | | 110: 5 cycles | | | | | | 111: 6 cycles | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12, 11 | SW[1:0] | 00 | R/W | Number of Delay Cycles from Address, $\overline{\text{CS4}}$ Assertion to $\overline{\text{RD}}$ , $\overline{\text{WE}}$ Assertion | | | | | | Specify the number of delay cycles from address and $\overline{\text{CS4}}$ assertion to $\overline{\text{RD}}$ and $\overline{\text{WE}}$ assertion. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | | 10 to 7 | WR[3:0] | 1010 | R/W | Number of Read Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for read access. | | | | | | 0000: No cycle | | | | | | 0001: 1 cycle | | | | | | 0010: 2 cycles | | | | | | 0011: 3 cycles | | | | | | 0100: 4 cycles | | | | | | 0101: 5 cycles | | | | | | 0110: 6 cycles | | | | | | 0111: 8 cycles | | | | | | 1000: 10 cycles | | | | | | 1001: 12 cycles | | | | | | 1010: 14 cycles | | | | | | 1011: 18 cycles | | | | | | 1100: 24 cycles | | | | | | 1101: Reserved (setting prohibited) | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Reserved (setting prohibited) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | WM | 0 | R/W | External Wait Mask Specification | | | | | | Specifies whether or not the external wait input is valid. The specification by this bit is valid even when the number of access wait cycle is 0. | | | | | | 0: External wait input is valid | | | | | | 1: External wait input is ignored | | 5 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1, 0 | HW[1:0] | 00 | R/W | Delay Cycles from RD, WEn Negation to Address, CS4 Negation | | | | | | Specify the number of delay cycles from RD and $\overline{\text{WEn}}$ negation to address and $\overline{\text{CS4}}$ negation. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | # • CS5WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|-----|------|-----|-----|-------|-----|-----|----|--------------|----|-----|---------|------| | | - | - | - | - | - | - | - | - | - | - | - | MPXW/<br>BAS | - | | WW[2:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R/W | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | SW[ | 1:0] | | WR | [3:0] | | WM | - | - | - | - | HW[ | 1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 to 21 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | BAS | 0 | R/W | SRAM with Byte Selection Byte Access Select | | | | | | Specifies the $\overline{\text{WEn}}$ and RD/ $\overline{\text{WR}}$ signal timing when the SRAM interface with byte selection is used. | | | | | | 0: Asserts the WEn signal at the read timing and asserts the RD/WR signal during the write access cycle. | | | | | | 1: Asserts the WEn signal during the read access cycle and asserts the RD/WR signal at the write timing. | | 19 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 18 to 16 | WW[2:0] | 000 | R/W | Number of Write Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for write access. | | | | | | 000: The same cycles as WR[3:0] setting (number of read access wait cycles) | | | | | | 001: No cycle | | | | | | 010: 1 cycle | | | | | | 011: 2 cycles | | | | | | 100: 3 cycles | | | | | | 101: 4 cycles | | | | | | 110: 5 cycles | | | | | | 111: 6 cycles | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12, 11 | SW[1:0] | 00 | R/W | Number of Delay Cycles from Address, $\overline{\text{CS5}}$ Assertion to $\overline{\text{RD}}$ , $\overline{\text{WEn}}$ Assertion | | | | | | Specify the number of delay cycles from address and $\overline{\text{CS5}}$ assertion to $\overline{\text{RD}}$ and $\overline{\text{WEn}}$ assertion. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | | 10 to 7 | WR[3:0] | 1010 | R/W | Number of Read Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for read access. | | | | | | 0000: No cycle | | | | | | 0001: 1 cycle | | | | | | 0010: 2 cycles | | | | | | 0011: 3 cycles | | | | | | 0100: 4 cycles | | | | | | 0101: 5 cycles | | | | | | 0110: 6 cycles | | | | | | 0111: 8 cycles | | | | | | 1000: 10 cycles | | | | | | 1001: 12 cycles | | | | | | 1010: 14 cycles | | | | | | 1011: 18 cycles | | | | | | 1100: 24 cycles | | | | | | 1101: Reserved (setting prohibited) | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Reserved (setting prohibited) | | 6 | WM | 0 | R/W | External Wait Mask Specification | | | | | | Specifies whether or not the external wait input is valid. The specification by this bit is valid even when the number of access wait cycle is 0. | | | | | | 0: External wait input is valid | | | | | | 1: External wait input is ignored | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|------------------------------------------------------------------------------------------| | 5 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1, 0 | HW[1:0] | 00 | R/W | Delay Cycles from RD, WEn Negation to Address, CS5 Negation | | | | | | Specify the number of delay cycles from RD and WEn negation to address and CS5 negation. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | ## • CS6WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|-----|-------|-----|-----|-------|-----|-----|----|-----|----|----|-----|-------| | | - | - | - | - | -1 | - | - | - | - | - | - | BAS | - | 1 | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | SW | [1:0] | | WR | [3:0] | | WM | - | - | - | 1 | HW | [1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------| | 31 to 21 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | BAS | 0 | R/W | SRAM with Byte Selection Byte Access Select | | | | | | Specifies the $\overline{\text{WEn}}$ and RD/ $\overline{\text{WR}}$ signal timing when the SRAM interface with byte selection is used. | | | | | | 0: Asserts the WEn signal at the read timing and asserts the RD/WR signal during the write access cycle. | | | | | | <ol> <li>Asserts the WEn signal during the read/write access<br/>cycle and asserts the RD/WR signal at the write<br/>timing.</li> </ol> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 19 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12, 11 | SW[1:0] | 00 | R/W | Number of Delay Cycles from Address, CS6 Assertion to RD, WEn Assertion | | | | | | Specify the number of delay cycles from address, $\overline{\text{CS6}}$ assertion to $\overline{\text{RD}}$ and $\overline{\text{WEn}}$ assertion. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | | 10 to 7 | WR[3:0] | 1010 | R/W | Number of Access Wait Cycles | | | | | | Specify the number of cycles that are necessary for read/write access. | | | | | | 0000: No cycle | | | | | | 0001: 1 cycle | | | | | | 0010: 2 cycles | | | | | | 0011: 3 cycles | | | | | | 0100: 4 cycles | | | | | | 0101: 5 cycles | | | | | | 0110: 6 cycles | | | | | | 0111: 8 cycles | | | | | | 1000: 10 cycles | | | | | | 1001: 12 cycles | | | | | | 1010: 14 cycles | | | | | | 1011: 18 cycles | | | | | | 1100: 24 cycles | | | | | | 1101: Reserved (setting prohibited) | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Reserved (setting prohibited) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | WN | 0 | R/W | External Wait Mask Specification | | | | | | Specifies whether or not the external wait input is valid. The specification of this bit is valid even when the number of access wait cycles is 0. | | | | | | 0: The external wait input is valid | | | | | | 1: The external wait input is ignored | | 5 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1, 0 | HW[1:0] | 00 | R/W | Number of Delay Cycles from RD, WEn Negation to Address, CS6 Negation | | | | | | Specify the number of delay cycles from $\overline{RD}$ , $\overline{WEn}$ negation to address, and $\overline{CS6}$ negation. | | | | | | 00: 0.5 cycles | | | | | | 01: 1.5 cycles | | | | | | 10: 2.5 cycles | | | | | | 11: 3.5 cycles | ## (2) SDRAM ## • CS3WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|-----|--------|----|------|--------|----|------|--------|----|----|-----|--------|----|-----|--------| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | WTR | P[1:0] | - | WTRC | D[1:0] | - | A3Cl | _[1:0] | - | - | TRW | L[1:0] | - | WTR | C[1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R/W | R/W | R | R/W | R/W | R | R/W | R/W | R | R | R/W | R/W | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|-----|--------------------------------------------------------------------------------------------------------| | 31 to 15 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 14, 13 | WTRP[1:0] | 00 | R/W | Number of Auto-Precharge Completion Wait Cycles | | | | | | Specify the number of minimum precharge completion wait cycles as shown below. | | | | | | <ul> <li>From the start of auto-precharge and issuing of<br/>ACTV command for the same bank</li> </ul> | | | | | | From issuing of the PRE/PALL command to issuing<br>of the ACTV command for the same bank | | | | | | Till entering the power-down mode or deep power-<br>down mode | | | | | | From the issuing of PALL command to issuing REF command in auto refresh mode | | | | | | <ul> <li>From the issuing of PALL command to issuing<br/>SELF command in self refresh mode</li> </ul> | | | | | | 00: No cycle | | | | | | 01: 1 cycle | | | | | | 10: 2 cycles | | | | | | 11: 3 cycles | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------| | 12 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 11, 10 | WTRCD[1:0] | 01 | R/W | Number of Wait Cycles between ACTV Command and READ(A)/WRIT(A) Command | | | | | | Specify the minimum number of wait cycles from issuing the ACTV command to issuing the READ(A)/WRIT(A) command. | | | | | | 00: No cycle | | | | | | 01: 1 cycle | | | | | | 10: 2 cycles | | | | | | 11: 3 cycles | | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 8, 7 | A3CL[1:0] | 10 | R/W | CAS Latency for Area 3 | | | | | | Specify the CAS latency for area 3. | | | | | | 00: 1 cycle | | | | | | 01: 2 cycles | | | | | | 10: 3 cycles | | | | | | 11: 4 cycles | | 6, 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|-----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4, 3 | TRWL[1:0] | 00 | R/W | Number of Auto-Precharge Startup Wait Cycles | | | | | | Specify the number of minimum auto-precharge startup wait cycles as shown below. | | | | | | Cycle number from the issuance of the WRITA command by this LSI until the completion of autoprecharge in the SDRAM. Equivalent to the cycle number from the issuance of the WRITA command until the issuance of the ACTV command. Confirm that how many cycles are required between the WRITE command receive in the SDRAM and the auto-precharge activation, referring to each SDRAM data sheet. And set the cycle number so as not to exceed the cycle number specified by this bit. | | | | | | <ul> <li>Cycle number from the issuance of the WRITA<br/>command until the issuance of the PRE command.</li> <li>This is the case when accessing another low<br/>address in the same bank in bank active mode.</li> </ul> | | | | | | 00: No cycle | | | | | | 01: 1 cycle | | | | | | 10: 2 cycles | | | | | | 11: 3 cycles | | 2 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|-----------|------------------|-----|-------------------------------------------------------------------------------------------------------------| | 1, 0 | WTRC[1:0] | 00 | R/W | Number of Idle Cycles from REF Command/Self-<br>Refresh Release to ACTV/REF/MRS Command | | | | | | Specify the number of minimum idle cycles in the periods shown below. | | | | | | <ul> <li>From the issuance of the REF command until the<br/>issuance of the ACTV/REF/MRS command</li> </ul> | | | | | | <ul> <li>From releasing self-refresh until the issuance of the<br/>ACTV/REF/MRS command.</li> </ul> | | | | | | 00: 2 cycles | | | | | | 01: 3 cycles | | | | | | 10: 5 cycles | | | | | | 11: 8 cycles | ## (3) PCMCIA # • CS5WCR, CS6WCR | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|-----|-----|-------|-----|-----|-----|-------|-----|----|-----|------|-----|-----|-------|-----| | | - | - | - | - | - | - | - | - | - | - | SA[ | 1:0] | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | | TED | [3:0] | | | PCW | [3:0] | | WM | - | - | | TEH | [3:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|---------------------------------------------------------------------------------------| | 31 to 22 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 21, 20 | SA[1:0] | 00 | R/W | Space Attribute Specification | | | | | | Select memory card interface or I/O card interface when PCMCIA interface is selected. | | | | | | SA1: | | | | | | 0: Selects memory card interface for the space for A25 = 1. | | | | | | 1: Selects I/O card interface for the space for A25 = 1. | | | | | | SA0: | | | | | | 0: Selects memory card interface for the space for A25 = 0. | | | | | | 1: Selects I/O card interface for the space for $A25 = 0$ . | | 19 to 15 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Jun 21, 2011 | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 to 11 | TED[3:0] | 0000 | R/W | Number of Delay Cycles from Address Output to RD/WE Assertion | | | | | | Specify the number of delay cycles from address output to RD/WE assertion for the memory card or to ICIORD/ICIOWR assertion for the I/O card in PCMCIA interface. | | | | | | 0000: 0.5 cycle | | | | | | 0001: 1.5 cycles | | | | | | 0010: 2.5 cycles | | | | | | 0011: 3.5 cycles | | | | | | 0100: 4.5 cycles | | | | | | 0101: 5.5 cycles | | | | | | 0110: 6.5 cycles | | | | | | 0111: 7.5 cycles | | | | | | 1000: 8.5 cycles | | | | | | 1001: 9.5 cycles | | | | | | 1010: 10.5 cycles | | | | | | 1011: 11.5 cycles | | | | | | 1100: 12.5 cycles | | | | | | 1101: 13.5 cycles | | | | | | 1110: 14.5 cycles | | | | | | 1111: 15.5 cycles | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------| | 10 to 7 | PCW[3:0] | 1010 | R/W | Number of Access Wait Cycles | | | | | | Specify the number of wait cycles to be inserted. | | | | | | 0000: 3 cycles | | | | | | 0001: 6 cycles | | | | | | 0010: 9 cycles | | | | | | 0011: 12 cycles | | | | | | 0100: 15 cycles | | | | | | 0101: 18 cycles | | | | | | 0110: 22 cycles | | | | | | 0111: 26 cycles | | | | | | 1000: 30 cycles | | | | | | 1001: 33 cycles | | | | | | 1010: 36 cycles | | | | | | 1011: 38 cycles | | | | | | 1100: 52 cycles | | | | | | 1101: 60 cycles | | | | | | 1110: 64 cycles | | | | | | 1111: 80 cycles | | 6 | WM | 0 | R/W | External Wait Mask Specification | | | | | | Specifies whether or not the external wait input is valid. The specification by this bit is valid even when the number of access wait cycles is 0. | | | | | | 0: External wait input is valid | | | | | | 1: External wait input is ignored | | 5, 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | | <b></b> | Initial | | | |--------|----------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 3 to 0 | TEH[3:0] | 0000 | R/W | Delay Cycles from RD/WE Negation to Address | | | | | | Specify the number of address hold cycles from RD/WE negation for the memory card or those from ICIORD/ICIOWR negation for the I/O card in PCMCIA interface. | | | | | | 0000: 0.5 cycle | | | | | | 0001: 1.5 cycles | | | | | | 0010: 2.5 cycles | | | | | | 0011: 3.5 cycles | | | | | | 0100: 4.5 cycles | | | | | | 0101: 5.5 cycles | | | | | | 0110: 6.5 cycles | | | | | | 0111: 7.5 cycles | | | | | | 1000: 8.5 cycles | | | | | | 1001: 9.5 cycles | | | | | | 1010: 10.5 cycles | | | | | | 1011: 11.5 cycles | | | | | | 1100: 12.5 cycles | | | | | | 1101: 13.5 cycles | | | | | | 1110: 14.5 cycles | | | | | | 1111: 15.5 cycles | # 7.4.4 SDRAM Control Register (SDCR) SDCR specifies the method to refresh and access SDRAM, and the types of SDRAMs to be connected. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|------|----|------|-------|-------|-------|----|----|----|------|--------|----|------|--------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | ı | ı | ı | ı | ı | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | DEEP | _ | RFSH | RMODE | PDOWN | BACTV | _ | ĺ | - | A3RO | W[1:0] | - | A3CO | L[1:0] | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R/W | R | R/W | R/W | R/W | R/W | R | R | R | R/W | R/W | R | R/W | R/W | | | | Initial | | | |----------|----------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 14 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 13 | DEEP | 0 | R/W | Deep Power-Down Mode | | | | | | This bit is valid for low-power SDRAM. If the RFSH or RMODE bit is set to 1 while this bit is set to 1, the deep power-down entry command is issued and the low-power SDRAM enters the deep power-down mode. | | | | | | 0: Self-refresh mode | | | | | | 1: Deep power-down mode | | 12 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 11 | RFSH | 0 | R/W | Refresh Control | | | | | | Specifies whether or not the refresh operation of the SDRAM is performed. | | | | | | 0: No refresh | | | | | | 1: Refresh | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 | RMODE | 0 | R/W | Refresh Control | | | | | | Specifies whether to perform auto-refresh or self-refresh when the RFSH bit is 1. When the RFSH bit is 1 and this bit is 1, self-refresh starts immediately. When the RFSH bit is 1 and this bit is 0, auto-refresh starts according to the contents that are set in registers RTCSR, RTCNT, and RTCOR. | | | | | | 0: Auto-refresh is performed | | | | | | 1: Self-refresh is performed | | 9 | PDOWN | 0 | R/W | Power-Down Mode | | | | | | Specifies whether the SDRAM will enter the power-down mode after the access to the SDRAM. With this bit being set to 1, after the SDRAM is accessed, the CKE signal is driven low and the SDRAM enters the power-down mode. | | | | | | <ol><li>The SDRAM does not enter the power-down mode<br/>after being accessed.</li></ol> | | | | | | <ol> <li>The SDRAM enters the power-down mode after<br/>being accessed.</li> </ol> | | 8 | BACTV | 0 | R/W | Bank Active Mode | | | | | | Specifies to access whether in auto-precharge mode (using READA and WRITA commands) or in bank active mode (using READ and WRIT commands). | | | | | | <ol><li>O: Auto-precharge mode (using READA and WRITA commands)</li></ol> | | | | | | Bank active mode (using READ and WRIT commands) | | 7 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|------------|------------------|-----|-------------------------------------------------------------------| | 4, 3 | A3ROW[1:0] | 00 | R/W | Number of Bits of Row Address for Area 3 | | | | | | Specify the number of bits of the row address for area 3. | | | | | | 00: 11 bits | | | | | | 01: 12 bits | | | | | | 10: 13 bits | | | | | | 11: Reserved (setting prohibited) | | 2 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 1, 0 | A3COL[1:0] | 00 | R/W | Number of Bits of Column Address for Area 3 | | | | | | Specify the number of bits of the column address for area 3. | | | | | | 00: 8 bits | | | | | | 01: 9 bits | | | | | | 10: 10 bits | | - | | | | 11: Reserved (setting prohibited) | ## 7.4.5 Refresh Timer Control/Status Register (RTCSR) RTCSR specifies various items about refresh for SDRAM. When RTCSR is written, the upper 16 bits of the write data must be H'A55A to cancel write protection. The phase of the clock for incrementing the count in the refresh timer counter (RTCNT) is adjusted only by a power-on reset. Note that there is an error in the time until the compare match flag is set for the first time after the timer is started with the CKS[2:0] bits being set to a value other than B'000. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|-----|------|-----|---------|-----|-----|---------|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | - | - | - | - | - | CMF | CMIE | | CKS[2:0 | ] | | RRC[2:0 | ] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. | | 7 | CMF | 0 | R/W | Compare Match Flag | | | | | | Indicates that a compare match occurs between the refresh timer counter (RTCNT) and refresh time constant register (RTCOR). This bit is set or cleared in the following conditions. | | | | | | <ol> <li>Clearing condition: When 0 is written in CMF after<br/>reading out RTCSR during CMF = 1.</li> </ol> | | | | | | 1: Setting condition: When the condition RTCNT = RTCOR is satisfied. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | CMIE | 0 | R/W | Compare Match Interrupt Enable | | | | | | Enables or disables CMF interrupt requests when the CMF bit in RTCSR is set to 1. | | | | | | 0: Disables CMF interrupt requests. | | | | | | 1: Enables CMF interrupt requests. | | 5 to 3 | CKS[2:0] | 000 | R/W | Clock Select | | | | | | Select the clock input to count-up the refresh timer counter (RTCNT). | | | | | | 000: Stop the counting-up | | | | | | 001: Вф/4 | | | | | | 010: Βφ/16 | | | | | | 011: Bφ/64 | | | | | | 100: Bφ/256 | | | | | | 101: Βφ/1024 | | | | | | 110: Βφ/2048 | | | | | | 111: Вф/4096 | | 2 to 0 | RRC[2:0] | 000 | R/W | Refresh Count | | | | | | Specify the number of continuous refresh cycles, when the refresh request occurs after the coincidence of the values of the refresh timer counter (RTCNT) and the refresh time constant register (RTCOR). These bits can make the period of occurrence of refresh long. | | | | | | 000: 1 time | | | | | | 001: 2 times | | | | | | 010: 4 times | | | | | | 011: 6 times | | | | | | 100: 8 times | | | | | | 101: Reserved (setting prohibited) | | | | | | 110: Reserved (setting prohibited) | | - | | | | 111: Reserved (setting prohibited) | ## 7.4.6 Refresh Timer Counter (RTCNT) RTCNT is an 8-bit counter that increments using the clock selected by bits CKS[2:0] in RTCSR. When RTCNT matches RTCOR, RTCNT is cleared to 0. The value in RTCNT returns to 0 after counting up to 255. When the RTCNT is written, the upper 16 bits of the write data must be H'A55A to cancel write protection. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|--------|--------|--------|--------|--------|--------|--------|--------|----------|----------|----------|----------|----------|----------|----------|----------| | | - | - | - | - | - | - | - | - | - | - | - | - | - | 1 | - | - | | Initial value:<br>R/W: | 0<br>R | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | - | - | - | - | - | | | | | | | | | | Initial value:<br>R/W: | 0<br>R 0<br>R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------| | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. | | 7 to 0 | | All 0 | R/W | 8-Bit Counter | #### 7.4.7 Refresh Time Constant Register (RTCOR) RTCOR is an 8-bit register. When RTCOR matches RTCNT, the CMF bit in RTCSR is set to 1 and RTCNT is cleared to 0. When the RFSH bit in SDCR is 1, a memory refresh request is issued by this matching signal. This request is maintained until the refresh operation is performed. If the request is not processed when the next matching occurs, the previous request is ignored. When the CMIE bit in RTCSR is set to 1, an interrupt request is issued by this matching signal. The request continues to be output until the CMF bit in RTCSR is cleared. Clearing the CMF bit only affects the interrupt request and does not clear the refresh request. Therefore, a combination of refresh request and interval timer interrupt can be specified so that the number of refresh requests are counted by using timer interrupts while refresh is performed periodically. When RTCOR is written, the upper 16 bits of the write data must be H'A55A to cancel write protection. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | _ | _ | | | _ | _ | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------| | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. | | 7 to 0 | | All 0 | R/W | 8-Bit Counter | #### 7.4.8 Internal Bus Master Bus Priority Register (IBMPR) IBMPR is a 32-bit register that sets the bus priority for the internal bus masters excluding the CPU. If internal bus masters excluding the same CPU are set at different priority levels, the highest one will be effective. After an attempt to set internal bus masters in an overlapping manner, if some of them failed to be set, then these failing bus masters will not be able to acquire bus mastership. Rewriting this register while any of the A-DMAC (including F-DMAC), E-DMAC, and DMAC is operating is prohibited. When rewriting this register, make sure that none of the A-DMAC (including F-DMAC), E-DMAC, and DMAC is not started. For details, see section 7.5.9 (2), Access from the Side of the LSI Internal Bus Master. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |---------------|----|----|------|--------|----|----|------|--------|----|----|------|--------|----|----|----|----| | | _ | _ | 0P1F | R[1:0] | _ | _ | 0P2F | R[1:0] | _ | _ | 0P3F | R[1:0] | _ | _ | | _ | | Initial Value | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | R/W: | R | R | R/W | R/W | R | R | R/W | R/W | R | R | R/W | R/W | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | ı | - | | _ | _ | _ | _ | ı | | _ | | _ | _ | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31, 30 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 29, 28 | 0P1R[1:0] | 01 | R/W | Of the internal bus masters excluding the CPU (that is, A-DMAC (including F-DMAC), E-DMAC, and DMAC), set the internal bus master having the highest priority level. | | | | | | 00: No setting | | | | | | 01: A-DMAC (including F-DMAC) | | | | | | 10: E-DMAC | | | | | | 11: DMAC | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27, 26 | | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 25, 24 | 0P2R[1:0] | 10 | R/W | Of the internal bus masters excluding the CPU (that is, A-DMAC (including F-DMAC), E-DMAC, and DMAC), set the internal bus master having the second highest priority level. | | | | | | 00: No setting | | | | | | 01: A-DMAC (including F-DMAC) | | | | | | 10: E-DMAC | | | | | | 11: DMAC | | 23, 22 | | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 21, 20 | 0P3R[1:0] | 11 | R/W | Of the internal bus masters excluding the CPU (that is, A-DMAC (including F-DMAC), E-DMAC, and DMAC), set the internal bus master having the third highest priority level. | | | | | | 00: No setting | | | | | | 01: A-DMAC (including F-DMAC) | | | | | | 10: E-DMAC | | | | | | 11: DMAC | | 19 to 0 | | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | ## 7.5 Operation #### 7.5.1 Endian/Access Size and Data Alignment This LSI supports both big endian, in which the most significant byte (MSB) of data is that in the direction of the 0th address, and little endian, in which the least significant byte (LSB) is that in the direction of the 0th address. In the initial state after a power-on reset, all areas will be in big endian mode. Little endian cannot be selected for area 0. However, the endian of areas 3 to 6 can be changed by the setting in the CSnBCR register setting as long as the target space is not being accessed. Three data bus widths (8 bits, 16 bits, and 32 bits) are selectable for areas 3 to 6, allowing the connection of normal memory and of SRAM with byte selection. Two data bus widths (16 bits and 32 bits) are available for SDRAM. Two data bus widths (8 bits and 16 bits) are available for the PCMCIA interface. For MPX-I/O, the data bus width can be fixed to either 8 or 16 bits, or made selectable as 8 bits or 16 bits by one of the address lines. Data alignment is in accord with the data bus width selected for the device. This also means that four read operations are required to read longword data from a byte-width device. In this LSI, data alignment and conversion of data length is performed automatically between the respective interfaces. The data bus width of area 0 is fixed to 8 bits or 16 bits by the MD\_BW pin setting at a power-on reset. Tables 7.5 to 7.10 show the relationship between device data width and access unit. Note that the correspondence between addresses and strobe signals for the 32- and 16-bit bus widths depends on the endian setting. For example, with big endian and a 32-bit bus width, $\overline{\text{WE3}}$ corresponds to the 0th address, which is represented by $\overline{\text{WE0}}$ when little endian has been selected. Little endian cannot be selected for area 0. Note also that 32-bit and 16-bit accesses coincide in instruction fetching, therefore, it is difficult to allocate instruction to little endian area. Make sure to execute instruction in big endian area. Table 7.5 32-Bit External Device Access and Data Alignment in Big Endian | | | Data | Bus | | Strobe Signals | | | | | |----------------------|------------------|------------------|-----------------|----------------|----------------|---------------|---------------|---------------|--| | Operation | D31 to<br>D24 | D23 to<br>D16 | D15 to<br>D8 | D7 to D0 | WE3,<br>DQMUU | WE2,<br>DQMUL | WE1,<br>DQMLU | WEO,<br>DQMLL | | | Byte access at 0 | Data<br>7 to 0 | _ | _ | _ | Assert | _ | _ | _ | | | Byte access at 1 | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | _ | | | Byte access at 2 | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | | | Byte access at 3 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Word access at 0 | Data<br>15 to 8 | Data<br>7 to 0 | _ | | Assert | Assert | _ | _ | | | Word access<br>at 2 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | | Longword access at 0 | Data<br>31 to 24 | Data<br>23 to 16 | Data<br>15 to 8 | Data<br>7 to 0 | Assert | Assert | Assert | Assert | | Table 7.6 16-Bit External Device Access and Data Alignment in Big Endian | | | | Da | ata Bus | | | Strobe Signals | | | | |----------------------|------------------|---------------|---------------|------------------|------------------|---------------|----------------|---------------|---------------|--| | Operation | | D31 to<br>D24 | D23 to<br>D16 | D15 to<br>D8 | D7 to D0 | WE3,<br>DQMUU | WE2,<br>DQMUL | WE1,<br>DQMLU | WEO,<br>DQMLL | | | Byte access | at 0 | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | | | Byte access | at 1 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access | at 2 | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | | | Byte access | at 3 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Word access | s at 0 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | | Word access | s at 2 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | | Longword access at 0 | 1st<br>time at 0 | _ | _ | Data<br>31 to 24 | Data<br>23 to 16 | _ | _ | Assert | Assert | | | | 2nd<br>time at 2 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | Table 7.7 8-Bit External Device Access and Data Alignment in Big Endian | | | Data Bus | | | | Strobe Signals | | | | | |----------------------|------------------|---------------|---------------|--------------|------------------|----------------|---------------|---------------|---------------|--| | Operation | | D31 to<br>D24 | D23 to<br>D16 | D15 to<br>D8 | D7 to D0 | WE3,<br>DQMUU | WE2,<br>DQMUL | WE1,<br>DQMLU | WEO,<br>DQMLL | | | Byte access a | it 0 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access a | ıt 1 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access a | ıt 2 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access a | it 3 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Word access at 0 | 1st time<br>at 0 | _ | _ | _ | Data<br>15 to 8 | _ | _ | _ | Assert | | | | 2nd time<br>at 1 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Word access at 2 | 1st time<br>at 2 | _ | _ | _ | Data<br>15 to 8 | _ | _ | _ | Assert | | | | 2nd time<br>at 3 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Longword access at 0 | 1st time<br>at 0 | _ | _ | _ | Data<br>31 to 24 | _ | _ | _ | Assert | | | | 2nd time<br>at 1 | _ | _ | _ | Data<br>23 to 16 | _ | _ | _ | Assert | | | | 3rd time at 2 | _ | _ | _ | Data<br>15 to 8 | _ | _ | _ | Assert | | | | 4th time at 3 | _ | | | Data<br>7 to 0 | _ | _ | _ | Assert | | Table 7.8 32-Bit External Device Access and Data Alignment in Little Endian | | | Data | Bus | | Strobe Signals | | | | | |----------------------|------------------|------------------|-----------------|----------------|----------------|---------------|---------------|---------------|--| | Operation | D31 to<br>D24 | D23 to<br>D16 | D15 to<br>D8 | D7 to D0 | WE3,<br>DQMUU | WE2,<br>DQMUL | WE1,<br>DQMLU | WEO,<br>DQMLL | | | Byte access at 0 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access at 1 | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | | | Byte access at 2 | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | _ | | | Byte access at 3 | Data<br>7 to 0 | _ | _ | _ | Assert | _ | _ | _ | | | Word access at 0 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | | Word access at 2 | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | _ | _ | | | Longword access at 0 | Data<br>31 to 24 | Data<br>23 to 16 | Data<br>15 to 8 | Data<br>7 to 0 | Assert | Assert | Assert | Assert | | Table 7.9 16-Bit External Device Access and Data Alignment in Little Endian | | | Da | ata Bus | | Strobe Signals | | | | | |----------------------|------------------|---------------|---------------|------------------|------------------|---------------|---------------|---------------|---------------| | Operation | | D31 to<br>D24 | D23 to<br>D16 | D15 to<br>D8 | D7 to D0 | WE3,<br>DQMUU | WE2,<br>DQMUL | WE1,<br>DQMLU | WEO,<br>DQMLL | | Byte access | at 0 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | Byte access | at 1 | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | | Byte access | at 2 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | Byte access | at 3 | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | _ | | Word acces | s at 0 | _ | | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | Word access | s at 2 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | Longword access at 0 | 1st<br>time at 0 | _ | _ | Data<br>15 to 8 | Data<br>7 to 0 | _ | _ | Assert | Assert | | | 2nd<br>time at 2 | _ | _ | Data<br>31 to 24 | Data<br>23 to 16 | _ | _ | Assert | Assert | Table 7.10 8-Bit External Device Access and Data Alignment in Little Endian | | | Data Bus | | | | Strobe Signals | | | | | |----------------------|------------------|---------------|---------------|--------------|------------------|----------------|---------------|---------------|---------------|--| | Operation | | D31 to<br>D24 | D23 to<br>D16 | D15 to<br>D8 | D7 to D0 | WE3,<br>DQMUU | WE2,<br>DQMUL | WE1,<br>DQMLU | WEO,<br>DQMLL | | | Byte access a | Byte access at 0 | | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access a | t 1 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access at 2 | | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Byte access a | t 3 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | Word access at 0 | 1st time<br>at 0 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | | 2nd time<br>at 1 | _ | _ | _ | Data<br>15 to 8 | _ | _ | _ | Assert | | | Word access at 2 | 1st time<br>at 2 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | | 2nd time<br>at 3 | _ | _ | _ | Data<br>15 to 8 | _ | _ | _ | Assert | | | Longword access at 0 | 1st time<br>at 0 | _ | _ | _ | Data<br>7 to 0 | _ | _ | _ | Assert | | | | 2nd time<br>at 1 | _ | _ | _ | Data<br>15 to 8 | _ | _ | _ | Assert | | | | 3rd time at 2 | _ | _ | _ | Data<br>23 to 16 | _ | _ | _ | Assert | | | | 4th time at 3 | _ | _ | _ | Data<br>31 to 24 | _ | _ | _ | Assert | | ## 7.5.2 Normal Space Interface #### (1) Basic Timing For access to a normal space, this LSI uses strobe signal output in consideration of the fact that mainly static RAM will be directly connected. When using SRAM with a byte-selection pin, see section 7.5.6, SRAM Interface with Byte Selection. Figure 7.2 shows the basic timings of normal space access. A no-wait normal access is completed in two cycles. The $\overline{BS}$ signal is asserted for one cycle to indicate the start of a bus cycle. Figure 7.2 Normal Space Basic Access Timing (Access Wait 0) There is no access size specification when reading. The correct access start address is output in the least significant bit of the address, but since there is no access size specification, 32 bits are always read in case of a 32-bit device, and 16 bits in case of a 16-bit device. When writing, only the $\overline{\text{WEn}}$ signal for the byte to be written is asserted. It is necessary to output the data that has been read using $\overline{RD}$ when a buffer is established in the data bus. The $\overline{RD/WR}$ signal is in a read state (high output) when no access has been carried out. Therefore, care must be taken when controlling the external data buffer, to avoid collision. Figures 7.3 and 7.4 show the basic timings of normal space access. If the WM bit in CSnWCR is cleared to 0, a Tnop cycle is inserted after the CSn space access to evaluate the external wait (figure 7.3). If the WM bit in CSnWCR is set to 1, external waits are ignored and no Tnop cycle is inserted (figure 7.4). Figure 7.3 Continuous Access for Normal Space 1 Bus Width = 16 Bits, Longword Access, CSnWCR.WM Bit = 0 (Access Wait = 0, Cycle Wait = 0) Figure 7.4 Continuous Access for Normal Space 2 Bus Width = 16 Bits, Longword Access, CSnWCR.WM Bit = 1 (Access Wait = 0, Cycle Wait = 0) Figure 7.5 Example of 32-Bit Data-Width SRAM Connection Figure 7.6 Example of 16-Bit Data-Width SRAM Connection Figure 7.7 Example of 8-Bit Data-Width SRAM Connection ## 7.5.3 Access Wait Control Wait cycle insertion on a normal space access can be controlled by the settings of bits WR3 to WR0 in CSnWCR. It is possible for areas 4 and 5 to insert wait cycles independently in read access and in write access. Areas 0, 3, and 6 have common access wait for read cycle and write cycle. The specified number of Tw cycles are inserted as wait cycles in a normal space access shown in figure 7.8. Figure 7.8 Wait Timing for Normal Space Access (Software Wait Only) When the $\overline{WM}$ bit in CSnWCR is cleared to 0, the external wait input $\overline{WAIT}$ signal is also sampled. $\overline{WAIT}$ pin sampling is shown in figure 7.9. A 2-cycle wait is specified as a software wait. The $\overline{WAIT}$ signal is sampled on the falling edge of CKIO at the transition from the T1 or Tw cycle to the T2 cycle. Figure 7.9 Wait Cycle Timing for Normal Space Access (Wait Cycle Insertion Using WAIT Signal) ### The number of cycles from $\overline{CSn}$ assertion to $\overline{RD}$ , $\overline{WEn}$ assertion can be specified by setting bits SW1 and SW0 in CSnWCR. The number of cycles from $\overline{RD}$ , $\overline{WEn}$ negation to $\overline{CSn}$ negation can be specified by setting bits HW1 and HW0. Therefore, a flexible interface to an external device can be obtained. Figure 7.10 shows an example. A Th cycle and a Tf cycle are added before and after an ordinary cycle, respectively. In these cycles, $\overline{RD}$ and $\overline{WEn}$ are not asserted, while other signals are asserted. The data output is prolonged to the Tf cycle, and this prolongation is useful for devices with slow writing operations. Figure 7.10 CSn Assert Period Expansion #### 7.5.5 SDRAM Interface ### **(1) SDRAM Direct Connection** The SDRAM that can be connected to this LSI is a product that has 11/12/13 bits of row address, 8/9/10 bits of column address, 4 or less banks, and uses the A10 pin for setting precharge mode in read and write command cycles. The control signals for direct connection of SDRAM are RAS, CAS, RD/WR, DQMUU, DQMUL, DQMLU, DQMLL, CKE, and CS3. All the signals other than CS3 are common to all areas, and signals other than CKE are valid when $\overline{\text{CS2}}$ or $\overline{\text{CS3}}$ is asserted. SDRAM can be connected to up to 2 spaces. The data bus width of the area that is connected to SDRAM can be set to 32 or 16 bits. Burst read/single write (burst length 1) and burst read/burst write (burst length 1) are supported as the SDRAM operating mode. Commands for SDRAM can be specified by RAS, CAS, RD/WR, and specific address signals. These commands supports: - NOP - Auto-refresh (REF) - Self-refresh (SELF) - All banks pre-charge (PALL) - Specified bank pre-charge (PRE) - Bank active (ACTV) - Read (READ) - Read with pre-charge (READA) - Write (WRIT) - Write with pre-charge (WRITA) - Write mode register (MRS, EMRS) The byte to be accessed is specified by DQMUU, DQMUL, DQMLU, and DQMLL. Reading or writing is performed for a byte whose corresponding DQMxx is low. For details on the relationship between DQMxx and the byte to be accessed, see section 7.5.1, Endian/Access Size and Data Alignment. Figures 7.11 and 7.12 show examples of the connection of the SDRAM with the LSI. Figure 7.11 Example of 32-Bit Data Width SDRAM Connection Figure 7.12 Example of 16-Bit Data Width SDRAM Connection # (2) Address Multiplexing An address multiplexing is specified so that SDRAM can be connected without external multiplexing circuitry according to the setting of bits BSZ[1:0] in CSnBCR, bits A2ROW[1:0], and A2COL[1:0], A3ROW[1:0], and A3COL[1:0] in SDCR. Tables 7.11 to 7.16 show the relationship between the settings of bits BSZ[1:0], A2ROW[1:0], A2COL[1:0], A3ROW[1:0], and A3COL[1:0] and the bits output at the address pins. Do not specify those bits in the manner other than this table, otherwise the operation of this LSI is not guaranteed. A25 to A18 are not multiplexed and the original values of address are always output at these pins. When the data bus width is 16 bits (BSZ1 and BSZ0 = B'10), A0 of SDRAM specifies a word address. Therefore, connect this A0 pin of SDRAM to the A1 pin of the LSI; the A1 pin of SDRAM to the A2 pin of the LSI, and so on. When the data bus width is 32 bits (BSZ1 and BSZ0 = B'11), the A0 pin of SDRAM specifies a longword address. Therefore, connect this A0 pin of SDRAM to the A2 pin of the LSI; the A1 pin of SDRAM to the A3 pin of the LSI, and so on. Table 7.11 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (1)-1 |--| | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | | | |---------------------------|----------------------------------|----------------------------------|--------------|-----------------------------| | 11 (32 bits) | 00 (11 bits) | 00 (8 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A25 | A17 | | Unused | | A16 | A24 | A16 | _ | | | A15 | A23 | A15 | <del>_</del> | | | A14 | A22* <sup>2</sup> * <sup>3</sup> | A22* <sup>2</sup> * <sup>3</sup> | A12 (BA1) | Specifies bank | | A13 | A21*2 | A21* <sup>2</sup> | A11 (BA0) | <del></del> | | A12 | A20 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A11 | A19 | A11 | A9 | Address | | A10 | A18 | A10 | A8 | | | A9 | A17 | A9 | A7 | <del></del> | | A8 | A16 | A8 | A6 | <del></del> | | A7 | A15 | A7 | A5 | <del></del> | | A6 | A14 | A6 | A4 | <del></del> | | A5 | A13 | A5 | A3 | <del></del> | | A4 | A12 | A4 | A2 | | | A3 | A11 | A3 | A1 | | | A2 | A10 | A2 | A0 | | | A1 | A9 | A1 | | Unused | | A0 | A8 | A0 | _ | | 64-Mbit product (512 Kwords × 32 bits × 4 banks, column 8 bits product): 1 16-Mbit product (512 Kwords $\times$ 16 bits $\times$ 2 banks, column 8 bits product): 2 Notes: 1. L/H is a bit used in the command specification; it is fixed at L or H according to the access mode. - 2. Bank address specification - 3. Applicable only to 64-bit products. Table 7.11 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (1)-2 | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | |---------------------------|-----------------------|--------------------------|-----------|-----------------------------| | 11 (32 bits) | 01 (12 bits) | 00 (8 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A25 | A17 | | Unused | | A16 | A24 | A16 | _ | | | A15 | A23*2 | A23* <sup>2</sup> | A13 (BA1) | Specifies bank | | A14 | A22*2 | A22*2 | A12 (BA0) | <del></del> | | A13 | A21 | A13 | A11 | Address | | A12 | A20 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A11 | A19 | A11 | A9 | Address | | A10 | A18 | A10 | A8 | | | A9 | A17 | A9 | A7 | <del></del> | | A8 | A16 | A8 | A6 | <del></del> | | A7 | A15 | A7 | A5 | | | A6 | A14 | A6 | A4 | | | A5 | A13 | A5 | A3 | | | A4 | A12 | A4 | A2 | | | A3 | A11 | A3 | A1 | <del></del> | | A2 | A10 | A2 | A0 | <del></del> | | A1 | A9 | A1 | | Unused | | A0 | A8 | A0 | _ | | 128-Mbit product (1 Mword × 32 bits × 4 banks, column 8 bits product): 1 64-Mbit product (1 Mword $\times$ 16 bits $\times$ 4 banks, column 8 bits product): 2 Notes: 1. L/H is a bit used in the command specification; it is fixed at L or H according to the access mode. - 2. Bank address specification - 3. Applicable only to 64-bit products. Table 7.12 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (2)-1 | | Setting | | | | |---------------------------|-----------------------|--------------------------|-----------|-----------------------------| | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | | 11 (32 bits) | 01 (12 bits) | 01 (9 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A26 | A17 | | Unused | | A16 | A25 | A16 | _ | | | A15 | A24*2 | A24* <sup>2</sup> | A13 (BA1) | Specifies bank | | A14 | A23*2 | A23*2 | A12 (BA0) | | | A13 | A22 | A13 | A11 | Address | | A12 | A21 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A11 | A20 | A11 | A9 | Address | | A10 | A19 | A10 | A8 | | | A9 | A18 | A9 | A7 | | | A8 | A17 | A8 | A6 | | | A7 | A16 | A7 | A5 | | | A6 | A15 | A6 | A4 | | | A5 | A14 | A5 | A3 | | | A4 | A13 | A4 | A2 | | | A3 | A12 | A3 | A1 | | | A2 | A11 | A2 | A0 | | | A1 | A10 | A1 | | Unused | Α9 Α0 256-Mbit product (2 Mwords $\times$ 32 bits $\times$ 4 banks, column 9 bits product): 1 Α0 128-Mbit product (2 Mwords $\times$ 16 bits $\times$ 4 banks, column 9 bits product): 2 Notes: 1. L/H is a bit used in the command specification; it is fixed at L or H according to the access mode. Table 7.12 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (2)-2 | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | | | |---------------------------|-----------------------|--------------------------|--------------|-----------------------------| | 11 (32 bits) | 01 (12 bits) | 10 (10 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A27 | A17 | | Unused | | A16 | A26 | A16 | <del>_</del> | | | A15 | A25* <sup>2</sup> | A25*2 | A13 (BA1) | Specifies bank | | A14 | A24* <sup>2</sup> | A24*2 | A12 (BA0) | | | A13 | A23 | A13 | A11 | Address | | A12 | A22 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A11 | A21 | A11 | A9 | Address | | A10 | A20 | A10 | A8 | | | A9 | A19 | A9 | A7 | | | A8 | A18 | A8 | A6 | | | A7 | A17 | A7 | A5 | | | A6 | A16 | A6 | A4 | | | A5 | A15 | A5 | A3 | | | A4 | A14 | A4 | A2 | | | A3 | A13 | A3 | A1 | | | A2 | A12 | A2 | A0 | | | A1 | A11 | A1 | | Unused | | A0 | A10 | A0 | _ | | 512-Mbit product (4 Mwords $\times$ 32 bits $\times$ 4 banks, column 10 bits product): 1 256-Mbit product (4 Mwords $\times$ 16 bits $\times$ 4 banks, column 10 bits product): 2 Notes: 1. L/H is a bit used in the command specification; it is fixed at L or H according to the access mode. Table 7.13 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (3) | S | e | tt | iı | n | a | |---|---|----|----|---|---| | | | | | | | | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | |---------------------------|-----------------------|--------------------------|-----------|-----------------------------| | 11 (32 bits) | 10 (13 bits) | 01 (9 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A26 | A17 | | Unused | | A16 | A25*2 | A25* <sup>2</sup> | A14 (BA1) | Specifies bank | | A15 | A24* <sup>2</sup> | A24* <sup>2</sup> | A13 (BA0) | <del></del> | | A14 | A23 | A14 | A12 | Address | | A13 | A22 | A13 | A11 | | | A12 | A21 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A11 | A20 | A11 | A9 | Address | | A10 | A19 | A10 | A8 | | | A9 | A18 | A9 | A7 | | | A8 | A17 | A8 | A6 | | | A7 | A16 | A7 | A5 | | | A6 | A15 | A6 | A4 | | | A5 | A14 | A5 | A3 | | | A4 | A13 | A4 | A2 | | | A3 | A12 | A3 | A1 | <del></del> | | A2 | A11 | A2 | A0 | <del></del> | | A1 | A10 | A1 | | Unused | | A0 | A9 | A0 | _ | | 512-Mbit product (4 Mwords $\times$ 32 bits $\times$ 4 banks, column 9 bits product): 1 256-Mbit product (4 Mwords × 16 bits × 4 banks, column 9 bits product): 2 Notes: 1. L/H is a bit used in the command specification; it is fixed at L or H according to the access mode. Table 7.14 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (4)-1 | Set | *** | าก | |-----|-----|----| | 961 | | ıч | | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | |---------------------------|-----------------------|--------------------------|--------------|-----------------------------| | 10 (16 bits) | 00 (11 bits) | 00 (8 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A25 | A17 | | Unused | | A16 | A24 | A16 | _ | | | A15 | A23 | A15 | <del>_</del> | | | A14 | A22 | A14 | <del>_</del> | | | A13 | A21* <sup>2</sup> | A21* <sup>2</sup> | A12 (BA1) | Specifies bank | | A12 | A20* <sup>2</sup> | A20* <sup>2</sup> | A11 (BA0) | | | A11 | A19 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A10 | A18 | A10 | A9 | Address | | A9 | A17 | A9 | A8 | | | A8 | A16 | A8 | A7 | <del></del> | | A7 | A15 | A7 | A6 | | | A6 | A14 | A6 | A5 | | | A5 | A13 | A5 | A4 | | | A4 | A12 | A4 | A3 | <del></del> | | A3 | A11 | A3 | A2 | <del></del> | | A2 | A10 | A2 | A1 | <del></del> | | A1 | A9 | A1 | A0 | <del></del> | | A0 | A8 | A0 | | Unused | 16-Mbit product (512 Kwords $\times$ 16 bits $\times$ 2 banks, column 8 bits product): 1 Notes: 1. L/H is a bit used in the command specification; it is fixed at low or high according to the access mode. Table 7.14 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (4)-2 | | Setting | | | | |---------------------------|-----------------------|--------------------------|--------------|-----------------------------| | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | | 10 (16 bits) | 01 (12 bits) | 00 (8 bits) | <del>_</del> | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A25 | A17 | | Unused | | A16 | A24 | A16 | _ | | | A15 | A23 | A15 | <del></del> | | | A14 | A22*2 | A22*2 | A13 (BA1) | Specifies bank | | A13 | A21*2 | A21* <sup>2</sup> | A12 (BA0) | <del></del> | | A12 | A20 | A12 | A11 | Address | | A11 | A19 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A10 | A18 | A10 | A9 | Address | | A9 | A17 | A9 | A8 | <del></del> | | A8 | A16 | A8 | A7 | <del></del> | | A7 | A15 | A7 | A6 | <del></del> | | A6 | A14 | A6 | A5 | <del></del> | | A5 | A13 | A5 | A4 | <del></del> | | A4 | A12 | A4 | A3 | | | A3 | A11 | A3 | A2 | | A10 Α9 Α8 A2 Α1 Α0 64-Mbit product (1 Mword × 16 bits × 4 banks, column 8 bits product): 1 Α2 Α1 Α0 Notes: 1. L/H is a bit used in the command specification; it is fixed at L or H according to the access mode. Α1 Α0 2. Bank address specification Unused Table 7.15 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (5)-1 | <b>~</b> | • | |----------|-----| | Sett | าทก | | - | | | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | |---------------------------|-----------------------|--------------------------|-----------|-----------------------------| | 10 (16 bits) | 01 (12 bits) | 01 (9 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A26 | A17 | | Unused | | A16 | A25 | A16 | _ | | | A15 | A24 | A15 | <u> </u> | | | A14 | A23*2 | A23*2 | A13 (BA1) | Specifies bank | | A13 | A22*2 | A22*2 | A12 (BA0) | | | A12 | A21 | A12 | A11 | Address | | A11 | A20 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A10 | A19 | A10 | A9 | Address | | A9 | A18 | A9 | A8 | | | A8 | A17 | A8 | A7 | | | A7 | A16 | A7 | A6 | | | A6 | A15 | A6 | A5 | | | A5 | A14 | A5 | A4 | | | A4 | A13 | A4 | A3 | <del></del> | | A3 | A12 | A3 | A2 | <del></del> | | A2 | A11 | A2 | A1 | | | A1 | A10 | A1 | A0 | <del></del> | | A0 | A9 | A0 | | Unused | 128-Mbit product (2 Mwords $\times$ 16 bits $\times$ 4 banks, column 9 bits product): 1 Notes: 1. L/H is a bit used in the command specification; it is fixed at low or high according to the access mode. Table 7.15 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (5)-2 Setting | Setting | | | | | |---------------------------|-----------------------|--------------------------|--------------|-----------------------------| | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | | 10 (16 bits) | 01 (12 bits) | 10 (10 bits) | <del>_</del> | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A27 | A17 | | Unused | | A16 | A26 | A16 | _ | | | A15 | A25 | A15 | <del></del> | | | A14 | A24* <sup>2</sup> | A24*2 | A13 (BA1) | Specifies bank | | A13 | A23*2 | A23*2 | A12 (BA0) | | | A12 | A22 | A12 | A11 | Address | | A11 | A21 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A10 | A20 | A10 | A9 | Address | | A9 | A19 | A9 | A8 | | | A8 | A18 | A8 | A7 | | | A7 | A17 | A7 | A6 | | | A6 | A16 | A6 | A5 | | | A5 | A15 | A5 | A4 | | Example of connected memory A14 A13 A12 A11 A10 Α4 А3 A2 Α1 Α0 256-Mbit product (4 Mwords × 16 bits × 4 banks, column 10 bits product): 1 Α4 А3 Α2 Α1 Α0 Notes: 1. L/H is a bit used in the command specification; it is fixed at low or high according to the access mode. A3 A2 Α1 Α0 2. Bank address specification Unused Table 7.16 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (6)-1 | Setting | ~ | |----------|---| | Settilli | ч | | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | |---------------------------|-----------------------|--------------------------|-----------|-----------------------------| | 10 (16 bits) | 10 (13 bits) | 01 (9 bits) | _ | | | Output Pin of<br>This LSI | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A26 | A17 | | Unused | | A16 | A25 | A16 | _ | | | A15 | A24*2 | A24* <sup>2</sup> | A14 (BA1) | Specifies bank | | A14 | A23*2 | A23*2 | A13 (BA0) | <del></del> | | A13 | A22 | A13 | A12 | Address | | A12 | A21 | A12 | A11 | | | A11 | A20 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A10 | A19 | A10 | A9 | Address | | A9 | A18 | A9 | A8 | | | A8 | A17 | A8 | A7 | | | A7 | A16 | A7 | A6 | | | A6 | A15 | A6 | A5 | | | A5 | A14 | A5 | A4 | | | A4 | A13 | A4 | A3 | | | A3 | A12 | A3 | A2 | | | A2 | A11 | A2 | A1 | | | A1 | A10 | A1 | A0 | | | A0 | A9 | A0 | | Unused | 256-Mbit product (4 Mwords $\times$ 16 bits $\times$ 4 banks, column 9 bits product): 1 Notes: 1. L/H is a bit used in the command specification; it is fixed at low or high according to the access mode. Table 7.16 Relationship between BSZ[1:0], A3ROW[1:0], A3COL[1:0], and Address Multiplex Output (6)-2 Setting | | 9 | | | | |--------------|-----------------------|--------------------------|-------------|-----------------------------| | BSZ[1:0] | A3ROW[1:0] | A3COL[1:0] | _ | | | 10 (16 bits) | 10 (13 bits) | 10 (10 bits) | _ | | | | Row Address<br>Output | Column Address<br>Output | SDRAM Pin | Function | | A17 | A27 | A17 | | Unused | | A16 | A26 | A16 | <del></del> | | | A15 | A25*2 | A25* <sup>2</sup> | A14 (BA1) | Specifies bank | | A14 | A24*2 | A24* <sup>2</sup> | A13 (BA0) | | | A13 | A23 | A13 | A12 | Address | | A12 | A22 | A12 | A11 | | | A11 | A21 | L/H* <sup>1</sup> | A10/AP | Specifies address/precharge | | A10 | A20 | A10 | A9 | Address | | A9 | A19 | A9 | A8 | | | A8 | A18 | A8 | A7 | | | A7 | A17 | A7 | A6 | | | A6 | A16 | A6 | A5 | | Example of connected memory A15 A14 A13 A12 A11 A10 A5 Α4 А3 A2 Α1 Α0 512-Mbit product (8 Mwords × 16 bits × 4 banks, column 10 bits product): 1 Α5 Α4 А3 Α2 Α1 Α0 Notes: 1. L/H is a bit used in the command specification; it is fixed at low or high according to the access mode. Α4 А3 A2 Α1 Α0 2. Bank address specification Unused # (3) Burst Read A burst read occurs in the following cases with this LSI. - Access size in reading is larger than data bus width. - 16-byte transfer in cache miss. - 16-byte transfer by DMAC This LSI always accesses the SDRAM with burst length 1. For example, read access of burst length 1 is performed consecutively 4 times to read 16-byte continuous data from the SDRAM that is connected to a 32-bit data bus. This access is called the burst read with the burst number 4. Table 7.17 shows the relationship between the access size and the number of bursts. Table 7.17 Relationship between Access Size and Number of Bursts | Bus Width | Access Size | Number of Bursts | |-----------|-------------|------------------| | 16 bits | 8 bits | 1 | | | 16 bits | 1 | | | 32 bits | 2 | | | 16 bits | 8 | | 32 bits | 8 bits | 1 | | | 16 bits | 1 | | | 32 bits | 1 | | | 16 bytes* | 4 | Figures 7.13 and 7.14 show a timing chart in burst read. In burst read, an ACTV command is output in the Tr cycle, the READ command is issued in the Tc1, Tc2, and Tc3 cycles, the READA command is issued in the Tc4 cycle, and the read data is received at the rising edge of the external clock (CKIO) in the Td1 to Td4 cycles. The Tap cycle is used to wait for the completion of an auto-precharge induced by the READA command in the SDRAM. In the Tap cycle, a new command will not be issued to the same bank. However, access to another CS space or another bank in the same SDRAM space is enabled. The number of Tap cycles is specified by the WTRP1 and WTRP0 bits in CS3WCR. In this LSI, wait cycles can be inserted by specifying each bit in CS3WCR to connect the SDRAM in variable frequencies. Figure 7.14 shows an example in which wait cycles are inserted. The number of cycles from the Tr cycle where the ACTV command is output to the Tc1 cycle where the READ command is output can be specified using the WTRCD1 and WTRCD0 bits in CS3WCR. If the WTRCD1 and WTRCD0 bits specify one cycles or more, a Trw cycle where the NOT command is issued is inserted between the Tr cycle and Tc1 cycle. The number of cycles from the Tc1 cycle where the READ command is output to the Td1 cycle where the read data is latched can be specified for the CS2 and CS3 spaces independently, using the A2CL1 and A2CL0 bits in CS2WCR or the A3CL1 and A3CL0 bits in CS3WCR and WTRCD0 bit in CS3WCR. The number of cycles from Tc1 to Td1 corresponds to the SDRAM CAS latency. The CAS latency for the SDRAM is normally defined as up to three cycles. However, the CAS latency in this LSI can be specified as 1 to 4 cycles. This CAS latency can be achieved by connecting a latch circuit between this LSI and the SDRAM. A Tde cycle is an idle cycle required to transfer the read data into this LSI and occurs once for every burst read or every single read. Figure 7.13 Burst Read Basic Timing (CAS Latency 1, Auto Pre-Charge) Figure 7.14 Burst Read Wait Specification Timing (CAS Latency 2, WTRCD[1:0] = 1 Cycle, Auto Pre-Charge) # (4) Single Read A read access ends in one cycle when data exists in a cache-disabled space and the data bus width is larger than or equal to the access size. As the SDRAM is set to the burst read with the burst length 1, only the required data is output. A read access that ends in one cycle is called single read. Figure 7.15 shows the single read basic timing. Figure 7.15 Basic Timing for Single Read (CAS Latency 1, Auto Pre-Charge) ## (5) Burst Write A burst write occurs in the following cases in this LSI. - Access size in writing is larger than data bus width. - Write-back of the cache - 16-byte transfer in DMAC This LSI always accesses SDRAM with burst length 1. For example, write access of burst length 1 is performed continuously 4 times to write 16-byte continuous data to the SDRAM that is connected to a 32-bit data bus. This access is called burst write with the burst number 4. The relationship between the access size and the number of bursts is shown in table 7.17. Figure 7.16 shows a timing chart for burst writes. In burst write, an ACTV command is output in the Tr cycle, the WRIT command is issued in the Tc1, Tc2, and Tc3 cycles, and the WRITA command is issued to execute an auto-precharge in the Tc4 cycle. In the write cycle, the write data is output simultaneously with the write command. After the write command with the auto-precharge is output, the Trw1 cycle that waits for the auto-precharge initiation is followed by the Tap cycle that waits for completion of the auto-precharge induced by the WRITA command in the SDRAM. Between the Trwl and the Tap cycle, a new command will not be issued to the same bank. However, access to another CS space or another bank in the same SDRAM space is enabled. The number of Trw1 cycles is specified by the TRWL1 and TRWL0 bits in CS3WCR. The number of Tap cycles is specified by the WTRP1 and WTRP0 bits in CS3WCR. Figure 7.16 Basic Timing for Burst Write (Auto Pre-Charge) ### Single Write (6) A write access ends in one cycle when data is written in a cache-disabled space and the data bus width is larger than or equal to access size. As a single write or burst write with burst length 1 is set in SDRAM, only the required data is output. The write access that ends in one cycle is called single write. Figure 7.17 shows the single write basic timing. Figure 7.17 Single Write Basic Timing (Auto-Precharge) ### (7) Bank Active The SDRAM bank function can be used to support high-speed access to the same row address. When the BACTV bit in SDCR is 1, access is performed using commands without auto-precharge (READ or WRIT). This function is called bank-active function. When the bank-active function is used, precharging is not performed when the access ends. When accessing the same row address in the same bank, it is possible to issue the READ or WRIT command immediately, without issuing an ACTV command. As SDRAM is internally divided into several banks, it is possible to activate one row address in each bank. If the next access is to a different row address, a PRE command is first issued to precharge the relevant bank, then when precharging is completed, the access is performed by issuing an ACTV command followed by a READ or WRIT command. If this is followed by an access to a different row address, the access time will be longer because of the precharging performed after the access request is issued. The number of cycles between issuance of the PRE command and the ACTV command is determined by the WTRP1 and WTPR0 bits in CS3WCR. In a write, when an auto-precharge is performed, a command cannot be issued to the same bank for a period of Trwl + Tap cycles after issuance of the WRITA command. When bank active mode is used, READ or WRIT commands can be issued successively if the row address is the same. The number of cycles can thus be reduced by Trwl + Tap cycles for each write. There is a limit on tRAS, the time for placing each bank in the active state. If there is no guarantee that there will not be a cache hit and another row address will be accessed within the period in which this value is maintained by program execution, it is necessary to set auto-refresh and set the refresh cycle to no more than the maximum value of tRAS. A burst read cycle without auto-precharge is shown in figure 7.18, a burst read cycle for the same row address in figure 7.19, and a burst read cycle for different row addresses in figure 7.20. Similarly, a burst write cycle without auto-precharge is shown in figure 7.21, a burst write cycle for the same row address in figure 7.22, and a burst write cycle for different row addresses in figure 7.23. In figure 7.19, a Tnop cycle in which no operation is performed is inserted before the Tc cycle that issues the READ command. The Tnop cycle is inserted to acquire two cycles of CAS latency for the DQMxx signal that specifies the read byte in the data read from the SDRAM. If the CAS latency is specified as two cycles or more, the Tnop cycle is not inserted because the two cycles of latency can be acquired even if the DQMxx signal is asserted after the Tc cycle. When bank active mode is set, if only access cycles to the respective banks in the area 3 space are considered, as long as access cycles to the same row address continue, the operation starts with the cycle in figure 7.18 or 7.21, followed by repetition of the cycle in figure 7.19 or 7.22. An access to a different area during this time has no effect. If there is an access to a different row address in the bank active state, after this is detected the bus cycle in figure 7.20 or 7.23 is executed instead of that in figure 7.19 or 7.22. In bank active mode, too, all banks become inactive after a refresh cycle or after the bus is released as the result of bus arbitration. Figure 7.18 Burst Read Timing (Bank Active, Different Bank, CAS Latency 1) Figure 7.19 Burst Read Timing (Bank Active, Same Row Addresses in the Same Bank, CAS Latency 1) Figure 7.20 Burst Read Timing (Bank Active, Different Row Addresses in the Same Bank, CAS Latency 1) Figure 7.21 Single Write Timing (Bank Active, Different Bank) Figure 7.22 Single Write Timing (Bank Active, Same Row Addresses in the Same Bank) Figure 7.23 Single Write Timing (Bank Active, Different Row Addresses in the Same Bank) # (8) Refreshing This LSI has a function for controlling SDRAM refreshing. Auto-refreshing can be performed by clearing the RMODE bit to 0 and setting the RFSH bit to 1 in SDCR. A continuous refreshing can be performed by setting the RRC2 to RRC0 bits in RTCSR. If SDRAM is not accessed for a long period, self-refresh mode, in which the power consumption for data retention is low, can be activated by setting both the RMODE bit and the RFSH bit to 1. ## (a) Auto-refreshing Refreshing is performed at intervals determined by the input clock selected by bits CKS2 to CKS0 in RTCSR, and the value set by in RTCOR. The value of bits CKS2 to CKS0 in RTCOR should be set so as to satisfy the refresh interval stipulation for the SDRAM used. First make the settings for RTCOR, RTCNT, and the RMODE and RFSH bits in SDCR, then make the CKS2 to CKS0 and RRC2 to RRC0 settings. When the clock is selected by bits CKS2 to CKS0, RTCNT starts counting up from the value at that time. The RTCNT value is constantly compared with the RTCOR value, and if the two values are the same, a refresh request is generated and an autorefresh is performed for the number of times specified by the RRC2 to RRC0. At the same time, RTCNT is cleared to zero and the count-up is restarted. Figure 7.24 shows the auto-refresh cycle timing. After starting, the auto refreshing, PALL command is issued in the Tp cycle to make all the banks to pre-charged state from active state when some bank is being pre-charged. Then REF command is issued in the Trr cycle after inserting idle cycles of which number is specified by the WTRP1 and WTRP0 bits in CS3WCR. A new command is not issued for the duration of the number of cycles specified by the WTRC1 and WTRC0 bits in CS3WCR after the Trr cycle. The WTRC1 and WTRC0 bits must be set so as to satisfy the SDRAM refreshing cycle time stipulation (tRC). An idle cycle is inserted between the Tp cycle and Trr cycle when the setting value of the WTRP1 and WTRP0 bits in CS3WCR is longer than or equal to 1 cycle. Figure 7.24 Auto-Refresh Timing # (b) Self-refreshing Self-refresh mode in which the refresh timing and refresh addresses are generated within the SDRAM. Self-refreshing is activated by setting both the RMODE bit and the RFSH bit in SDCR to 1. After starting the self-refreshing, PALL command is issued in Tp cycle after the completion of the pre-charging bank. A SELF command is then issued after inserting idle cycles of which number is specified by the WTRP1 and WTRP0 bits in CS3WSR. SDRAM cannot be accessed while in the self-refresh state. Self-refresh mode is cleared by clearing the RMODE bit to 0. After self-refresh mode has been cleared, command issuance is disabled for the number of cycles specified by the WTRC1 and WTRC0 bits in CS3WCR. Self-refresh timing is shown in figure 7.25. Settings must be made so that self-refresh clearing and data retention are performed correctly, and auto-refreshing is performed at the correct intervals. When self-refreshing is activated from the state in which auto-refreshing is set, or when exiting standby mode other than through a power-on reset, auto-refreshing is restarted if the RFSH bit is set to 1 and the RMODE bit is cleared to 0 when self-refresh mode is cleared. If the transition from clearing of self-refresh mode to the start of auto-refreshing takes time, this time should be taken into consideration when setting the initial value of RTCNT. Making the RTCNT value 1 less than the RTCOR value will enable refreshing to be started immediately. After self-refreshing has been set, the self-refresh state continues even if the chip standby state is entered using the LSI standby function, and is maintained even after recovery from standby mode due to an interrupt. Note that the necessary signals such as CKE must be driven even in standby state by setting the HIZCNT bit in CMNCR to 1. In case of a power-on reset, the bus state controller's registers are initialized, and therefore the self-refresh state is cleared. Figure 7.25 Self-Refresh Timing # (9) Relationship between Refresh Requests and Bus Cycles If a refresh request occurs during bus cycle execution, the refresh cycle must wait for the bus cycle to be completed. If a new refresh request occurs while waiting for the previous refresh request, the previous refresh request is deleted. To refresh correctly, a bus cycle longer than the refresh interval must be prevented from occurring. ## (10) Power-Down Mode If the PDOWN bit in SDCR is set to 1, the SDRAM is placed in power-down mode by bringing the CKE signal to the low level in the non-access cycle. This power-down mode can effectively lower the power consumption in the non-access cycle. However, please note that if an access occurs in power-down mode, a cycle of overhead occurs because a cycle is needed to assert the CKE in order to cancel the power-down mode. Figure 7.26 shows the access timing in power-down mode. Figure 7.26 Power-Down Mode Access Timing # (11) Power-On Sequence In order to use SDRAM, mode setting must first be made for SDRAM after waiting for $100 \,\mu s$ or a longer period after powering on. This $100 - \mu s$ or longer period should be obtained by a power-on reset generating circuit or software. To perform SDRAM initialization correctly, the bus state controller registers must first be set, followed by a write to the SDRAM mode register. In SDRAM mode register setting, the address signal value at that time is latched by a combination of the $\overline{CSn}$ , $\overline{RAS}$ , $\overline{CAS}$ , and $\overline{RD/WR}$ signals. If the value to be set is X, the bus state controller provides for value X to be written to the SDRAM mode register by performing a write to address H'FFFC5000 + X for area 3 SDRAM. In this operation the data is ignored, but the mode write is performed as a byte-size access. To set burst read/single write, CAS latency 2 to 3, wrap type = sequential, and burst length 1 supported by the LSI, arbitrary data is written in a byte-size access to the addresses shown in table 7.18. In this time 0 is output at the external address pins of A12 or later. Table 7.18 Access Address in SDRAM Mode Register Write Setting for Area 3 Burst read/single write (burst length 1): | Data Bus Width | CAS Latency | Access Address | External Address Pin | |----------------|-------------|----------------|----------------------| | 16 bits | 2 | H'FFFC5440 | H'0000440 | | | 3 | H'FFFC5460 | H'0000460 | | 32 bits | 2 | H'FFFC5880 | H'0000880 | | | 3 | H'FFFC58C0 | H'00008C0 | Burst read/burst write (burst length 1): | Data Bus Width | CAS Latency | Access Address | External Address Pin | |----------------|-------------|----------------|----------------------| | 16 bits | 2 | H'FFFC5040 | H'0000040 | | | 3 | H'FFFC5060 | H'0000060 | | 32 bits | 2 | H'FFFC5080 | H'0000080 | | | 3 | H'FFFC50C0 | H'00000C0 | Mode register setting timing is shown in figure 7.27. A PALL command (all bank pre-charge command) is firstly issued. A REF command (auto refresh command) is then issued 8 times. An MRS command (mode register write command) is finally issued. Idle cycles, of which number is specified by the WTRP1 and WTRP0 bits in CS3WCR, are inserted between the PALL and the first REF. Idle cycles, of which number is specified by the WTRC1 and WTRC0 bits in CS3WCR, are inserted between REF and REF, and between the 8th REF and MRS. Idle cycles, of which number is one or more, are inserted between the MRS and a command to be issued next. It is necessary to keep idle time of certain cycles for SDRAM before issuing PALL command after power-on. Refer to the manual of the SDRAM for the idle time to be needed. When the pulse width of the reset signal is longer than the idle time, mode register setting can be started immediately after the reset, but care should be taken when the pulse width of the reset signal is shorter than the idle time. Figure 7.27 SDRAM Mode Write Timing (Based on JEDEC) ## (12) Low-Power SDRAM The low-power SDRAM can be accessed using the same protocol as the normal SDRAM. The differences between the low-power SDRAM and normal SDRAM are that partial refresh takes place that puts only a part of the SDRAM in the self-refresh state during the self-refresh function, and that power consumption is low during refresh under user conditions such as the operating temperature. The partial refresh is effective in systems in which there is data in a work area other than the specific area can be lost without severe repercussions. The low-power SDRAM supports the extension mode register (EMRS) in addition to the mode registers as the normal SDRAM. This LSI supports issuing of the EMRS command. The EMRS command is issued according to the conditions specified in table below. For example, if data H'0YYYYYYY is written to address H'FFFC5XX0 in longword, the commands are issued to the CS3 space in the following sequence: PALL -> REF × 8 -> MRS -> EMRS. In this case, the MRS and EMRS issue addresses are H'0000XX0 and H'YYYYYYYY, respectively. If data H'1YYYYYYYY is written to address H'FFFC5XX0 in longword, the commands are issued to the CS3 space in the following sequence: PALL -> MRS -> EMRS. Table 7.19 Output Addresses when EMRS Command Is Issued | Command to be<br>Issued | Access<br>Address | Access Data | Write<br>Access<br>Size | MRS<br>Command<br>Issue Address | EMRS<br>Command<br>Issue Address | |-------------------------|-------------------|-------------|-------------------------|---------------------------------|----------------------------------| | CS3 MRS | H'FFFC5XX0 | H'****** | 16 bits | H'0000XX0 | _ | | CS3 MRS + EMRS | H'FFFC5XX0 | H'0YYYYYYY | 32 bits | H'0000XX0 | H'YYYYYYY | | (with refresh) | | | | | | | CS3 MRS + EMRS | H'FFFC5XX0 | H'1YYYYYYY | 32 bits | H'0000XX0 | H'YYYYYYY | | (without refresh) | | | | | | Figure 7.28 EMRS Command Issue Timing ## • Deep power-down mode The low-power SDRAM supports the deep power-down mode as a low-power consumption mode. In the partial self-refresh function, self-refresh is performed on a specific area. In the deep power-down mode, self-refresh will not be performed on any memory area. This mode is effective in systems where all of the system memory areas are used as work areas. If the RMODE bit in the SDCR is set to 1 while the DEEP and RFSH bits in the SDCR are set to 1, the low-power SDRAM enters the deep power-down mode. If the RMODE bit is cleared to 0, the CKE signal is pulled high to cancel the deep power-down mode. Before executing an access after returning from the deep power-down mode, the power-up sequence must be re-executed. Figure 7.29 Deep Power-Down Mode Transition Timing ### 7.5.6 SRAM Interface with Byte Selection The SRAM interface with byte selection is for access to an SRAM which has a byte-selection pin (WEn). This interface has 16-bit data pins and accesses SRAMs having upper and lower byte selection pins, such as UB and LB. When the BAS bit in CSnWCR is cleared to 0 (initial value), the write access timing of the SRAM interface with byte selection is the same as that for the normal space interface. While in read access of a byte-selection SRAM interface, the byte-selection signal is output from the $\overline{\text{WEn}}$ pin, which is different from that for the normal space interface. The basic access timing is shown in figure 7.30. In write access, data is written to the memory according to the timing of the byteselection pin (WEn). For details, please refer to the Data Sheet for the corresponding memory. If the BAS bit in CSnWCR is set to 1, the WEn pin and RD/WR pin timings change. Figure 7.31 shows the basic access timing. In write access, data is written to the memory according to the timing of the write enable pin (RD/WR). The data hold timing from RD/WR negation to data write must be acquired by setting the HW1 and HW0 bits in CSnWCR. Figure 7.32 shows the access timing when a software wait is specified. Figure 7.30 Basic Access Timing for SRAM with Byte Selection (BAS = 0) Figure 7.31 Basic Access Timing for SRAM with Byte Selection (BAS = 1) Figure 7.32 Wait Timing for SRAM with Byte Selection (BAS = 1) (SW[1:0] = 01, WR[3:0] = 0001, HW[1:0] = 01) Figure 7.33 Example of Connection with 32-Bit Data-Width SRAM with Byte Selection Figure 7.34 Example of Connection with 16-Bit Data-Width SRAM with Byte Selection ## 7.5.7 PCMCIA Interface With this LSI, areas 5 and 6 can be used for the IC memory card and I/O card interface defined in the JEIDA specifications version 4.2 (PCMCIA2.1 Rev. 2.1) by specifying bits TYPE[2:0] in CSnBCR (n = 5 and 6) to B'101. In addition, the bits SA[1:0] in CSnWCR (n = 5 and 6) assign the upper or lower 32 Mbytes of each area to IC memory card or I/O card interface. For example, if the bits SA1 and SA0 in CS5WCR are set to 1 and cleared to 0, respectively, the upper 32 Mbytes of area 5 are used for IC memory card interface and the lower 32 Mbytes are used for I/O card interface. When the PCMCIA interface is used, the bus size must be specified as 8 bits or 16 bits using the bits BSZ[1:0] in CS5BCR or CS6BCR. Figure 7.35 shows an example of connection between this LSI and a PCMCIA card. To enable hot swapping (insertion and removal of the PCMCIA card with the system power turned on), tri-state buffers must be connected between the LSI and the PCMCIA card. In the JEIDA and PCMCIA standards, operation in big endian mode is not clearly defined. Consequently, the provided PCMCIA interface in big endian mode is available only for this LSI. Figure 7.35 Example of PCMCIA Interface Connection ## (1) Basic Timing for Memory Card Interface Figure 7.36 shows the basic timing of the PCMCIA IC memory card interface. When areas 5 and 6 are specified as the PCMCIA interface, the bus is accessed with the IC memory card interface according to the SA[1:0] bit settings in CS5WCR and CS6WCR. If the external bus frequency (CKIO) increases, the setup times and hold times for the address pins (A25 to A0), card enable signals ( $\overline{CE1A}$ , $\overline{CE2A}$ , $\overline{CE1B}$ , $\overline{CE2B}$ ), and write data (D15 to D0) to the $\overline{RD}$ and $\overline{WE}$ signals become insufficient. To prevent this error, this LSI enables the setup times and hold times for areas 5 and 6 to be specified independently, using CS5WCR and CS6WCR. In the PCMCIA interface, as in the normal space interface, a software wait or hardware wait using the $\overline{WAIT}$ pin can be inserted. Figure 7.37 shows the PCMCIA memory bus wait timing. Figure 7.36 Basic Access Timing for PCMCIA Memory Card Interface Figure 7.37 Wait Timing for PCMCIA Memory Card Interface (TED[3:0] = B'0010, PCW[3:0] = B'0000, TEH[3:0] = B'0001, Hardware Wait = 1) A port is used to generate the REG signal that switches between the common memory and attribute memory. As shown in the example in figure 7.38, when the total memory space necessary for the common memory and attribute memory is 32 Mbytes or less, pin A24 can be used as the REG signal to allocate a 16-Mbyte common memory space and a 16-Mbyte attribute memory space. Figure 7.38 Example of PCMCIA Space Allocation (CS5WCR.SA[1:0] = B'10, CS6WCR.SA[1:0] = B'10) # (2) Basic Timing for I/O Card Interface Figures 7.39 and 7.40 show the basic timing for the PCMCIA I/O card interface. When accessing an I/O card through the PCMCIA interface, be sure to access the space as cache-disabled. Switching between I/O card and IC memory card interfaces in the respective address spaces is accomplished by the SA[1:0] bit settings in CS5WCR and CS6WCR. The $\overline{\text{IOIS16}}$ pin can be used for dynamic adjustment of the width of the I/O bus in access to an I/O card via the PCMCIA interface when little endian mode has been selected. When the bus width of area 5 or 6 is set to 16 bits and the $\overline{\text{IOIS16}}$ signal is driven high during a cycle of word-unit access to the I/O card bus, the bus width will be recognized as 8 bits and only 8 bits of data will be accessed during the current cycle of the I/O card bus. Operation will automatically continue with access to the remaining 8 bits of data. The IOIS16 signal is sampled on falling edges of the CKIO in Tpci0 as well as all Tpci0w cycles for which the TED3 to TED0 bits are set to 1.5 cycles or more, and the $\overline{\text{CE2A}}$ and $\overline{\text{CE2B}}$ signals are updated after 1.5 cycles of the CKIO signal from the sampling point of Tpci0. Ensure that the $\overline{\text{IOIS16}}$ signal is defined at all sampling points and does not change along the way. Set the TED3 to TED0 bits to satisfy the requirement of the PC card in use with regard to setup timing from $\overline{\text{ICIORD}}$ or $\overline{\text{ICIOWR}}$ to $\overline{\text{CE1}}$ or $\overline{\text{CE2}}$ . The basic waveforms for dynamic bus-size adjustment are shown in figure 7.40. Since the $\overline{IOIS16}$ signal is not supported in big endian mode, the $\overline{IOIS16}$ signal should be fixed to the low level when big endian mode has been selected. Figure 7.39 Basic Access Timing for PCMCIA I/O Card Interface Figure 7.40 Dynamic Bus-Size Adjustment Timing for PCMCIA I/O Card Interface (TED[3:0] = B'0010, PCW[3:0] = B'0000, TEH[3:0] = B'0001, Hardware Wait = 1) ### 7.5.8 Wait between Access Cycles As the operating frequency of LSIs becomes higher, the off-operation of the data buffer often collides with the next data access when the read operation from devices with slow access speed is completed. As a result of these collisions, the reliability of the device is low and malfunctions may occur. A function that avoids data collisions by inserting idle (wait) cycles between continuous access cycles has been newly added. The number of wait cycles between access cycles can be set by the WM bit in CSnWCR, bits IWW2 to IWW0, IWRWD2 to IWRWD0, IWRWS2 to IWRWS0, IWRRD2 to IWRRD0, and IWRRS2 to IWRRS 0 in CSnBCR, and bits DMAIW2 to DMAIW0 and DMAIWA in CMNCR. The conditions for setting the idle cycles between access cycles are shown below. - 1. Continuous access cycles are write-read or write-write - 2. Continuous access cycles are read-write for different spaces - 3. Continuous access cycles are read-write for the same space - 4. Continuous access cycles are read-read for different spaces - 5. Continuous access cycles are read-read for the same space - 6. Data output from an external device caused by DMA single address transfer is followed by data output from another device that includes this LSI (DMAIWA = 0) - 7. Data output from an external device caused by DMA single address transfer is followed by any type of access (DMAIWA = 1) For the specification of the number of idle cycles between access cycles described above, refer to the description of each register. Besides the idle cycles between access cycles specified by the registers, idle cycles must be inserted to interface with the internal bus or to obtain the minimum pulse width for a multiplexed pin (WEn). The following gives detailed information about the idle cycles and describes how to estimate the number of idle cycles. The number of idle cycles on the external bus from CSn negation to CSn or CSm assertion is described below. Here, CSn and CSm also include CE2A and CE2B for PCMCIA. There are eight conditions that determine the number of idle cycles on the external bus as shown in table 7.20. The effects of these conditions are shown in figure 7.41. Table 7.20 Conditions for Determining Number of Idle Cycles | No. | Condition | Description | Range | Note | |-----|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [1] | DMAIW[2:0] in<br>CMNCR | These bits specify the number of idle cycles for DMA single address transfer. This condition is effective only for single address transfer and generates idle cycles after the access is completed. | 0 to 12 | When 0 is specified for the number of idle cycles, the DACK signal may be asserted continuously. This causes a discrepancy between the number of cycles detected by the device with DACK and the DMAC transfer count, resulting in a malfunction. | | [2] | IW***[2:0] in<br>CSnBCR | These bits specify the number of idle cycles for access other than single address transfer. The number of idle cycles can be specified independently for each combination of the previous and next cycles. For example, in the case where reading CS3 space followed by reading other CS space, the bits IWRRD[2:0] in CS3BCR should be set to B'100 to specify six or more idle cycles. This condition is effective only for access cycles other than single address transfer and generates idle cycles after the access is completed. | 0 to 12 | Do not set 0 for the number of idle cycles between memory types which are not allowed to be accessed successively. | | [3] | SDRAM-related<br>bits in<br>CSnWCR | These bits specify precharge completion and startup wait cycles and idle cycles between commands for SDRAM access. This condition is effective only for SDRAM access and generates idle cycles after the access is completed | 0 to 3 | Specify these bits in accordance with the specification of the target SDRAM. | | [4] | WM in<br>CSnWCR | This bit enables or disables external WAIT pin input for the memory types other than SDRAM. When this bit is cleared to 0 (external WAIT enabled), one idle cycle is inserted to check the external WAIT pin input after the access is completed. When this bit is set to 1 (disabled), no idle cycle is generated. | 0 or 1 | | | No. | Condition | Description | Range | Note | |-----|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [5] | Read data<br>transfer cycle | One idle cycle is inserted after a read access is completed. This idle cycle is not generated for the first or middle cycles in divided access cycles. This is neither generated when the HM[1:0] bits in CSnWCR are not B'00. | 0 or 1 | One idle cycle is always<br>generated after a read cycle<br>with SDRAM or PCMCIA<br>interface. | | [6] | Internal bus idle cycles, etc. | External bus access requests from the CPU or DMAC and their results are passed through the internal bus. The external bus enters idle state during internal bus idle cycles or while a bus other than the external bus is being accessed. This condition is not effective for divided access cycles, which are generated by the BSC when the access size is larger than the external data bus width. | 0 or<br>larger | The number of internal bus idle cycles may not become 0 depending on the $I\phi$ :B $\phi$ clock ratio. Tables 7.21 and 7.22 show the relationship between the clock ratio and the minimum number of internal bus idle cycles. | | [7] | Write data wait cycles | During write access, a write cycle is executed on the external bus only after the write data becomes ready. This write data wait period generates idle cycles before the write cycle. Note that when the previous cycle is a write cycle and the internal bus idle cycles are shorter than the previous write cycle, write data can be prepared in parallel with the previous write cycle and therefore, no idle cycle is generated (write buffer effect). | 0 or 1 | For write → write or write → read access cycles, successive access cycles without idle cycles are frequently available due to the write buffer effect described in the left column. If successive access cycles without idle cycles are not allowed, specify the minimum number of idle cycles between access cycles through CSnBCR. | | [8] | Idle cycles<br>between<br>different<br>memory types | To ensure the minimum pulse width on the signal-multiplexed pins, idle cycles may be inserted before access after memory types are switched. For some memory types, idle cycles are inserted even when memory types are not switched. | 0 to 2.5 | The number of idle cycles depends on the target memory types. See table 7.23. | In the above conditions, a total of four conditions, that is, condition [1] or [2] (either one is effective), condition [3] or [4] (either one is effective), a set of conditions [5] to [7] (these are generated successively, and therefore the sum of them should be taken as one set of idle cycles), and condition [8] are generated at the same time. The maximum number of idle cycles among these four conditions become the number of idle cycles on the external bus. To ensure the minimum idle cycles, be sure to make register settings for condition [1] or [2]. Figure 7.41 Idle Cycle Conditions Table 7.21 Minimum Number of Idle Cycles on Internal Bus (CPU Operation) | Clask | Datia | /IA.DA\ | |-------|-------|---------| | CIUCK | nauo | (lo:Bo) | | <b>CPU Operation</b> | 8:1 | 6:1 | 4:1 | 3:1 | 2:1 | 1:1 | | |--------------------------|-----|-----|-----|-----|-----|-----|--| | $Write \to write$ | 1 | 1 | 2 | 2 | 2 | 3 | | | $Write \rightarrow read$ | 0 | 0 | 0 | 0 | 0 | 1 | | | $Read \to write$ | 1 | 1 | 2 | 2 | 2 | 3 | | | $Read \to read$ | 0 | 0 | 0 | 0 | 0 | 1 | | Table 7.22 Minimum Number of Idle Cycles on Internal Bus (DMAC Operation) ## **Transfer Mode** | <b>DMAC Operation</b> | Dual Address | Single Address | | |---------------------------|--------------|----------------|--| | $Write \rightarrow write$ | 0 | 2 | | | $Write \rightarrow read$ | 0 or 2 | 0 | | | $Read \rightarrow write$ | 0 | 0 | | | $Read \rightarrow read$ | 0 | 2 | | Notes: 1. The write → write and read → read columns in dual address transfer indicate the cycles in the divided access cycles. - 2. For the write → read cycles in dual address transfer, 0 means different channels are activated successively and 2 means when the same channel is activated successively. - The write → read and read → write columns in single address transfer indicate the case when different channels are activated successively. The "write" means transfer from a device with DACK to external memory and the "read" means transfer from external memory to a device with DACK. Table 7.23 Number of Idle Cycles Inserted between Access Cycles to Different Memory Types ### **Next Cycle** | Previous Cycle | SRAM | Byte SRAM (BAS = 0) | Byte SRAM (BAS = 1) | SDRAM | PCMCIA | |---------------------|------|---------------------|---------------------|-------|--------| | SRAM | 0 | 0 | 1 | 1 | 0 | | Byte SRAM (BAS = 0) | 0 | 0 | 1 | 1 | 0 | | Byte SRAM (BAS = 1) | 1 | 1 | 0 | 0 | 1 | | SDRAM | 1 | 1 | 0 | 0 | 1 | | PCMCIA | 0 | 0 | 1 | 1 | 0 | Figure 7.42 shows sample estimation of idle cycles between access cycles. In the actual operation, the idle cycles may become shorter than the estimated value due to the write buffer effect or may become longer due to internal bus idle cycles caused by stalling in the pipeline due to CPU instruction execution or CPU register conflicts. Please consider these errors when estimating the idle cycles. Sample estimation of the number of idle clock cycles (states) between cycles of bus access We consider CPU access for the transfer of data from the CS5 to the CS6 space. For this transfer, the sequence read from CS5 →read from CS5 →write to CS6 →write to CS6 ... is repeated. ### Condition 0 is specified as the number of idle cycles between CS5BCR and CS6BCR. WM bit in CS5WCR and CS6WCR = 1 (external WAIT\_pin disabled) HW[1:0] = 00 (no delay of CS negation) $I\phi:B\phi=4:1$ No other processing proceeds during the transfer. CS5 and CS6 are connected to SRAM for access in 32-bit units by a 32-bit-wide bus. The items that decide the number of idle cycles are estimated for the different transitions on between bus cycles. R indicates reading and W indicates writing in the table below. | Item | R→R | R→W | W→W | W→R | Note | |---------------------------------|-----|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1)/(2) | 0 | 0 | 0 | 0 | Since CSnBCR is set to 0 | | (3)/(4) | 0 | 0 | 0 | 0 | When the WM bit is set to 1 | | (5) | 1 | 1 | 0 | 0 | Generated after the read cycle | | (6) | 0 | 2 | 2 | 0 | See the description for Iφ:Βφ = 4:1 in table 7.21. | | (7) | 0 | 1 | 0 | 0 | The effect of the write buffer is that idle cycles are not generated the second time. | | (5)+(6)+(7) | 1 | 4 | 2 | 0 | | | (8) | 0 | 0 | 0 | 0 | Due to SRAM→SRAM | | Estimated number of idle cycles | 1 | 4 | 2 | 0 | Maximum value among (1)/(2), (3)/(4), (5)+(6)+(7), and (8) | | Actual number of idle cycles | 1 | 4 | 2 | 1 | The mismatch in the case of W→R is because the estimate of the number of idle cycles for item (6) was zero. Since a loop-decision instruction is actually executed here, an idle cycle is generated internally. | Figure 7.42 Comparison between Estimated Idle Cycles and Actual Value #### 7.5.9 Others #### **(1)** Reset The bus state controller (BSC) can be initialized completely only at power-on reset. At power-on reset, all signals are negated and data output buffers are turned off regardless of the bus cycle state after the internal reset is synchronized with the internal clock. All control registers are initialized. In standby, sleep, and manual reset, control registers of the bus state controller are not initialized. At manual reset, only the current bus cycle being executed is completed. Since the RTCNT continues counting up during manual reset signal assertion, a refresh request occurs to initiate the refresh cycle. #### **(2)** Access from the Side of the LSI Internal Bus Master There are three types of LSI internal buses: a CPU bus, internal bus, and peripheral bus. The CPU and cache memory are connected to the CPU bus. Internal bus masters other than the CPU and bus state controller are connected to the internal bus. Low-speed peripheral modules are connected to the peripheral bus. Internal memories other than the cache memory are connected bidirectionally to the CPU bus and internal bus. Access from the CPU bus to the internal bus is enabled but access from the internal bus to the cache bus is disabled. This gives rise to the following problems. On-chip bus masters such as DMAC other than the CPU can access internal memory other than the cache memory but cannot access the cache memory. If an on-chip bus master other than the CPU writes data to an external memory other than the cache, the contents of the external memory may differ from that of the cache memory. To prevent this problem, if the external memory whose contents is cached is written by an on-chip bus master other than the CPU, the corresponding cache memory should be purged by software. In a cache-enabled space, if the CPU initiates read access, the cache is searched. If the cache stores data, the CPU latches the data and completes the read access. If the cache does not store data, the CPU performs four contiguous longword read cycles to perform cache fill operations via the internal bus. If a cache miss occurs in byte or word operand access or at a branch to an odd word boundary (4n + 2), the CPU performs four contiguous longword access cycles to perform a cache fill operation on the external interface. For a cache-disabled space, the CPU performs access according to the actual access addresses. For an instruction fetch to an even word boundary (4n), the CPU performs longword access. For an instruction fetch to an odd word boundary (4n + 2), the CPU performs word access. For a read cycle of an on-chip peripheral module, the cycle is initiated through the internal bus and peripheral bus. The read data is sent to the CPU via the peripheral bus, internal bus, and CPU bus. In a write cycle for the cache-enabled space, the write cycle operation differs according to the cache write methods. In write-back mode, the cache is first searched. If data is detected at the address corresponding to the cache, the data is then re-written to the cache. In the actual memory, data will not be re-written until data in the corresponding address is re-written. If data is not detected at the address corresponding to the cache, the cache is modified. In this case, data to be modified is first saved to the internal buffer, 16-byte data including the data corresponding to the address is then read, and data in the corresponding access of the cache is finally modified. Following these operations, a write-back cycle for the saved 16-byte data is executed. In write-through mode, the cache is first searched. If data is detected at the address corresponding to the cache, the data is re-written to the cache simultaneously with the actual write via the internal bus. If data is not detected at the address corresponding to the cache, the cache is not modified but an actual write is performed via the internal bus. Since the bus state controller (BSC) incorporates a one-stage write buffer, the BSC can execute an access via the internal bus before the previous external bus cycle is completed in a write cycle. If the on-chip module is read or written after the external low-speed memory is written, the on-chip module can be accessed before the completion of the external low-speed memory write cycle. In read cycles, the CPU is placed in the wait state until read operation has been completed. To continue the process after the data write to the device has been completed, perform a dummy read to the same address to check for completion of the write before the next process to be executed. The write buffer of the BSC functions in the same way for an access by a bus master other than the CPU such as the DMAC. Accordingly, to perform dual address DMA transfers, the next read cycle is initiated before the previous write cycle is completed. Note, however, that if both the DMA source and destination addresses exist in external memory space, the next write cycle will not be initiated until the previous write cycle is completed. Changing the registers in the BSC while the write buffer is operating may disrupt correct write access. Therefore, do not change the registers in the BSC immediately after a write access. If this change becomes necessary, do it after executing a dummy read of the write data. In this LSI, the priority level applicable when there is a request for bus mastership for the internal bus from any of the internal bus masters excluding the CPU (that is, A-DMAC (including F-DMAC), E-DMAC, and DMAC) can be set in the register. When changing the priority level, rewrite the register after making sure that none of the A-DMAC (including F-DMAC), E-DMAC, and DMAC is started. # (3) On-Chip Peripheral Module Access To access an on-chip module register, two or more peripheral module clock $(P\phi)$ cycles are required. Care must be taken in system design. When the CPU writes data to the internal peripheral registers, the CPU performs the succeeding instructions without waiting for the completion of writing to registers. For example, a case is described here in which the system is transferring to the software standby mode for power savings. To make this transition, the SLEEP instruction must be performed after setting the STBY bit in the STBCR register to 1. However a dummy read of the STBCR register is required before executing the SLEEP instruction. If a dummy read is omitted, the CPU executes the SLEEP instruction before the STBY bit is set to 1, thus the system enters sleep mode not software standby mode. A dummy read of the STBCR register is indispensable to complete writing to the STBY bit. To reflect the change by internal peripheral registers while performing the succeeding instructions, execute a dummy read of registers to which write instruction is given and then perform the succeeding instructions. # Section 8 Direct Memory Access Controller (DMAC) The DMAC can be used in place of the CPU to perform high-speed transfers between external devices that have DACK (transfer request acknowledge signal), external memory, on-chip memory, memory-mapped external devices, and on-chip peripheral modules. #### 8.1 **Features** - Number of channels: Eight channels (channels 0 to 7) selectable Two channels (channels 0 and 1) can receive external requests. - 4-Gbyte physical address space - Data transfer unit is selectable: Byte, word (two bytes), longword (four bytes), and 16 bytes $(longword \times 4)$ - Maximum transfer count: 16,777,216 transfers (24 bits) - Address mode: Dual address mode and single address mode are supported. - Transfer requests - External request - On-chip peripheral module request - Auto request The following modules can issue on-chip peripheral module requests. - Six SCIF sources, two IIC3 sources, two CMT sources, two SSI sources, and two SDHI sources - Selectable bus modes - Cycle steal mode (normal mode and intermittent mode) - Burst mode - Selectable channel priority levels: The channel priority levels are selectable between fixed mode and round-robin mode. - Interrupt request: An interrupt request can be sent to the CPU on completion of half- or fulldata transfer. Through the HE and HIE bits in CHCR, an interrupt is specified to be issued to the CPU when half of the initially specified DMA transfer is completed. - External request detection: There are following four types of DREQ input detection. - Low level detection - High level detection - Rising edge detection - Falling edge detection - Transfer request acknowledge and transfer end signals: Active levels for DACK and TEND can be set independently. - Support of reload functions in DMA transfer information registers: DMA transfer using the same information as the current transfer can be repeated automatically without specifying the information again. Modifying the reload registers during DMA transfer enables next DMA transfer to be done using different transfer information. The reload function can be enabled or disabled in each channel and in each reload register. Figure 8.1 shows the block diagram of the DMAC. Figure 8.1 Block Diagram of DMAC # 8.2 Input/Output Pins The external pins for DMAC are described below. Table 8.1 lists the configuration of the pins that are connected to external bus. DMAC has pins for two channels (channels 0 and 1) for external bus use. **Table 8.1** Pin Configuration Page 296 of 1278 | Channel | Name | Abbreviation | I/O | Function | |---------|----------------------------------|--------------|-----|------------------------------------------------------------------------------| | 0 | DMA transfer request | DREQ0 | I | DMA transfer request input from an external device to channel 0 | | | DMA transfer request acknowledge | DACK0 | 0 | DMA transfer request acknowledge output from channel 0 to an external device | | 1 | DMA transfer request | DREQ1 | I | DMA transfer request input from an external device to channel 1 | | | DMA transfer request acknowledge | DACK1 | 0 | DMA transfer request acknowledge output from channel 1 to an external device | | 0 | DMA transfer end | TEND0 | 0 | DMA transfer end output for channel 0 | | 1 | DMA transfer end | TEND1 | 0 | DMA transfer end output for channel 1 | # **8.3** Register Descriptions The DMAC has the registers listed in table 8.2. There are four control registers and three reload registers for each channel, and one common control register is used by all channels. In addition, there is one extension resource selector per two channels. Each channel number is expressed in the register names, as in SAR\_0 for SAR in channel 0. **Table 8.2** Register Configuration | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------------------|--------------|-------|---------------|------------|----------------| | 0 | DMA source address register_0 | SAR_0 | R/W | H'00000000 | H'FFFE1000 | 16, 32 | | | DMA destination address register_0 | DAR_0 | R/W | H'00000000 | H'FFFE1004 | 16, 32 | | | DMA transfer count register_0 | DMATCR_0 | R/W | H'00000000 | H'FFFE1008 | 16, 32 | | | DMA channel control register_0 | CHCR_0 | R/W*1 | H'00000000 | H'FFFE100C | 8, 16, 32 | | | DMA reload source address register_0 | RSAR_0 | R/W | H'00000000 | H'FFFE1100 | 16, 32 | | | DMA reload destination address register_0 | RDAR_0 | R/W | H'00000000 | H'FFFE1104 | 16, 32 | | | DMA reload transfer count register_0 | RDMATCR_0 | R/W | H'00000000 | H'FFFE1108 | 16, 32 | | 1 | DMA source address register_1 | SAR_1 | R/W | H'00000000 | H'FFFE1010 | 16, 32 | | | DMA destination address register_1 | DAR_1 | R/W | H'00000000 | H'FFFE1014 | 16, 32 | | | DMA transfer count register_1 | DMATCR_1 | R/W | H'00000000 | H'FFFE1018 | 16, 32 | | | DMA channel control register_1 | CHCR_1 | R/W*1 | H'00000000 | H'FFFE101C | 8, 16, 32 | | | DMA reload source address register_1 | RSAR_1 | R/W | H'00000000 | H'FFFE1110 | 16, 32 | | | DMA reload destination address register_1 | RDAR_1 | R/W | H'00000000 | H'FFFE1114 | 16, 32 | | | DMA reload transfer count register_1 | RDMATCR_1 | R/W | H'00000000 | H'FFFE1118 | 16, 32 | | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------------------|--------------|-------|---------------|------------|----------------| | 2 | DMA source address register_2 | SAR_2 | R/W | H'00000000 | H'FFFE1020 | 16, 32 | | | DMA destination address register_2 | DAR_2 | R/W | H'00000000 | H'FFFE1024 | 16, 32 | | | DMA transfer count register_2 | DMATCR_2 | R/W | H'00000000 | H'FFFE1028 | 16, 32 | | | DMA channel control register_2 | CHCR_2 | R/W*1 | H'00000000 | H'FFFE102C | 8, 16, 32 | | | DMA reload source address register_2 | RSAR_2 | R/W | H'00000000 | H'FFFE1120 | 16, 32 | | | DMA reload destination address register_2 | RDAR_2 | R/W | H'00000000 | H'FFFE1124 | 16, 32 | | | DMA reload transfer count register_2 | RDMATCR_2 | R/W | H'00000000 | H'FFFE1128 | 16, 32 | | 3 | DMA source address register_3 | SAR_3 | R/W | H'00000000 | H'FFFE1030 | 16, 32 | | | DMA destination address register_3 | DAR_3 | R/W | H'00000000 | H'FFFE1034 | 16, 32 | | | DMA transfer count register_3 | DMATCR_3 | R/W | H'00000000 | H'FFFE1038 | 16, 32 | | | DMA channel control register_3 | CHCR_3 | R/W*1 | H'00000000 | H'FFFE103C | 8, 16, 32 | | | DMA reload source address register_3 | RSAR_3 | R/W | H'00000000 | H'FFFE1130 | 16, 32 | | | DMA reload destination address register_3 | RDAR_3 | R/W | H'00000000 | H'FFFE1134 | 16, 32 | | | DMA reload transfer count register_3 | RDMATCR_3 | R/W | H'00000000 | H'FFFE1138 | 16, 32 | | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------------------|--------------|-------|---------------|------------|----------------| | 4 | DMA source address register_4 | SAR_4 | R/W | H'00000000 | H'FFFE1040 | 16, 32 | | | DMA destination address register_4 | DAR_4 | R/W | H'00000000 | H'FFFE1044 | 16, 32 | | | DMA transfer count register_4 | DMATCR_4 | R/W | H'00000000 | H'FFFE1048 | 16, 32 | | | DMA channel control register_4 | CHCR_4 | R/W*1 | H'00000000 | H'FFFE104C | 8, 16, 32 | | | DMA reload source address register_4 | RSAR_4 | R/W | H'00000000 | H'FFFE1140 | 16, 32 | | | DMA reload destination address register_4 | RDAR_4 | R/W | H'00000000 | H'FFFE1144 | 16, 32 | | | DMA reload transfer count register_4 | RDMATCR_4 | R/W | H'00000000 | H'FFFE1148 | 16, 32 | | 5 | DMA source address register_5 | SAR_5 | R/W | H'00000000 | H'FFFE1050 | 16, 32 | | | DMA destination address register_5 | DAR_5 | R/W | H'00000000 | H'FFFE1054 | 16, 32 | | | DMA transfer count register_5 | DMATCR_5 | R/W | H'00000000 | H'FFFE1058 | 16, 32 | | | DMA channel control register_5 | CHCR_5 | R/W*1 | H'00000000 | H'FFFE105C | 8, 16, 32 | | | DMA reload source address register_5 | RSAR_5 | R/W | H'00000000 | H'FFFE1150 | 16, 32 | | | DMA reload destination address register_5 | RDAR_5 | R/W | H'00000000 | H'FFFE1154 | 16, 32 | | | DMA reload transfer count register_5 | RDMATCR_5 | R/W | H'00000000 | H'FFFE1158 | 16, 32 | | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------------------|--------------|-------|---------------|------------|----------------| | 6 | DMA source address register_6 | SAR_6 | R/W | H'00000000 | H'FFFE1060 | 16, 32 | | | DMA destination address register_6 | DAR_6 | R/W | H'00000000 | H'FFFE1064 | 16, 32 | | | DMA transfer count register_6 | DMATCR_6 | R/W | H'00000000 | H'FFFE1068 | 16, 32 | | | DMA channel control register_6 | CHCR_6 | R/W*1 | H'00000000 | H'FFFE106C | 8, 16, 32 | | | DMA reload source address register_6 | RSAR_6 | R/W | H'00000000 | H'FFFE1160 | 16, 32 | | | DMA reload destination address register_6 | RDAR_6 | R/W | H'00000000 | H'FFFE1164 | 16, 32 | | | DMA reload transfer count register_6 | RDMATCR_6 | R/W | H'00000000 | H'FFFE1168 | 16, 32 | | 7 | DMA source address register_7 | SAR_7 | R/W | H'00000000 | H'FFFE1070 | 16, 32 | | | DMA destination address register_7 | DAR_7 | R/W | H'00000000 | H'FFFE1074 | 16, 32 | | | DMA transfer count register_7 | DMATCR_7 | R/W | H'00000000 | H'FFFE1078 | 16, 32 | | | DMA channel control register_7 | CHCR_7 | R/W*1 | H'00000000 | H'FFFE107C | 8, 16, 32 | | | DMA reload source address register_7 | RSAR_7 | R/W | H'00000000 | H'FFFE1170 | 16, 32 | | | DMA reload destination address register_7 | RDAR_7 | R/W | H'00000000 | H'FFFE1174 | 16, 32 | | | DMA reload transfer count register_7 | RDMATCR_7 | R/W | H'00000000 | H'FFFE1178 | 16, 32 | | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-----------------------------------|--------------|-------------------|---------------|------------|----------------| | Common | DMA operation register | DMAOR | R/W* <sup>2</sup> | H'0000 | H'FFFE1200 | 8, 16 | | 0 and 1 | DMA extension resource selector 0 | DMARS0 | R/W | H'0000 | H'FFFE1300 | 16 | | 2 and 3 | DMA extension resource selector 1 | DMARS1 | R/W | H'0000 | H'FFFE1304 | 16 | | 4 and 5 | DMA extension resource selector 2 | DMARS2 | R/W | H'0000 | H'FFFE1308 | 16 | | 6 and 7 | DMA extension resource selector 3 | DMARS3 | R/W | H'0000 | H'FFFE130C | 16 | Notes: 1. For the HE and TE bits in CHCRn, only 0 can be written to clear the flags after 1 is read. 2. For the AE and NMIF bits in DMAOR, only 0 can be written to clear the flags after 1 is read. #### 8.3.1 DMA Source Address Registers (SAR) The DMA source address registers (SAR) are 32-bit readable/writable registers that specify the source address of a DMA transfer. During a DMA transfer, these registers indicate the next source address. When the data of an external device with DACK is transferred in single address mode, SAR is ignored. To transfer data in word (2-byte), longword (4-byte), or 16-byte unit, specify the address with 2byte, 4-byte, or 16-byte address boundary respectively. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | - | ı | _ | _ | İ | _ | _ | _ | - | _ | _ | 1 | _ | _ | ı | _ | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | | _ | _ | | _ | _ | _ | | _ | _ | | _ | _ | | _ | | Initial value:<br>R/W: | 0<br>R/W ## 8.3.2 DMA Destination Address Registers (DAR) The DMA destination address registers (DAR) are 32-bit readable/writable registers that specify the destination address of a DMA transfer. During a DMA transfer, these registers indicate the next destination address. When the data of an external device with DACK is transferred in single address mode, DAR is ignored. To transfer data in word (2-byte), longword (4-byte), or 16-byte unit, specify the address with 2-byte, 4-byte, or 16-byte address boundary respectively. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ı | _ | | _ | _ | | | l | _ | l | _ | _ | _ | - | | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W # 8.3.3 DMA Transfer Count Registers (DMATCR) The DMA transfer count registers (DMATCR) are 32-bit readable/writable registers that specify the number of DMA transfers. The transfer count is 1 when the setting is H'00000001, 16,777,215 when H'00FFFFFF is set, and 16,777,216 (the maximum) when H'00000000 is set. During a DMA transfer, these registers indicate the remaining transfer count. The upper eight bits of DMATCR are always read as 0, and the write value should always be 0. To transfer data in 16 bytes, one 16-byte transfer (128 bits) counts one. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | ı | 1 | _ | ı | | _ | _ | ı | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R/W ## 8.3.4 DMA Channel Control Registers (CHCR) The DMA channel control registers (CHCR) are 32-bit readable/writable registers that control the DMA transfer mode. The DO, AM, AL, DL, and DS bits which specify the DREQ and DACK external pin functions can be read and written to in channels 0 and 1, but they are reserved in channels 2 to 7. The TL bit which specifies the TEND external pin function can be read and written to in channels 0 and 1, but it is reserved in channels 2 to 7. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-------|-----|-------|-----|-----|------|-----|-----|-----|-----|-----|--------|-----|--------|-----| | | TC | _ | _ | RLD | _ | _ | _ | _ | DO | TL | _ | _ | HE | HIE | AM | AL | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R | R | R/W | R | R | R | R | R/W | R/W | R | R | R/(W)* | R/W | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DM | [1:0] | SM | [1:0] | | RS[ | 3:0] | | DL | DS | ТВ | TS | [1:0] | ΙE | TE | DE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W R/(W)* | R/W | Note: \* Only 0 can be written to clear the flag after 1 is read. | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | TC | 0 | R/W | Transfer Count Mode | | | | | | Specifies whether to transmit data once or for the count specified in DMATCR by one transfer request. This function is valid only at a request of the peripheral module. Note that when this bit is set to 0, the TB bit must not be set to 1 (burst mode). When the SCIF, IIC3, or SSI is selected for the transfer request source, this bit (TC) must not be set to 1. | | | | | | 0: Transmits data once by one transfer request. | | | | | | <ol> <li>Transmits data for the count specified in DMATCR<br/>by one transfer request.</li> </ol> | | 30 | | 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |----------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 29 | RLDSAR | 0 | R/W | SAR Reload Function Enable or Disable | | | | | | Sets whether to enable or disable the reload function for SAR or DMATCR. | | | | | | 0: Disables the reload function for SAR or DMATCR. | | | | | | 1: Enables the reload function for SAR or DMATCR. | | 28 | RLDDAR | 0 | R/W | DAR Reload Function Enable or Disable | | | | | | Sets whether to enable or disable the reload function for DAR or DMATCR. | | | | | | 0: Disables the reload function for DAR or DMATCR. | | | | | | 1: Enables the reload function for DAR or DMATCR. | | 27 to 24 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 23 | DO | 0 | R/W | DMA Overrun | | | | | | Selects whether DREQ is detected by overrun 0 or by overrun 1. This bit is valid only in CHCR_0 and CHCR_1. This bit is reserved in CHCR_2 to CHCR_7; it is always read as 0 and the write value should always be 0. | | | | | | 0: Detects DREQ by overrun 0. | | | | | | 1: Detects DREQ by overrun 1. | | 22 | TL | 0 | R/W | Transfer End Level | | | | | | Specifies the TEND signal output is high active or low active. This bit is valid only in CHCR_0 and CHCR_1. This bit is reserved in CHCR_2 to CHCR_7; it is always read as 0 and the write value should always be 0. | | | | | | 0: Low-active output from TEND | | | | | | 1: High-active output from TEND | | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |-----|----------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 21 | _ | 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | TEMASK | 0 | R/W | TE Set Mask | | | | | | Indicates that DMA transfer is not terminated when the TE bit is set to 1. By setting this bit together with the SAR reload function or the DAR reload function, DMA transfer can be executed until the transfer request is canceled. Upon detection of the rising or falling edge of an auto request or external request, this bit is ignored and the DMA transfer is terminated when the TE bit is set. Note that this function is enabled if either of the RLDSAR bit or the RLDDAR bit is set to 1. | | | | | | 0: Terminates DMA if the TE bit is set. | | | | | | 1: Continues DMA even if the TE bit is set. | | 19 | HE | 0 | R/(W)* | Half-End Flag | | | | | | This bit is set to 1 when the transfer count reaches half of the DMATCR value that was specified before transfer starts. | | | | | | If DMA transfer ends because of an NMI interrupt, a DMA address error, or clearing of the DE bit or the DME bit in DMAOR before the transfer count reaches half of the initial DMATCR value, the HE bit is not set to 1. If DMA transfer ends due to an NMI interrupt, a DMA address error, or clearing of the DE bit or the DME bit in DMAOR after the HE bit is set to 1, the bit remains set to 1. | | | | | | To clear the HE bit, write 0 to it after $HE = 1$ is read. | | | | | | 0: DMATCR > (DMATCR set before transfer starts)/2<br>during DMA transfer or after DMA transfer is<br>terminated | | | | | | [Clearing condition] | | | | | | • Writing 0 after reading HE = 1. | | | | | | 1: DMATCR ≤ (DMATCR set before transfer starts)/2 | | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | HIE | 0 | R/W | Half-End Interrupt Enable | | | | | | Specifies whether to issue an interrupt request to the CPU when the transfer count reaches half of the DMATCR value that was specified before transfer starts. | | | | | | When the HIE bit is set to 1, the DMAC requests an interrupt to the CPU when the HE bit becomes 1. | | | | | | 0: Disables an interrupt to be issued when DMATCR = (DMATCR set before transfer starts)/2. | | | | | | 1: Enables an interrupt to be issued when DMATCR = (DMATCR set before transfer starts)/2. | | 17 | AM | 0 | R/W | Acknowledge Mode | | | | | | Specifies whether DACK is output in data read cycle or in data write cycle in dual address mode. | | | | | | In single address mode, DACK is always output regardless of the specification by this bit. | | | | | | This bit is valid only in CHCR_0 and CHCR_1. This bit is reserved in CHCR_2 to CHCR_7; it is always read as 0 and the write value should always be 0. | | | | | | 0: DACK output in read cycle (dual address mode) | | | | | | 1: DACK output in write cycle (dual address mode) | | 16 | AL | 0 | R/W | Acknowledge Level | | | | | | Specifies the DACK (acknowledge) signal output is high active or low active. | | | | | | This bit is valid only in CHCR_0 and CHCR_1. This bit is reserved in CHCR_2 to CHCR_7; it is always read as 0 and the write value should always be 0. | | | | | | 0: Low-active output from DACK | | | | | | 1: High-active output from DACK | | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |--------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15, 14 | DM[1:0] | 00 | R/W | Destination Address Mode | | | | | | These bits select whether the DMA destination address is incremented, decremented, or left fixed. (In single address mode, DM1 and DM0 bits are ignored when data is transferred to an external device with DACK.) | | | | | | 00: Fixed destination address | | | | | | 01: Destination address is incremented (+1 in 8-bit transfer, +2 in 16-bit transfer, +4 in 32-bit transfer, +16 in 16-byte transfer) | | | | | | <ol> <li>Destination address is decremented (-1 in 8-bit<br/>transfer, -2 in 16-bit transfer, -4 in 32-bit transfer,<br/>setting prohibited in 16-byte transfer)</li> </ol> | | | | | | 11: Setting prohibited | | 13, 12 | SM[1:0] | 00 | R/W | Source Address Mode | | | | | | These bits select whether the DMA source address is incremented, decremented, or left fixed. (In single address mode, SM1 and SM0 bits are ignored when data is transferred from an external device with DACK.) | | | | | | 00: Fixed source address | | | | | | 01: Source address is incremented (+1 in byte-unit<br>transfer, +2 in word-unit transfer, +4 in longword-<br>unit transfer, +16 in 16-byte-unit transfer) | | | | | | 10: Source address is decremented (–1 in byte-unit<br>transfer, –2 in word-unit transfer, –4 in longword-<br>unit transfer, setting prohibited in 16-byte-unit<br>transfer) | | | | | | 11: Setting prohibited | | | | Initial | | | |---------|----------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Descriptions | | 11 to 8 | RS[3:0] | 0000 | R/W | Resource Select | | | | | | These bits specify which transfer requests will be sent to the DMAC. The changing of transfer request source should be done in the state when DMA enable bit (DE) is set to 0. | | | | | | 0000: External request, dual address mode | | | | | | 0001: Setting prohibited | | | | | | 0010: External request/single address mode | | | | | | External address space $\rightarrow$ External device with DACK | | | | | | 0011: External request/single address mode | | | | | | External device with DACK $\rightarrow$ External address | | | | | | space | | | | | | 0100: Auto request | | | | | | 0101: Setting prohibited | | | | | | 0110: Setting prohibited | | | | | | 0111: Setting prohibited | | | | | | 1000: DMA extension resource selector | | | | | | 1001: Setting prohibited | | | | | | 1010: Setting prohibited | | | | | | 1011: Setting prohibited | | | | | | 1100: Setting prohibited | | | | | | 1101: Setting prohibited | | | | | | 1110: Setting prohibited | | | | | | 1111: Setting prohibited | | | | | | Note: External request specification is valid only in CHCR_0 to CHCR_3. If a request source is selected in channels CHCR_4 to CHCR_7, no | | | | | | operation will be performed. | | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | DL | 0 | R/W | DREQ Level | | 6 | DS | 0 | R/W | DREQ Edge Select | | | | | | These bits specify the sampling method of the DREQ pin input and the sampling level. | | | | | | These bits are valid only in CHCR_0 and CHCR_1. These bits are reserved in CHCR_2 to CHCR_7; they are always read as 0 and the write value should always be 0. | | | | | | If the transfer request source is specified as an on-chip<br>peripheral module or if an auto-request is specified, the<br>specification by these bits is ignored. | | | | | | 00: DREQ detected in low level | | | | | | 01: DREQ detected at falling edge | | | | | | 10: DREQ detected in high level | | | | | | 11: DREQ detected at rising edge | | 5 | ТВ | 0 | R/W | Transfer Bus Mode | | | | | | Specifies the bus mode when DMA transfers data.<br>Note that the burst mode must not be selected when $TC = 0$ . | | | | | | 0: Cycle steal mode | | | | | | 1: Burst mode | | 4, 3 | TS[1:0] | 00 | R/W | Transfer Size | | | | | | These bits specify the size of data to be transferred. | | | | | | Select the size of data to be transferred when the source or destination is an on-chip peripheral module register of which transfer size is specified. | | | | | | 00: Byte unit | | | | | | 01: Word unit (two bytes) | | | | | | 10: Longword unit (four bytes) | | | | | | 11: 16-byte (four longword) unit | Page 310 of 1278 | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |-----|----------|------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | IF | 0 | R/W | Interrupt Enable | | _ | | ŭ | | Specifies whether or not an interrupt request is generated to the CPU at the end of the DMA transfer. Setting this bit to 1 generates an interrupt request (DEI) to the CPU when TE bit is set to 1. | | | | | | 0: Disables an interrupt request. | | | | | | 1: Enables an interrupt request. | | 1 | TE | 0 | R/(W)* | Transfer End Flag | | | | | | This bit is set to 1 when DMATCR becomes 0 and DMA transfer ends. | | | | | | The TE bit is not set to 1 in the following cases. | | | | | | • DMA transfer ends due to an NMI interrupt or DMA address error before DMATCR becomes 0. | | | | | | <ul> <li>DMA transfer is ended by clearing the DE bit and<br/>DME bit in DMA operation register (DMAOR).</li> </ul> | | | | | | To clear the TE bit, write 0 after reading TE = 1. | | | | | | If the TEMASK bit is 0 and the TE bit is set, transfer is not enabled even if the DE bit is set to 1. | | | | | | 0: During the DMA transfer or DMA transfer has been terminated | | | | | | [Clearing condition] | | | | | | • Writing 0 after reading TE = 1 | | | | | | 1: DMA transfer ends by the specified count (DMATCR = 0) | | Bit | Bit Name | Initial<br>Value | R/W | Descriptions | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | DE | 0 | R/W | DMA Enable | | | | | | Enables or disables the DMA transfer. In auto request mode, DMA transfer starts by setting the DE bit and DME bit in DMAOR to 1. In this case, all of the bits TE, NMIF in DMAOR, and AE must be 0. In an external request or peripheral module request, DMA transfer starts if DMA transfer request is generated by the devices or peripheral modules after setting the bits DE and DME to 1. If the TEMASK bit is 1, the NMIF and AE bits must be 0 upon detection of the low or high level of an external request and at a request of the peripheral module. If the TEMASK bit is 0, the TE bit must also be 0. As with auto request mode, all of the TE, NMIF, and AE bits must be 0 upon detection of the rising or falling edge of an external request. Clearing the DE bit to 0 can terminate the DMA transfer. | | | | | | 1: DMA transfer disabled | | | | | | TI BINIT TRAILORD CHADICA | Note: \* Only 0 can be written to clear the flag after 1 is read. # 8.3.5 DMA Reload Source Address Registers (RSAR) The DMA reload source address registers (RSAR) are 32-bit readable/writable registers. When the SAR reload function is enabled, the RSAR value is written to the source address register (SAR) at the end of the current DMA transfer. In this case, a new value for the next DMA transfer can be preset in RSAR during the current DMA transfer. When the SAR reload function is disabled, RSAR is ignored. To transfer data in word (2-byte), longword (4-byte), or 16-byte unit, specify the address with 2-byte, 4-byte, or 16-byte address boundary respectively. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R/W # 8.3.6 DMA Reload Destination Address Registers (RDAR) The DMA reload destination address registers (RDAR) are 32-bit readable/writable registers. When the DAR reload function is enabled, the RDAR value is written to the destination address register (SAR) at the end of the current DMA transfer. In this case, a new value for the next DMA transfer can be preset in RDAR during the current DMA transfer. When the DAR reload function is disabled, RDAR is ignored. To transfer data in word (2-byte), longword (4-byte), or 16-byte unit, specify the address with 2-byte, 4-byte, or 16-byte address boundary respectively. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | - | | | - | | | _ | | _ | _ | - | _ | _ | _ | _ | | Initial value:<br>R/W: | 0<br>R/W # 8.3.7 DMA Reload Transfer Count Registers (RDMATCR) The DMA reload transfer count registers (RDMATCR) are 32-bit readable/writable registers. When the SAR or DAR reload function is enabled, the RDMATCR value is written to the transfer count register (DMATCR) at the end of the current DMA transfer. In this case, a new value for the next DMA transfer can be preset in RDMATCR during the current DMA transfer. When the SAR or DAR reload function is disabled, RDMATCR is ignored. The upper eight bits of RDMATCR are always read as 0, and the write value should always be 0. As in DMATCR, the transfer count is 1 when the setting is H'00000001, 16,777,215 when H'00FFFFFF is set, and 16,777,216 (the maximum) when H'00000000 is set. To transfer data in 16 bytes, one 16-byte transfer (128 bits) counts one. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | l | | _ | - | | - | | _ | _ | _ | _ | _ | | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R/W #### 8.3.8 **DMA Operation Register (DMAOR)** The DMA operation register (DMAOR) is a 16-bit readable/writable register that specifies the priority level of channels at the DMA transfer. This register also shows the DMA transfer status. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|-----|--------|----|----|-----|-------|---|---|---|---|---|--------|--------|-----| | | _ | _ | CMS | S[1:0] | | _ | PR | [1:0] | _ | _ | _ | | _ | AE | NMIF | DME | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R/W | R/W | R | R | R/W | R/W | R | R | R | R | R | R/(W)* | R/(W)* | R/W | Note: \* Only 0 can be written to clear the flag after 1 is read. | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------| | 15, 14 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 13, 12 | CMS[1:0] | 00 | R/W | Cycle Steal Mode Select | | | | | | These bits select either normal mode or intermittent mode in cycle steal mode. | | | | | | It is necessary that the bus modes of all channels be<br>set to cycle steal mode to make the intermittent mode<br>valid. | | | | | | 00: Normal mode | | | | | | 01: Setting prohibited | | | | | | 10: Intermittent mode 16 | | | | | | Executes one DMA transfer for every 16 cycles of B $\phi$ clock. | | | | | | 11: Intermittent mode 64 | | | | | | Executes one DMA transfer for every 64 cycles of B $\phi$ clock. | | 11, 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9, 8 | PR[1:0] | 00 | R/W | Priority Mode | | | | | | These bits select the priority level between channels when there are transfer requests for multiple channels simultaneously. | | | | | | 00: Fixed mode 1: CH0 > CH1 > CH2 > CH3 > CH4 > CH5 > CH6 > CH7 | | | | | | 01: Fixed mode 2: CH0 > CH4 > CH1 > CH5 > CH2 > CH6 > CH3 > CH7 | | | | | | 10: Setting prohibited | | | | | | 11: Round-robin mode (only supported in CH0 to CH3) | | 7 to 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 | AE | 0 | R/(W)* | Address Error Flag | | | | | | Indicates whether an address error has occurred by the DMAC. When this bit is set, even if the DE bit in CHCR and the DME bit in DMAOR are set to 1, DMA transfer is not enabled. This bit can only be cleared by writing 0 after reading 1. | | | | | | 0: No DMAC address error | | | | | | 1: DMAC address error occurred | | | | | | [Clearing condition] | | | | | | • Writing 0 after reading AE = 1 | | 1 | NMIF | 0 | R/(W)* | NMI Flag | | | | | | Indicates that an NMI interrupt occurred. When this bit is set, even if the DE bit in CHCR and the DME bit in DMAOR are set to 1, DMA transfer is not enabled. This bit can only be cleared by writing 0 after reading 1. | | | | | | When the NMI is input, the DMA transfer in progress can be done in one transfer unit. Even if the NMI interrupt is input while the DMAC is not in operation, the NMIF bit is set to 1. | | | | | | 0: No NMI interrupt | | | | | | 1: NMI interrupt occurred | | | | | | [Clearing condition] | | | | | | Writing 0 after reading NMIF = 1 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | DME | 0 | R/W | DMA Master Enable | | | | | | Enables or disables DMA transfer on all channels. If<br>the DME bit and DE bit in CHCR are set to 1, DMA<br>transfer is enabled. | | | | | | However, transfer is enabled only when the TE bit in CHCR of the transfer corresponding channel, the NMIF bit in DMAOR, and the AE bit are all cleared to 0. Clearing the DME bit to 0 can terminate the DMA transfer on all channels. | | | | | | 0: DMA transfer is disabled on all channels | | | | | | 1: DMA transfer is enabled on all channels | Note: \* Only 0 can be written to clear the flag after 1 is read. If the priority mode bits are modified after a DMA transfer, the channel priority is initialized. If fixed mode 2 is specified, the channel priority is specified as CH0 > CH4 > CH1 > CH5 > CH2 > CH6 > CH3 > CH7. If fixed mode 1 is specified, the channel priority is specified as CH0 > CH1 > CH2 > CH3 > CH4 > CH5 > CH6 > CH7. If the round-robin mode is specified, the transfer end channel is reset. Table 8.3 shows the priority change in each mode (modes 0 to 2) specified by the priority mode bits. In each priority mode, the channel priority to accept the next transfer request may change in up to three ways according to the transfer end channel. For example, when the transfer end channel is channel 1, the priority of the channel to accept the next transfer request is specified as CH2 > CH3 > CH0 > CH1 > CH4 > CH5 > CH6 > CH7. When the transfer end channel is any one of the channels 4 to 7, round-robin will not be applied and the priority level is not changed at the end of transfer in the channels 4 to 7. The DMAC internal operation for an address error is as follows: - No address error: Read (source to DMAC) → Write (DMAC to destination) - Address error in source address: Nop → Nop - Address error in destination address: Read → Nop **Table 8.3** Combinations of Priority Mode Bits | | Transfer | Priority Mode | | | | | | | | | | | |--------------------------|-------------|---------------|-------|------|----------|-----|-----|-----|-----|----------|-----|--| | | End | E | Bits | High | <b>←</b> | | | | | <u> </u> | Low | | | Mode | CH No. | PR[1] | PR[0] | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | Mode 0<br>(fixed mode 1) | Any channel | 0 | 0 | CH0 | CH1 | CH2 | СНЗ | CH4 | CH5 | CH6 | CH7 | | | Mode 1<br>(fixed mode 2) | Any channel | 0 | 1 | CH0 | CH4 | CH1 | CH5 | CH2 | CH6 | СНЗ | CH7 | | | Mode 2 | CH0 | 1 | 1 | CH1 | CH2 | СНЗ | CH0 | CH4 | CH5 | CH6 | CH7 | | | (round-robin mode) | CH1 | 1 | 1 | CH2 | СНЗ | CH0 | CH1 | CH4 | CH5 | CH6 | CH7 | | | | CH2 | 1 | 1 | СНЗ | CH0 | CH1 | CH2 | CH4 | CH5 | CH6 | CH7 | | | | СНЗ | 1 | 1 | CH0 | CH1 | CH2 | СНЗ | CH4 | CH5 | CH6 | CH7 | | | | CH4 | 1 | 1 | CH0 | CH1 | CH2 | СНЗ | CH4 | CH5 | CH6 | CH7 | | | | CH5 | 1 | 1 | CH0 | CH1 | CH2 | СНЗ | CH4 | CH5 | CH6 | CH7 | | | | CH6 | 1 | 1 | CH0 | CH1 | CH2 | СНЗ | CH4 | CH5 | CH6 | CH7 | | | | CH7 | 1 | 1 | CH0 | CH1 | CH2 | СНЗ | CH4 | CH5 | CH6 | CH7 | | #### 8.3.9 DMA Extension Resource Selectors 0 to 3 (DMARS0 to DMARS3) The DMA extension resource selectors (DMARS) are 16-bit readable/writable registers that specify the DMA transfer sources from peripheral modules in each channel. DMARS0 is for channels 0 and 1, DMARS1 is for channels 2 and 3, DMARS2 is for channels 4 and 5, and DMARS3 is for channels 6 and 7. Table 8.4 shows the specifiable combinations. This register can specify transfer requests from six SCIF sources, two IIC3 sources, two CMT sources, two USB sources, two SSI sources, and two SDHI sources. ### DMARS0 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-------|----------|-----|-----|-------|----------|-----|-----|-------|-----------|-----|-----|-------|----------| | | | | CH1 M | IID[5:0] | | | CH1 F | RID[1:0] | | | CH0 N | /IID[5:0] | | | CH0 F | RID[1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W ### DMARS1 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------------|-----|-----|-----|-----|-------|------------------------|-----|-----|----------|-----|-----|-------|----------|-----|-----| | | CH3 MID[5:0] | | | | | CH3 F | CH3 RID[1:0] CH2 MID[5 | | | IID[5:0] | | | CH2 F | RID[1:0] | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ | DAM | DAM | D/M | DAM | DAM | DAM | DAM | DAM | DAM | D/M | D/M | D/M | DAM | DAM | D/M | D/M | ### DMARS2 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-------|----------|-----|-----|-------|----------|-----|-----|-------|----------|-----|-----|-------|----------| | | | | CH5 N | IID[5:0] | | | CH5 R | IID[1:0] | | | CH4 N | IID[5:0] | | | CH4 F | RID[1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | D/M. | D/M | D/M | D/M | DAM | DAM | D/M | D/M | D/M | DAM | D/M | D/M | D/M | DAM | DAM | D/M | D/M | ### DMARS3 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-------|----------|-----|-----|-------|----------|-----|-----|-------|----------|-----|-----|-------|----------| | | | | CH7 M | 1ID[5:0] | | | CH7 F | RID[1:0] | | | CH6 N | IID[5:0] | | | CH6 F | RID[1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ | R/M | R/M | R/W | R/W | R/M | R/M | R/M | R/W | R/M | R/M | R/M | R/W | R/W | R/W | R/M | R/M | Transfer requests from the various modules specify MID and RID as shown in table 8.4. **Table 8.4 DMARS Settings** | Peripheral Module | Setting Value for One Channel ({MID, RID}) | MID | RID | Function | |-------------------|--------------------------------------------|----------|------|----------| | USB_0 | H'03 | B'000000 | B'11 | _ | | USB_1 | H'07 | B'000001 | B'11 | _ | | SDHI | H'11 | B'000100 | B'01 | Transmit | | | H'12 | B'000100 | B'10 | Receive | | SSI_0 | H'23 | B'001000 | B'11 | _ | | SSI_1 | H'27 | B'001001 | B'11 | _ | | IIC3_0 | H'61 | B'011000 | B'01 | Transmit | | | H'62 | | B'10 | Receive | | SCIF_0 | H'81 | B'100000 | B'01 | Transmit | | | H'82 | | B'10 | Receive | | SCIF_1 | H'85 | B'100001 | B'01 | Transmit | | | H'86 | | B'10 | Receive | | SCIF_2 | H'89 | B'100010 | B'01 | Transmit | | | H'8A | | B'10 | Receive | | CMT_0 | H'FB | B'111110 | B'11 | _ | | CMT_1 | H'FF | B'111111 | B'11 | _ | When MID or RID other than the values listed in table 8.4 is set, the operation of this LSI is not guaranteed. The transfer request from DMARS is valid only when the resource select bits (RS[3:0]) in CHCR0 to CHCR7 have been set to B'1000. Otherwise, even if DMARS has been set, the transfer request source is not accepted. #### **Operation** 8.4 When there is a DMA transfer request, the DMAC starts the transfer according to the predetermined channel priority order; when the transfer end conditions are satisfied, it ends the transfer. Transfers can be requested in three modes: auto request, external request, and on-chip peripheral module request. In bus mode, the burst mode or the cycle steal mode can be selected. #### 8.4.1 Transfer Flow After the DMA source address registers (SAR), DMA destination address registers (DAR), DMA transfer count registers (DMATCR), DMA channel control registers (CHCR), DMA operation register (DMAOR), three reload registers (RSAR, RDAR, and RDMATCR), and DMA extension resource selector (DMARS) are set for the target transfer conditions, the DMAC transfers data according to the following procedure: - 1. Checks to see if transfer is enabled (DE = 1, DME = 1, TEMASK = 0 and TE = 0 [or TEMASK = 1, AE = 0, NMIF = 0) - 2. When a transfer request comes and transfer is enabled, the DMAC transfers one transfer unit of data (depending on the TS[1:0] settings). For an auto request, the transfer begins automatically when the DE bit and DME bit are set to 1. The DMATCR value will be decremented by 1 for each transfer. The actual transfer flows vary by address mode and bus mode. - 3. When half of the specified transfer count is exceeded (when DMATCR reaches half of the initial value), an HEI interrupt is sent to the CPU if the HIE bit in CHCR is set to 1. - 4. When TEMASK = 0, if transfer has been completed for the specified count (that is, DMATCR reaches 0), the transfer ends normally. If the IE bit in CHCR is set to 1 at this time, a DEI interrupt is sent to the CPU. When TEMASK = 1, if DMATCR reaches 0, TE is set to 1. The specified RSAR, RDAR, and RDMATC values are reloaded into RSAR, RDAR, and RDMATC, and the transfer operation continues until there are no more transfer requests. - 5. When an address error in the DMAC or an NMI interrupt is generated, the transfer is terminated. Transfers are also terminated when the DE bit in CHCR or the DME bit in DMAOR is cleared to 0. Figure 8.2 is a flowchart of this procedure. Figure 8.2 DMA Transfer Flowchart ## 8.4.2 DMA Transfer Requests DMA transfer requests are basically generated in either the data transfer source or destination, but they can also be generated in external devices and on-chip peripheral modules that are neither the transfer source nor destination. Transfers can be requested in three modes: auto request, external request, and on-chip peripheral module request. The request mode is selected by the RS[3:0] bits in CHCR\_0 to CHCR\_7 and DMARS0 to DMARS3. ### (1) Auto-Request Mode When there is no transfer request signal from an external source, as in a memory-to-memory transfer or a transfer between memory and an on-chip peripheral module unable to request a transfer, the auto-request mode allows the DMAC to automatically generate a transfer request signal internally. When the DE bits in CHCR\_0 to CHCR\_7 and the DME bit in DMAOR are set to 1, the transfer begins so long as the TE bits in CHCR\_0 to CHCR\_7, and the AE and NMIF bits in DMAOR are 0. ### (2) External Request Mode In this mode a transfer is performed at the request signals (DREQ0 and DREQ1) of an external device. Choose one of the modes shown in table 8.5 according to the application system. When the DMA transfer is enabled (for level detection, DE=1, DME=1, TEMASK = 0 and TE = 0 [or TEMASK = 1], AE=0, NMIF=0); for edge detection, DE=1, DME=1, TE=0, AE=0, NMIF=0), DMA transfer is performed upon a request at the DREQ input. **Table 8.5** Selecting External Request Modes with the RS Bits | RS[3] | RS[2] | RS[1] | RS[0] | Address Mode | Transfer Source | Transfer Destination | |-------|-------|-------|-------|---------------------|------------------------------------------------------|------------------------------------------------------| | 0 | 0 | 0 | 0 | Dual address mode | Any | Any | | 0 | 0 | 1 | 0 | Single address mode | External memory,<br>memory-mapped<br>external device | External device with DACK | | | | | 1 | - | External device with DACK | External memory,<br>memory-mapped<br>external device | Choose to detect DREQ by either the edge or level of the signal input with the DL and DS bits in CHCR\_0 and CHCR\_1 as shown in table 8.6. The source of the transfer request does not have to be the data transfer source or destination. Upon detection of a rising or falling edge, one transfer request in burst mode causes the transfer to continue until DMATCR = 0 is reached. In cycle steal mode, one transfer request results in a single transfer. Table 8.6 Selecting External Request Detection with DL and DS Bits ### CHCR | DL bit | DS bit | Detection of External Request | |--------|--------|-------------------------------| | 0 | 0 | Low level detection | | | 1 | Falling edge detection | | 1 | 0 | High level detection | | | 1 | Rising edge detection | When DREQ is accepted, the DREQ pin enters the request accept disabled state (non-sensitive period). After issuing acknowledge DACK signal for the accepted DREQ, the DREQ pin again enters the request accept enabled state. When DREQ is used by level detection, there are following two cases by the timing to detect the next DREQ after outputting DACK. Overrun 0: Transfer is terminated after the same number of transfer has been performed as requests. Overrun 1: Transfer is terminated after transfers have been performed for (the number of requests plus 1) times. The DO bit in CHCR selects this overrun 0 or overrun 1. Table 8.7 Selecting External Request Detection with DO Bit ### **CHCR** | DO bit | External Request | | |--------|------------------|--| | 0 | Overrun 0 | | | 1 | Overrun 1 | | ## (3) On-Chip Peripheral Module Request In this mode, the transfer is performed in response to the DMA transfer request signal from an onchip peripheral module. Table 8.8 shows the list of DMAC transfer request signals sent from on-chip peripheral modules to DMAC. When a transfer request signal is sent in on-chip peripheral module request mode while DMA transfer is enabled (DE=1, DME=1, TEMASK = 0 and TE = 0 [or TEMASK = 1], AE=0, NMIF=0), DMA transfer is performed. For on-chip peripheral module requests, there are cases in which the transfer source and destination are fixed; see table 8.8. Table 8.8 Selecting On-Chip Peripheral Module Request Modes with RS3 to RS0 Bits | CHCR | DMAI | RS | DMA Transfer | | | | | |---------|-------------------------|-----|-------------------|------------------------------------|--------------------|-------------------------|----------------------| | RS[3:0] | MID | RID | Request<br>Source | DMA Transfer<br>Request Signal | Transfer<br>Source | Transfer<br>Destination | Bus Mode | | 1000 | 000000 | 11 | USB | USB_DMA0<br>(receive FIFO full) | D0FIFO | Any | Cycle steal or burst | | | | | | USB_DMA0<br>(transmit FIFO empty) | Any | D0FIFO | <del>-</del> | | | 000001 | 11 | USB | USB_DMA1<br>(receive FIFO full) | D1FIFO | Any | <del>-</del> | | | | | | USB_DMA1<br>(transmit FIFO empty) | Any | Any D1FIFO | | | | 000100 | 01 | SDHI transmit | TXI (receive data empty) | Data register | Any | Cycle steal | | | | 10 | SDHI receive | RXI (transmit data full) | Any | Data<br>register | <del>-</del> | | | 001000 | 11 | SSI_0 | DMA0 (transmit mode) | Any | SSITDR0 | =' | | | | | | DMA0 (receive mode) | SSIRDR0 | Any | =' | | | 001001 | 11 | SSI_1 | DMA1 (transmit mode) | Any | SSITDR1 | _ | | | | | | DMA1 (receive mode) | SSIRDR1 | Any | - | | | 011000 | 01 | IIC3_0 transmit | TXI0 (transmit data empty) | Any | ICDRT0 | | | | | 10 | IIC3_0 receive | RXI0 (receive data full) | ICDRR0 | Any | _ | | | 100000 | 01 | SCIF_0 transmit | TXI0<br>(transmit FIFO data empty) | Any | SCFTDR_0 | | | | | 10 | SCIF_0 receive | RXI0<br>(receive FIFO data full) | SCFRDR_0 | Any | | | | 100001 01 SCIF_1 transm | | SCIF_1 transmit | TXI1<br>(transmit FIFO data empty) | Any | SCFTDR_1 | <del>-</del> | | | | 10 | SCIF_1 receive | RXI1<br>(receive FIFO data full) | SCFRDR_1 | Any | | | | 100010 | 01 | SCIF_2 transmit | TXI2<br>(transmit FIFO data empty) | Any | SCFTDR_2 | | | | | 10 | SCIF_2 receive | RXI2<br>(receive FIFO data full) | SCFRDR_2 | Any | <del>-</del> | | | 111110 | 11 | CMT_0 | CMI0 (compare match) | Any | Any | Cycle steal | | | 111111 | 11 | CMT_1 | CMI1 (compare match) | Any | Any | or burst | #### 8.4.3 **Channel Priority** When the DMAC receives simultaneous transfer requests on two or more channels, it selects a channel according to a predetermined priority order. Three modes (fixed mode 1, fixed mode 2, and round-robin mode) are selected using the PR1 and PR0 bits in DMAOR. #### **(1)** Fixed Mode In fixed modes, the priority levels among the channels remain fixed. There are two kinds of fixed modes as follows: Fixed mode 1: CH0 > CH1 > CH2 > CH3 > CH4 > CH5 > CH6 > CH7 Fixed mode 2: CH0 > CH4 > CH1 > CH5 > CH2 > CH6 > CH3 > CH7 These are selected by the PR1 and PR0 bits in the DMA operation register (DMAOR). #### Round-Robin Mode **(2)** Each time one unit of word, byte, longword, or 16 bytes is transferred on one channel, the priority order is rotated. The channel on which the transfer was just finished is rotated to the lowest of the priority order among the four round-robin channels (channels 0 to 4). The priority of the channels other than the round-robin channels (channels 0 to 4) does not change even in round-robin mode. The round-robin mode operation is shown in figure 8.3. The priority in round-robin mode is CH0 > CH1 > CH2 > CH3 > CH4 > CH5 > CH6 > CH7 immediately after a reset. When the round-robin mode has been specified, do not concurrently specify cycle steal mode and burst mode as the bus modes of any two or more channels. Figure 8.3 Round-Robin Mode Figure 8.4 shows how the priority order changes when channel 0 and channel 3 transfers are requested simultaneously and a channel 1 transfer is requested during the channel 0 transfer. The DMAC operates as follows: - 1. Transfer requests are generated simultaneously to channels 0 and 3. - 2. Channel 0 has a higher priority, so the channel 0 transfer begins first (channel 3 waits for transfer). - 3. A channel 1 transfer request occurs during the channel 0 transfer (channels 1 and 3 are both waiting) - 4. When the channel 0 transfer ends, channel 0 is given the lowest priority among the round-robin channels. - 5. At this point, channel 1 has a higher priority than channel 3, so the channel 1 transfer begins (channel 3 waits for transfer). - 6. When the channel 1 transfer ends, channel 1 is given the lowest priority among the round-robin channels. - 7. The channel 3 transfer begins. - 8. When the channel 3 transfer ends, channels 3 and 2 are lowered in priority so that channel 3 is given the lowest priority among the round-robin channels. Figure 8.4 Changes in Channel Priority in Round-Robin Mode # 8.4.4 DMA Transfer Types DMA transfer has two types; single address mode transfer and dual address mode transfer. They depend on the number of bus cycles of access to the transfer source and destination. A data transfer timing depends on the bus mode, which is the cycle steal mode or burst mode. The DMAC supports the transfers shown in table 8.9. **Table 8.9 Supported DMA Transfers** | | | | Transfer Destination | on | | |-------------------------------|---------------------------|--------------------|----------------------------------|------------------------------|-------------------| | Transfer Source | External Device with DACK | External<br>Memory | Memory-Mapped<br>External Device | On-Chip<br>Peripheral Module | On-Chip<br>Memory | | External device with DACK | Not available | Dual, single | Dual, single | Not available | Not available | | External memory | Dual, single | Dual | Dual | Dual | Dual | | Memory-mapped external device | Dual, single | Dual | Dual | Dual | Dual | | On-chip peripheral module | Not available | Dual | Dual | Dual | Dual | | On-chip memory | Not available | Dual | Dual | Dual | Dual | Notes: 1. Dual: Dual address mode - 2. Single: Single address mode - 16-byte transfer is available only for on-chip peripheral modules that support longword access. ## (1) Address Modes ## (a) Dual Address Mode In dual address mode, both the transfer source and destination are accessed (selected) by an address. The transfer source and destination can be located externally or internally. DMA transfer requires two bus cycles because data is read from the transfer source in a data read cycle and written to the transfer destination in a data write cycle. At this time, transfer data is temporarily stored in the DMAC. In the transfer between external memories as shown in figure 8.5, data is read to the DMAC from one external memory in a data read cycle, and then that data is written to the other external memory in a data write cycle. Figure 8.5 Data Flow of Dual Address Mode Auto request, external request, and on-chip peripheral module request are available for the transfer request. DACK can be output in read cycle or write cycle in dual address mode. The AM bit in the channel control register (CHCR) can specify whether the DACK is output in read cycle or write cycle. Figure 8.6 shows an example of DMA transfer timing in dual address mode. Figure 8.6 Example of DMA Transfer Timing in Dual Mode (Transfer Source: Normal Memory, Transfer Destination: Normal Memory) ## (b) Single Address Mode In single address mode, both the transfer source and destination are external devices, either of them is accessed (selected) by the DACK signal, and the other device is accessed by an address. In this mode, the DMAC performs one DMA transfer in one bus cycle, accessing one of the external devices by outputting the DACK transfer request acknowledge signal to it, and at the same time outputting an address to the other device involved in the transfer. For example, in the case of transfer between external memory and an external device with DACK shown in figure 8.7, when the external device outputs data to the data bus, that data is written to the external memory in the same bus cycle. Figure 8.7 Data Flow in Single Address Mode Two kinds of transfer are possible in single address mode: (1) transfer between an external device with DACK and a memory-mapped external device, and (2) transfer between an external device with DACK and external memory. In both cases, only the external request signal (DREQ) is used for transfer requests. Figure 8.8 shows an example of DMA transfer timing in single address mode. SH7670 Group Figure 8.8 Example of DMA Transfer Timing in Single Address Mode ## (2) Bus Modes There are two bus modes; cycle steal and burst. Select the mode by the TB bits in the channel control registers (CHCR). ## (a) Cycle Steal Mode #### Normal mode In normal mode of cycle steal, the bus mastership is given to another bus master after a one-transfer-unit (byte, word, longword, or 16-byte unit) DMA transfer. When another transfer request occurs, the bus mastership is obtained from another bus master and a transfer is performed for one transfer unit. When that transfer ends, the bus mastership is passed to another bus master. This is repeated until the transfer end conditions are satisfied. The cycle-steal normal mode can be used for any transfer section; transfer request source, transfer source, and transfer destination. Figure 8.9 shows an example of DMA transfer timing in cycle-steal normal mode. Transfer conditions shown in the figure are; - Dual address mode - DREQ low level detection Figure 8.9 DMA Transfer Example in Cycle-Steal Normal Mode (Dual Address, DREQ Low Level Detection) Intermittent Mode 16 and Intermittent Mode 64 In intermittent mode of cycle steal, DMAC returns the bus mastership to other bus master whenever a unit of transfer (byte, word, longword, or 16 bytes) is completed. If the next transfer request occurs after that, DMAC obtains the bus mastership from other bus master after waiting for 16 or 64 cycles of $B\phi$ clock. DMAC then transfers data of one unit and returns the bus mastership to other bus master. These operations are repeated until the transfer end condition is satisfied. It is thus possible to make lower the ratio of bus occupation by DMA transfer than the normal mode of cycle steal. When DMAC obtains again the bus mastership, DMA transfer may be postponed in case of entry updating due to cache miss. The cycle-steal intermittent mode can be used for any transfer section; transfer request source, transfer source, and transfer destination. The bus modes, however, must be cycle steal mode in all channels. Figure 8.10 shows an example of DMA transfer timing in cycle-steal intermittent mode. Transfer conditions shown in the figure are; - Dual address mode - DREQ low level detection Figure 8.10 Example of DMA Transfer in Cycle-Steal Intermittent Mode (Dual Address, DREQ Low Level Detection) ## (b) Burst Mode In burst mode, once the DMAC obtains the bus mastership, it does not release the bus mastership and continues to perform transfer until the transfer end condition is satisfied. In external request mode with low level detection of the DREQ pin, however, when the DREQ pin is driven high, the bus mastership is passed to another bus master after the DMAC transfer request that has already been accepted ends, even if the transfer end conditions have not been satisfied. Figure 8.11 shows DMA transfer timing in burst mode. Figure 8.11 DMA Transfer Example in Burst Mode (Dual Address, DREQ Low Level Detection) ## (3) Relationship between Request Modes and Bus Modes by DMA Transfer Category Table 8.10 shows the relationship between request modes and bus modes by DMA transfer category. A -1 -1--- - -- Table 8.10 Relationship of Request Modes and Bus Modes by DMA Transfer Category | Address<br>Mode | Transfer Category | Request<br>Mode | Bus<br>Mode | Transfer<br>Size (Bits) | Usable<br>Channels | |-----------------|-----------------------------------------------------------------|-------------------|-------------|-------------------------|--------------------| | Dual | External device with DACK and external memory | External | B/C | 8/16/32/128 | 0 and 1 | | | External device with DACK and memory-mapped external device | External | B/C | 8/16/32/128 | 0 and 1 | | | External memory and external memory | All* <sup>4</sup> | B/C | 8/16/32/128 | 0 to 7*3 | | | External memory and memory-mapped external device | All* <sup>4</sup> | B/C | 8/16/32/128 | 0 to 7*3 | | | Memory-mapped external device and memory-mapped external device | All* <sup>4</sup> | B/C | 8/16/32/128 | 0 to 7*3 | | | External memory and on-chip peripheral module | All*1 | B/C*5 | 8/16/32/128*2 | 0 to 7*3 | | | Memory-mapped external device and on-chip peripheral module | All*1 | B/C*5 | 8/16/32/128*2 | 0 to 7*3 | | | On-chip peripheral module and on-chip peripheral module | All*1 | B/C*5 | 8/16/32/128*2 | 0 to 7*3 | | | On-chip memory and on-chip memory | All* <sup>4</sup> | B/C | 8/16/32/128 | 0 to 7*3 | | | On-chip memory and memory-mapped external device | All* <sup>4</sup> | B/C | 8/16/32/128 | 0 to 7*3 | | | On-chip memory and on-chip peripheral module | All*1 | B/C*5 | 8/16/32/128*2 | 0 to 7*3 | | | On-chip memory and external memory | All* <sup>4</sup> | B/C | 8/16/32/128 | 0 to 7*3 | | Single | External device with DACK and external memory | External | B/C | 8/16/32/128 | 0 and 1 | | | External device with DACK and memory-mapped external device | External | B/C | 8/16/32/128 | 0 and 1 | | | | - | _ | | | [Legend] B: Burst C: Cycle steal Notes: 1. External requests, auto requests, and on-chip peripheral module requests are all available. However, in the case of internal module request, along with the exception of CMT as the transfer request source, the requesting module must be designated as the transfer source or the transfer destination. - Access size permitted for the on-chip peripheral module register functioning as the transfer source or transfer destination. - 3. If the transfer request is an external request, channels 0 to 3 are only available. - External requests, auto requests, and on-chip peripheral module requests are all available. In the case of on-chip peripheral module requests, however, the CMT are only available. - 5. In the case of internal module request, only cycle steal except for the USB, SSI, and CMT as the transfer request source. ## (4) Bus Mode and Channel Priority In priority fixed mode (CH0 > CH1), when channel 1 is transferring data in burst mode and a request arrives for transfer on channel 0, which has higher-priority, the data transfer on channel 0 will begin immediately. In this case, if the transfer on channel 0 is also in burst mode, the transfer on channel 1 will only resume on completion of the transfer on channel 0. When channel 0 is in cycle steal mode, one transfer-unit of data on this channel, which has the higher priority, is transferred. Data is then transferred continuously to channel 1 without releasing the bus. The bus mastership will then switch between the two in this order: channel 0, channel 1, channel 0, channel 1, etc. That is, the CPU cycle after the data transfer in cycle steal mode is replaced with a burst-mode transfer cycle (priority execution of burst-mode cycle). An example of this is shown in figure 8.12. When multiple channels are in burst mode, data transfer on the channel that has the highest priority is given precedence. When DMA transfer is being performed on multiple channels, the bus mastership is not released to another bus-master device until all of the competing burst-mode transfers have been completed. Figure 8.12 Bus State when Multiple Channels are Operating In round-robin mode, the priority changes as shown in figure 8.3. Note that channels in cycle steal and burst modes must not be mixed. ### 8.4.5 Number of Bus Cycles and DREQ Pin Sampling Timing ### (1)**Number of Bus Cycles** When the DMAC is the bus master, the number of bus cycles is controlled by the bus state controller (BSC) in the same way as when the CPU is the bus master. For details, see section 7, Bus State Controller (BSC). ### **(2) DREQ Pin Sampling Timing** Figures 8.13 to 8.16 show the DREQ input sampling timings in each bus mode. Figure 8.13 Example of DREQ Input Detection in Cycle Steal Mode Edge Detection Figure 8.14 Example of DREQ Input Detection in Cycle Steal Mode Level Detection Figure 8.15 Example of DREQ Input Detection in Burst Mode Edge Detection Figure 8.16 Example of DREQ Input Detection in Burst Mode Level Detection Figure 8.17 shows the TEND output timing. Figure 8.17 Example of DMA Transfer End Signal Timing (Cycle Steal Mode Level Detection) The unit of the DMA transfer is divided into multiple bus cycles when 16-byte transfer is performed for an 8-bit, 16-bit, or 32-bit external device, when longword access is performed for an 8-bit or 16-bit external device, or when word access is performed for an 8-bit external device. When a setting is made so that the DMA transfer size is divided into multiple bus cycles and the $\overline{\text{CS}}$ signal is negated between bus cycles, note that DACK and TEND are divided like the $\overline{\text{CS}}$ signal for data alignment as shown in figure 8.18. Figures 8.13 to 8.17 show cases in which DACK and TEND are not divided at the time of DMA transfer. Figure 8.18 BSC Normal Memory Access (No Wait, Idle Cycle 1, Longword Access to 16-Bit Device) # 8.5 Usage Notes ## 8.5.1 NMIF Bit (NMI Flag) in DMA Operation Register (DMAOR) When the flag is read with the same timing as flag setting, the flag is read as 0 but internally the LSI might enter the state where 1 has been read in some cases. Accordingly, if 0 is written to the flag in this state, the flag is cleared to 0 in the same way as when 0 is written to the flag after 1 is read. When using this flag, take the following steps to read from and write to the flag to prevent unexpected clearing of the flag. Only when explicitly clearing the flag, write 0 to the flag after reading 1; in other cases, the write value should always be 1. When the flag is not used, the write value should always be 0 (write 0 after reading 1 only when explicitly clearing the flag). ## 8.5.2 Half-End Flag Setting and Half-End Interrupt Generation Note the following when the half-end flag in CHCR is referred to or the half-end interrupt is used while the reload function is used. The reload transfer count (the RDMATCR setting) should be the same value as the initial transfer count (the DMATCR setting). If the initial DMATCR setting and the RDMATCR setting used for the second or later transfers differ, the half-end flag or interrupt might be set or generated before the transfer count reaches half of the specified value, or the half-end flag or interrupt might never be set or generated. # Section 9 Clock Pulse Generator (CPG) This LSI has a clock pulse generator (CPG) that generates an internal clock ( $I\phi$ ), a peripheral clock ( $P\phi$ ), and a bus clock ( $B\phi$ ). The CPG consists of a crystal oscillator, PLL circuits, and divider circuits. ## 9.1 Features Four clock operating modes The mode can be selected from among the four clock operating modes (three clock operating modes in the wide temperature specifications) based on the frequency range to be used and the input clock type: the crystal resonator, the external clock, the crystal resonator for USB, or the external clock for USB. - Three clocks generated independently An internal clock (Iφ) for the CPU and cache; a peripheral clock (Pφ) for the on-chip peripheral modules; a bus clock (Bφ = CKIO) for the external bus interface - Frequency change function Internal and peripheral clock frequencies can be changed independently using the PLL (phase locked loop) circuits and divider circuits within the CPG. Frequencies are changed by software using frequency control register (FRQCR) settings. - Power-down mode control The clock can be stopped in sleep mode and software standby mode, and specific modules can be stopped using the module standby function. For details on clock control in the power-down modes, see section 11, Power-Down Modes. Figure 9.1 shows a block diagram of the clock pulse generator. Figure 9.1 Block Diagram of Clock Pulse Generator The clock pulse generator blocks function as follows: ### **Crystal Oscillator (1)** The crystal oscillator is an oscillation circuit in which the crystal resonator is connected to the XTAL/EXTAL pin or USB X1/USB X2 pin. This can be used according to the clock operating mode. #### **(2)** Divider 1 Divider 1 divides the frequency of one of the three clocks: the clock from the crystal resonator or the EXTAL pin, the clock from the CKIO pin, and the clock from the crystal resonator or the USB X1 pin. The division ratio depends on the clock operating mode. ### **(3) PLL Circuit** The PLL circuit multiplies the frequency of the output from divider 1 by 8 or 12. The multiplication rate is set by the frequency control register. When this is done, the phase of the rising edge of the internal clock is controlled so that it will agree with the phase of the rising edge of the CKIO pin. The input clock to be used depends on the clock operating mode. The clock operating mode is specified using the MD\_CK0 and MD\_CK1 pins. For details on the clock operating mode, see table 9.2. ### **(4)** Divider 2 Divider 2 divides the frequency of output of the PLL circuit to generate an internal clock, a bus clock, and a peripheral clock. The internal clock can be 1 or 1/2 times the output frequency of the PLL circuit, and it should not be lower than the clock frequency on the CKIO pin. The peripheral clock can be 1/4, 1/6, 1/8, or 1/12 times the output frequency of the PLL circuit, and it should not be higher than the half of the clock frequency on the CKIO pin. The bus clock is automatically determined by hardware at the division ratio against the output frequency of the PLL circuit so that it will be 4 times the clock source (when clock mode = 0), 2 times (when clock mode = 1 or 3), or 1 times (when clock mode = 2). ### **(5) Clock Frequency Control Circuit** The clock frequency control circuit controls the clock frequency using the MD CK0 and MD CK1 pins and the frequency control register (FRQCR). ## (6) Standby Control Circuit The standby control circuit controls the states of the clock pulse generator and other modules during clock switching, or sleep or software standby mode. In addition, the standby control register is provided to control the power-down mode of other modules. For details on the standby control register, see section 11, Power-Down Modes. # (7) Frequency Control Register (FRQCR) The frequency control register (FRQCR) has control bits assigned for the following functions: clock output/non-output from the CKIO pin during software standby mode, the frequency multiplication ratio of PLL circuit, and the frequency division ratio of the internal clock and the peripheral clock ( $P\phi$ ). ### 9.2 **Input/Output Pins** Table 9.1 lists the clock pulse generator pins and their functions. **Table 9.1** Pin Configuration and Functions of the Clock Pulse Generator | Pin Name | Symbol | I/O | Function<br>(Clock<br>Operating<br>Mode 0) | Function<br>(Clock<br>Operating<br>Mode 1) | Function<br>(Clock<br>Operating<br>Mode 2) | Function<br>(Clock<br>Operating<br>Mode 3) | |-------------------------------------------------------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------| | Mode control pins | MD_<br>CLK0 | Input | Sets the clock o | perating mode. | | | | | MD_<br>CLK1 | Input | Sets the clock o | perating mode. | | | | Crystal<br>input/output<br>pins (clock<br>input pins) | XTAL | Output | Connected to<br>the crystal<br>resonator.<br>(Leave this pin<br>open when the<br>crystal<br>resonator is not<br>in use.) | Leave this pin open. | Leave this pin open. | Leave this pin open. | | | EXTAL | Input | Connected to<br>the crystal<br>resonator or<br>used to input<br>external clock. | Used as an external clock input terminal. | Pull-up this pin. | Pull-up this pin. | | Clock<br>input/output<br>pin | CKIO | I/O | Clock output pin. | Clock output<br>pin | Clock input pin | Clock output<br>pin | | Pin Name | Symbol | I/O | Function<br>(Clock<br>Operating<br>Mode 0) | Function<br>(Clock<br>Operating<br>Mode 1) | Function<br>(Clock<br>Operating<br>Mode 2) | Function<br>(Clock<br>Operating<br>Mode 3) | |---------------------------------------------------------------------|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | Crystal<br>input/output<br>pins for<br>USB<br>(clock input<br>pins) | USB_X1 | Input | Connected to<br>the crystal<br>resonator to<br>input the clock<br>for USB only, or<br>used to input<br>external clock.<br>When USB is<br>not used, this<br>pin should be<br>pulled up. | Connected to<br>the crystal<br>resonator to<br>input the clock<br>for USB only, or<br>used to input<br>external clock.<br>When USB is<br>not used, this<br>pin should be<br>pulled up. | Connected to<br>the crystal<br>resonator to<br>input the clock<br>for USB only, or<br>used to input<br>external clock.<br>When USB is<br>not used, this<br>pin should be<br>pulled up. | Connected to<br>the crystal<br>resonator to<br>input the clock<br>for both USB<br>and the LSI, or<br>used to input<br>external clock. | | | USB_X2 | Output | the crystal<br>resonator for<br>USB.<br>(Leave this pin<br>open when the<br>crystal | Connected to<br>the crystal<br>resonator for<br>USB.<br>(Leave this pin<br>open when the<br>crystal<br>resonator is not<br>in use.) | Connected to<br>the crystal<br>resonator for<br>USB.<br>(Leave this pin<br>open when the<br>crystal<br>resonator is not<br>in use.) | Connected to<br>the crystal<br>resonator for<br>both USB and<br>the LSI.<br>(Leave this pin<br>open when the<br>crystal<br>resonator is not<br>in use.) | # 9.3 Clock Operating Modes Table 9.2 shows the relationship between the combinations of the mode control pins (MD\_CK1 and MD\_CK0) and the clock operating modes. Table 9.3 shows the usable frequency ranges in the clock operating modes. **Table 9.2** Clock Operating Modes | | Pin \ | /alues | Clock I/C | ) | | PLL Circuit | | | | |------|--------|--------|-----------------------------|--------|-----------|--------------|----------------------------------------|--|--| | Mode | MD_CK1 | MD_CK0 | Source | Output | Divider 2 | On/Off | CKIO Frequency | | | | 0 | 0 | 0 | EXTAL or crystal resonator | CKIO | 1 | ON (× 8, 12) | (EXTAL or crystal resonator) × 4 | | | | 1 | 0 | 1 | EXTAL | CKIO | 1/2 | ON (× 8, 12) | (EXTAL) × 2 | | | | 2 | 1 | 0 | CKIO | | 1/4 | ON (× 8, 12) | (CKIO) | | | | 3 | 1 | 1 | USB_X1 or crystal resonator | CKIO | 1/2 | ON (× 8) | (USB_X1 or<br>crystal resonator)<br>×2 | | | ## Mode 0 In mode 0, clock is input from the EXTAL pin or the crystal resonator. The PLL circuit shapes waveforms and the frequency is multiplied according to the frequency control register setting before the clock is supplied to the LSI. The oscillating frequency for the crystal resonator and EXTAL pin input clock ranges from 15 to 25 MHz (15 to 16.6 MHz in the wide temperature specifications). The frequency range of CKIO is from 60 to 100 MHz (60 MHz to 66.6 MHz in the wide temperature specifications). To reduce current supply, pull up the USB\_X1 pin and open the USB X2 pin when USB is not used. ### Mode 1 In mode 1, clock is input from the EXTAL pin. The PLL circuit shapes waveform and the frequency is multiplied according to the frequency control register setting before the clock is supplied to the LSI. The oscillating frequency for the EXTAL pin input clock ranges from 30 to 50 MHz (30 to 33.3 MHz in the wide temperature specifications). The frequency range of CKIO is from 60 to 100 MHz (60 to 66.6 MHz in the wide temperature specifications). To reduce current supply, pull up the USB\_X1 pin and open the USB\_X2 pin when USB is not used. ### Mode 2 In mode 2, the CKIO pin functions as an input pin and draws an external clock signal. The PLL circuit shapes waveform and the frequency is multiplied according to the frequency control register setting before the clock is supplied to the LSI. The frequency range of CKIO is from 60 to 100 MHz (60 to 66.6 MHz in the wide temperature specifications). To reduce current supply, pull up the EXTAL pin and open the XTAL pin when the LSI is used in mode 2. When USB is not used, pull up the USB\_X1 pin and open the USB\_X2 pin. ## • Mode 3 In mode 3, clock is input from the USB\_X1 pin or the crystal oscillator. The external clock is input through this pin and waveform is shaped in the PLL circuit. Then the frequency is multiplied according to the frequency control register setting before the clock is supplied to the LSI. The frequency of CKIO is the same as that of the input clock 96 MHz. To reduce current supply, pull up the EXTAL pin and open the XTAL pin when the LSI is used in mode 3. When the USB crystal resonator is not used, open the USB\_X2 pin. Note that this mode is supported only in the regular specifications; it is not supported in the wide temperature specifications. Table 9.3 Relationship between Clock Operating Mode and Frequency Range (1) ВΙΙ Regular Specifications $Restrictions:\ I\varphi \leq 200MHz,\ B\varphi \leq 100MHz,\ P\varphi \leq 50MHz,\ I\varphi \leq B\varphi \leq P\varphi \times 2$ | Clock | | | Frequency<br>Multiplier | Ratio of<br>Internal<br>Clock | | ige (MHz) | | | | |-------------------|--------|-----------|-------------------------|-------------------------------|----------------|----------------------------|------------------------|-------------------|--------------------------| | Operating<br>Mode | | Divider 1 | PLL<br>Circuit | Frequencies (I:B:P)*2 | Input Clock*3 | Output Clock<br>(CKIO Pin) | Internal Clock<br>(Iø) | Bus Clock<br>(Βφ) | Peripheral<br>Clock (Pø) | | 0 | H'x003 | 1/1 | ON (× 8) | 8:4:2 | 15.00 to 25.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 30.00 to 50.00 | | | H'x004 | 1/1 | ON (× 8) | 8:4:4/3 | 15.00 to 25.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 20.00 to 33.33 | | | H'x005 | 1/1 | ON (× 8) | 8:4:1 | 15.00 to 25.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 15.00 to 25.00 | | | H'x006 | 1/1 | ON (× 8) | 8:4:2/3 | 15.00 to 25.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 10.00 to 16.67 | | | H'x013 | 1/1 | ON (× 8) | 4:4:2 | 15.00 to 25.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 30.00 to 50.00 | | | H'x014 | 1/1 | ON (× 8) | 4:4:4/3 | 15.00 to 25.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 20.00 to 33.33 | | | H'x015 | 1/1 | ON (× 8) | 4:4:1 | 15.00 to 25.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 15.00 to 25.00 | | | H'x016 | 1/1 | ON (× 8) | 4:4:2/3 | 15.00 to 25.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 10.00 to 16.67 | | | H'x104 | 1/1 | ON (× 12) | 12:4:2 | 15.00 to 16.67 | 60.00 to 66.67 | 180.00 to 200.00 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x106 | 1/1 | ON (× 12) | 12:4:1 | 15.00 to 16.67 | 60.00 to 66.67 | 180.00 to 200.00 | 60.00 to 66.67 | 15.00 to 16.67 | | Clock | | | PLL<br>Frequency<br>Multiplier | Ratio of<br>Internal<br>Clock | | Selectabl | le Frequency Ran | ge (MHz) | | |-------------------|--------------------------------|-----------|--------------------------------|-------------------------------|-----------------|----------------------------|------------------------|-------------------|--------------------------| | Operating<br>Mode | FRQCR<br>Setting* <sup>1</sup> | Divider 1 | PLL<br>Circuit | Frequencies (I:B:P)*2 | Input Clock*3 | Output Clock<br>(CKIO Pin) | Internal Clock<br>(I ) | Bus Clock<br>(Βφ) | Peripheral<br>Clock (Pφ) | | 1 | H'x003 | 1/2 | ON (× 8) | 4:2:1 | 30.00 to 50.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 30.00 to 50.00 | | | H'x004 | 1/2 | ON (× 8) | 4:2:4/3 | 30.00 to 50.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 20.00 to 33.33 | | | H'x005 | 1/2 | ON (× 8) | 4:2:1/2 | 30.00 to 50.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 15.00 to 25.00 | | | H'x006 | 1/2 | ON (× 8) | 4:1:1/3 | 30.00 to 50.00 | 60.00 to 100.00 | 120.00 to 200.00 | 60.00 to 100.00 | 10.00 to 16.67 | | | H'x013 | 1/2 | ON(× 8) | 2:2:1 | 30.00 to 50.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 30.00 to 50.00 | | | H'x014 | 1/2 | ON(× 8) | 2:2:2/3 | 30.00 to 50.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 20.00 to 33.33 | | | H'x015 | 1/2 | ON(× 8) | 2:2:1/2 | 30.00 to 50.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 15.00 to 25.00 | | | H'x016 | 1/2 | ON(× 8) | 2:2:1/3 | 30.00 to 50.00 | 60.00 to 100.00 | 60.00 to 100.00 | 60.00 to 100.00 | 10.00 to 16.67 | | | H'x104 | 1/2 | ON (× 12) | 6:2:1 | 30.00 to 33.33 | 60.00 to 66.67 | 180.00 to 200.00 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x106 | 1/2 | ON (× 12) | 6:2:1/2 | 30.00 to 33.33 | 60.00 to 66.67 | 180.00 to 200.00 | 60.00 to 66.67 | 15.00 to 16.67 | | 2 | H'x003 | 1/4 | ON (× 8) | 2:1:1/2 | 60.00 to 100.00 | _ | 120.00 to 200.00 | 60.00 to 100.00 | 30.00 to 50.00 | | | H'x004 | 1/4 | ON (× 8) | 2:1:1/3 | 60.00 to 100.00 | _ | 120.00 to 200.00 | 60.00 to 100.00 | 20.00 to 33.33 | | | H'x005 | 1/4 | ON (× 8) | 2:1:1/4 | 60.00 to 100.00 | _ | 120.00 to 200.00 | 60.00 to 100.00 | 15.00 to 25.00 | | | H'x006 | 1/4 | ON (× 8) | 2:1:1/6 | 60.00 to 100.00 | _ | 120.00 to 200.00 | 60.00 to 100.00 | 10.00 to 16.67 | | | H'x013 | 1/4 | ON (× 8) | 1:1:1/2 | 60.00 to 100.00 | _ | 60.00 to 100.00 | 60.00 to 100.00 | 30.00 to 50.00 | | | H'x014 | 1/4 | ON (× 8) | 1:1:1/3 | 60.00 to 100.00 | _ | 60.00 to 100.00 | 60.00 to 100.00 | 20.00 to 33.33 | | | H'x015 | 1/4 | ON (× 8) | 1:1:1/4 | 60.00 to 100.00 | _ | 60.00 to 100.00 | 60.00 to 100.00 | 15.00 to 25.00 | | | H'x016 | 1/4 | ON (× 8) | 1:1:1/6 | 60.00 to 100.00 | _ | 60.00 to 100.00 | 60.00 to 100.00 | 10.00 to 16.67 | | | H'x104 | 1/4 | ON (× 12) | 3:1:1/2 | 60.00 to 66.67 | _ | 180.00 to 200.00 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x106 | 1/4 | ON (× 12) | 3:1:1/4 | 60.00 to 66.67 | _ | 180.00 to 200.00 | 60.00 to 66.67 | 15.00 to 16.67 | | 3 | H'x003 | 1/2 | ON (× 8) | 4:2:1 | 48.00 to 48.00 | 96.00 to 96.00 | 192.00 to 192.00 | 96.00 to 96.00 | 48.00 to 48.00 | | | H'x004 | 1/2 | ON (× 8) | 4:2:2/3 | 48.00 to 48.00 | 96.00 to 96.00 | 192.00 to 192.00 | 96.00 to 96.00 | 32.00 to 32.00 | | | H'x005 | 1/2 | ON (× 8) | 4:2:1/2 | 48.00 to 48.00 | 96.00 to 96.00 | 192.00 to 192.00 | 96.00 to 96.00 | 24.00 to 24.00 | | | H'x006 | 1/2 | ON (× 8) | 4:2:1/3 | 48.00 to 48.00 | 96.00 to 96.00 | 192.00 to 192.00 | 96.00 to 96.00 | 16.00 to 16.00 | | | H'x013 | 1/2 | ON (× 8) | 2:2:1 | 48.00 to 48.00 | 96.00 to 96.00 | 96.00 to 96.00 | 96.00 to 96.00 | 48.00 to 48.00 | | | H'x014 | 1/2 | ON (× 8) | 2:2:2/3 | 48.00 to 48.00 | 96.00 to 96.00 | 96.00 to 96.00 | 96.00 to 96.00 | 32.00 to 32.00 | | | H'x015 | 1/2 | ON (× 8) | 2:2:1/2 | 48.00 to 48.00 | 96.00 to 96.00 | 96.00 to 96.00 | 96.00 to 96.00 | 24.00 to 24.00 | | | H'x016 | 1/2 | ON (× 8) | 2:2:1/3 | 48.00 to 48.00 | 96.00 to 96.00 | 96.00 to 96.00 | 96.00 to 96.00 | 16.00 to 16.00 | Table 9.3 Relationship between Clock Operating Mode and Frequency Range (2) wide temperature Specifications Restrictions: $I\phi \le 200MHz$ , $B\phi \le 100MHz$ , $P\phi \le 50MHz$ , $I\phi \le B\phi \le P\phi \times 2$ | Clock | | | PLL<br>Frequency<br>Multiplier | Ratio of<br>Internal<br>Clock | Selectable Free | quency Range (MI | Hz) | | | |-------------------|--------------------------------|--------------|--------------------------------|-------------------------------|-----------------|----------------------------|------------------------|-------------------|--------------------------| | Operating<br>Mode | FRQCR<br>Setting* <sup>1</sup> | Divider<br>1 | PLL<br>Circuit | Frequencies (I:B:P)*2 | Input Clock*3 | Output Clock<br>(CKIO Pin) | Internal Clock<br>(Ιφ) | Bus Clock<br>(Bø) | Peripheral<br>Clock (Pø) | | 0 | H'x003 | 1/1 | ON (× 8) | 8/4/2 | 15.00 to 16.67 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x004 | 1/1 | ON (× 8) | 8/4/4/3 | 15.00 to 16.67 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 20.00 to 22.22 | | | H'x005 | 1/1 | ON (× 8) | 8/4/1 | 15.00 to 16.67 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 15.00 to 16.67 | | | H'x006 | 1/1 | ON (× 8) | 8/4/2/3 | 15.00 to 16.67 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 10.00 to 11.11 | | | H'x013 | 1/1 | ON (× 8) | 4/4/2 | 15.00 to 16.67 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x014 | 1/1 | ON (× 8) | 4/4/4/3 | 15.00 to 16.67 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 20.00 to 22.22 | | | H'x015 | 1/1 | ON (× 8) | 4/4/1 | 15.00 to 16.67 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 15.00 to 16.67 | | | H'x016 | 1/1 | ON (× 8) | 4/4/2/3 | 15.00 to 16.67 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 10.00 to 11.11 | | 1 | H'x003 | 1/2 | ON (× 8) | 4/2/1 | 30.00 to 33.33 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x004 | 1/2 | ON (× 8) | 4/2/2/3 | 30.00 to 33.33 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 20.00 to 22.22 | | | H'x005 | 1/2 | ON (× 8) | 4/2/1/2 | 30.00 to 33.33 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 15.00 to 16.67 | | | H'x006 | 1/2 | ON (× 8) | 4/2/1/3 | 30.00 to 33.33 | 60.00 to 66.67 | 120.00 to 133.33 | 60.00 to 66.67 | 10.00 to 11.11 | | | H'x013 | 1/2 | ON (× 8) | 2/2/1 | 30.00 to 33.33 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x014 | 1/2 | ON (× 8) | 2/2/2/3 | 30.00 to 33.33 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 20.00 to 22.22 | | | H'x015 | 1/2 | ON (× 8) | 2/2/1/2 | 30.00 to 33.33 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 15.00 to 16.67 | | | H'x016 | 1/2 | ON (× 8) | 2/2/1/3 | 30.00 to 33.33 | 60.00 to 66.67 | 60.00 to 66.67 | 60.00 to 66.67 | 10.00 to 11.11 | | 2 | H'x003 | 1/4 | ON (× 8) | 2/1/1/2 | 60.00 to 66.67 | _ | 120.00 to 133.33 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x004 | 1/4 | ON (× 8) | 2/1/1/3 | 60.00 to 66.67 | _ | 120.00 to 133.33 | 60.00 to 66.67 | 20.00 to 22.22 | | | H'x005 | 1/4 | ON (× 8) | 2/1/1/4 | 60.00 to 66.67 | _ | 120.00 to 133.33 | 60.00 to 66.67 | 15.00 to 16.67 | | | H'x006 | 1/4 | ON (× 8) | 2/1/1/6 | 60.00 to 66.67 | _ | 120.00 to 133.33 | 60.00 to 66.67 | 10.00 to 11.11 | | | H'x013 | 1/4 | ON (× 8) | 1/1/1/2 | 60.00 to 66.67 | _ | 60.00 to 66.67 | 60.00 to 66.67 | 30.00 to 33.33 | | | H'x014 | 1/4 | ON (× 8) | 1/1/1/3 | 60.00 to 66.67 | _ | 60.00 to 66.67 | 60.00 to 66.67 | 20.00 to 22.22 | | | H'x015 | 1/4 | ON (× 8) | 1/1/1/4 | 60.00 to 66.67 | _ | 60.00 to 66.67 | 60.00 to 66.67 | 15.00 to 16.67 | | | H'x016 | 1/4 | ON (× 8) | 1/1/1/6 | 60.00 to 66.67 | _ | 60.00 to 66.67 | 60.00 to 66.67 | 10.00 to 11.11 | Notes: 1. x in the FRQCR register setting depends on the set value in bits 12 and 13. 2. The ratio of clock frequencies, where the input clock frequency is assumed to be 1. 3. In mode 0, the frequency of the EXTAL pin input clock or the crystal resonator In mode 1, the frequency of the EXTAL pin input clock In mode 2, the frequency of the CKIO pin input clock. In mode 3, the frequency of the USB\_X1 pin input clock or the crystal resonator #### Cautions: 1. The frequency of the internal clock is as follows: | In mode 0 | the frequency on the EXTAL pin $\times$ the frequency-multiplier of the PLL circuit $\times$ the divisor of the divider 1 | |-----------|------------------------------------------------------------------------------------------------------------------------------------------| | In mode 1 | (the frequency on the EXTAL pin $\times$ 1/2) $\times$ the frequency-multiplier of the PLL circuit $\times$ the divisor of the divider 1 | | In mode 2 | (the frequency on the CKIO pin $\times$ 1/4) $\times$ the frequency-multiplier of the PLL circuit $\times$ the divisor of the divider 1 | | In mode 3 | (the frequency on the USB_X1pin $\times$ 1/2) $\times$ the frequency-multiplier of the PLL circuit $\times$ the divisor of the divider 1 | The frequency of the internal clock should not be set lower than the frequency on the CKIO pin. - 2. The frequency of the peripheral clock is as follows: - In mode 0 the frequency on the EXTAL pin × the frequency-multiplier of the PLL circuit × the divisor of the divider 1 - In mode 1 (the frequency on the EXTAL pin $\times$ 1/2) $\times$ the frequency-multiplier of the PLL circuit × the divisor of the divider 1 - In mode 2 (the frequency on the CKIO pin $\times$ 1/4) $\times$ the frequency-multiplier of the PLL circuit × the divisor of the divider 1 - In mode 3 (the frequency on the USB X1 pin $\times$ 1/2) $\times$ the frequency-multiplier of the PLL circuit × the divisor of the divider 1 The frequency of the peripheral clock should be set to 50 MHz or less, and should not be set higher than one half of the frequency on the CKIO pin. - 3. The frequency multiplier of PLL circuit can be selected as $\times 8$ or $\times$ 12. The divisor of the divider can be selected as $\times$ 1, $\times$ 1/2, $\times$ 1/3, $\times$ 1/4, $\times$ 1/6, $\times$ 1/8, or $\times$ 1/12. The settings are made in the frequency-control register (FRQCR). - 4. The output frequency of the PLL circuit is as follows: - In mode 0 the frequency on the EXTAL pin × the frequency-multiplier of the PLL circuit - In mode 1 (the frequency on the EXTAL pin $\times$ 1/2) $\times$ the frequency-multiplier of the PLL circuit - In mode 2 (the frequency on the CKIO pin $\times$ 1/4) $\times$ the frequency-multiplier of the PLL circuit - In mode 3 (the frequency on the USB\_X1 pin $\times$ 1/2) $\times$ the frequency-multiplier of the PLL circuit Ensure that the output frequency of the PLL circuit should be 200 MHz or less. # 9.4 Register Descriptions The clock pulse generator has the following registers. **Table 9.4** Register Configuration | Register Name | Abbreviation | R/W | Initial Value | Address | Access Size | |----------------------------|--------------|-----|---------------|------------|-------------| | Frequency control register | FRQCR | R/W | H'0003 | H'FFFE0010 | 16 | ## 9.4.1 Frequency Control Register (FRQCR) FRQCR is a 16-bit readable/writable register used to specify whether a clock is output from the CKIO pin during normal operation mode, software standby mode and standby mode cancellation. The register also specifies the frequency-multiplier of the PLL circuit and the frequency division ratio for the internal clock and peripheral clock ( $P\phi$ ). FRQCR is accessed by word. FRQCR is initialized to H'0003 only by a power-on reset or in deep standby. FRQCR retains its previous value in manual reset or software standby mode. The previous value is also retained when an internal reset is triggered by an overflow of the WDT. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|------|--------|----|----|-----|-------|---|---|---|-----|---|-----|----------|-----| | | - | - | CKOE | N[1:0] | - | - | STC | [1:0] | - | - | - | IFC | - | | PFC[2:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | R/W: | R | R | R/W | R/W | R | R | R/W | R/W | R | R | R | R/W | R | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------| | 15, 14 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Desc | ription | | | | | |--------|------------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------------------------|--|--|--| | 13, 12 | CKOEN[1:0] | 00 | R/W | Clock | Output Enable | | | | | | | | | | Specifies the CKIO pin outputs clock signals, or is set to a fixed level or high impedance (Hi-Z) during normal operation mode, standby mode, or cancellation of standby mode. | | | | | | | | | | | If these bits are set to 01, the CKIO pin is fixed at low during standby mode or cancellation of standby mode. Therefore, the malfunction of an external circui caused by an unstable CKIO clock during cancellation of standby mode can be prevented. In clock operating mode 2, the CKIO pin functions as an input regardless of the value of these bits. | | | | | | | | | | | In normal operation In standby mode | | | | | | | | | | | 00 | Output | Output off (Hi-Z) | | | | | | | | | 01 | Output | Low-level output | | | | | | | | | 10 | Output | Output (unstable clock output) | | | | | | | | | 11 | Output off (Hi-Z) | Output off (Hi-Z) | | | | | 11, 10 | _ | All 0 | R | Rese | rved | | | | | | | | | | | e bits are always read a<br>d always be 0. | s 0. The write value | | | | | 9, 8 | STC[1:0] | 00 | R/W | Frequ | ency Multiplication Rati | o of PLL Circuit | | | | | | | | | 00:× | 8 time | | | | | | | | | | 01:× | 12 times | | | | | | | | | | 10: R | eserved (setting prohibi | ted) | | | | | | | | | 11: Reserved (setting prohibited) | | | | | | | 7 to 5 | _ | All 0 | R | Rese | rved | | | | | | | | | | | e bits are always read a<br>d always be 0. | s 0. The write value | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-------|------------------------------------------------------------------------------------------------------------------------------| | 4 | IFC | 0 | R/W | Internal Clock Frequency Division Ratio | | 4 | IFO | U | □/ VV | This bit specifies the frequency division ratio of the | | | | | | internal clock with respect to the output frequency of PLL circuit. | | | | | | 0: × 1 time | | | | | | 1: × 1/2 time | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 to 0 | PFC[2:0] | 011 | R/W | Peripheral Clock Frequency Division Ratio | | | | | | These bits specify the frequency division ratio of the peripheral clock with respect to the output frequency of PLL circuit. | | | | | | 000: Reserved (setting prohibited) | | | | | | 001: Reserved (setting prohibited) | | | | | | 010: Reserved (setting prohibited) | | | | | | 011: × 1/4 time | | | | | | 100: × 1/6 time | | | | | | 101: × 1/8 time | | | | | | 110: × 1/12 time | | | | | | 111: Reserved (setting prohibited) | # 9.5 Changing the Frequency The frequency of the internal clock ( $I\phi$ ) and peripheral clock ( $P\phi$ ) can be changed either by changing the multiplication rate of PLL circuit or by changing the division rates of divider. All of these are controlled by software through the frequency control register (FRQCR). The methods are described below. # 9.5.1 Changing the Multiplication Rate A PLL settling time is required when the multiplication rate of PLL circuit is changed. The onchip WDT counts the settling time. - 1. In the initial state, the multiplication rate of PLL circuit is 8 time. - 2. Set a value that will become the specified oscillation settling time in the WDT and stop the WDT. The following must be set: WTCSR.TME = 0: WDT stops WTCSR.CKS[2:0]: Division ratio of WDT count clock WTCNT counter: Initial counter value (The WDT count is incremented using the clock after the setting.) - 3. Set the desired value in the STC1 and STC0 bits. The division ratio can also be set in the IFC and PFC2 to PFC0 bits. - 4. This LSI pauses temporarily and the WDT starts incrementing. The internal and peripheral clocks both stop and the WDT is supplied with the clock. The clock will continue to be output at the CKIO pin. This state is the same as software standby mode. Whether or not registers are initialized depends on the module. For details, see section 28.3, Register States in Each Operating Mode. - 5. Supply of the clock that has been set begins at WDT count overflow, and this LSI begins operating again. The WDT stops after it overflows. Page 360 of 1278 # 9.5.2 Changing the Division Ratio Counting by the WDT does not proceed if the frequency divisor is changed but the multiplier is not. - 1. In the initial state, IFC = B'0 and PFC[2:0] = B'011. - 2. Set the desired value in the IFC and PFC2 to IFC0 bits. The values that can be set are limited by the clock operating mode and the multiplication rate of PLL circuit. Note that if the wrong value is set, this LSI will malfunction. - 3. After the register bits (IFC and PFC2 to PFC0) have been set, the clock is supplied of the new division ratio. Note: When executing the SLEEP instruction after the frequency has been changed, be sure to read the frequency control register (FRQCR) three times before executing the SLEEP instruction. # 9.6 Notes on Board Design ## 9.6.1 Note on Inputting External Clock Figure 9.2 is an example of connecting the external clock input. When putting the XTAL pin in open state, make sure the parasitic capacitance is less than or equal to 10 pF. To stably input the external clock with enough PLL stabilizing time at power on or releasing the standby, wait longer than the oscillation stabilizing time. Figure 9.2 Example of Connecting External Clock ## 9.6.2 Note on Using an External Crystal Resonator Place the crystal resonator and capacitors CL1 and CL2 as close to the XTAL and EXTAL pins as possible. In addition, to minimize induction and thus obtain oscillation at the correct frequency, the capacitors to be attached to the resonator must be grounded to the same ground. Do not bring wiring patterns close to these components. Figure 9.3 Note on Using a Crystal Resonator ## 9.6.3 Note on Resonator Since various characteristics related to the resonator are closely linked to the user's board design, thorough evaluation is necessary on the user's part, using the resonator connection examples shown in this section as a guide. As the parameters for the oscillation circuit will depend on the floating capacitance of the resonator and the user board, the parameters should be determined in consultation with the resonator manufacturer. The design must ensure that a voltage exceeding the maximum rating is not applied to the resonator pin. ## 9.6.4 Note on Using a PLL Oscillation Circuit In the PLLVcc and PLLVss connection pattern for the PLL, signal lines from the board power supply pins must be as short as possible and pattern width must be as wide as possible to reduce inductive interference. In clock operating mode 2 or 3, the EXTAL pin is pulled up and the XTAL pin is left open. Since the analog power supply pins of the PLL are sensitive to the noise, the system may malfunction due to inductive interference at the other power supply pins. To prevent such malfunction, the analog power supply pins and digital power supply pins Vcc and VccQ should not supply the same resources on the board if at all possible. Figure 9.4 Note on Using a PLL Oscillation Circuit # Section 10 Watchdog Timer (WDT) This LSI includes the watchdog timer (WDT), which externally outputs an overflow signal (WDTOVF) on overflow of the counter when the value of the counter has not been updated because of a system malfunction. The WDT can simultaneously generate an internal reset signal for the entire LSI. The WDT is a single channel timer that counts up the clock oscillation settling period when the system leaves software standby mode or the temporary standby periods that occur when the clock frequency is changed. It can also be used as a general watchdog timer or interval timer. ## 10.1 Features - Can be used to ensure the clock oscillation settling time The WDT is used in leaving software standby mode or the temporary standby periods that occur when the clock frequency is changed. - Can switch between watchdog timer mode and interval timer mode. - Outputs WDTOVF signal in watchdog timer mode When the counter overflows in watchdog timer mode, the WDTOVF signal is output externally. It is possible to select whether to reset the LSI internally when this happens. Either the power-on reset or manual reset signal can be selected as the internal reset type. - Interrupt generation in interval timer mode An interval timer interrupt is generated when the counter overflows. - Choice of eight counter input clocks Eight clocks (Pφ × 1 to Pφ × 1/16384) that are obtained by dividing the peripheral clock can be selected. Figure 10.1 shows a block diagram of the WDT. Figure 10.1 Block Diagram of WDT # 10.2 Input/Output Pin Table 10.1 shows the pin configuration of the WDT. **Table 10.1 Pin Configuration** | Pin Name | Symbol | I/O | Function | |-------------------------|--------|--------|------------------------------------------------------------| | Watchdog timer overflow | WDTOVF | Output | Outputs the counter overflow signal in watchdog timer mode | # 10.3 Register Descriptions The WDT has the following registers. **Table 10.2 Register Configuration** | Register Name | Abbreviation | R/W | Initial<br>Value | Address | Access<br>Size | |----------------------------------------|--------------|-----|------------------|------------|----------------| | Watchdog timer counter | WTCNT | R/W | H'00 | H'FFFE0002 | 16* | | Watchdog timer control/status register | WTCSR | R/W | H'18 | H'FFFE0000 | 16* | | Watchdog reset control/status register | WRCSR | R/W | H'1F | H'FFFE0004 | 16* | Note: \* For the access size, see section 10.3.4, Notes on Register Access. # **10.3.1** Watchdog Timer Counter (WTCNT) WTCNT is an 8-bit readable/writable register that is incremented by cycles of the selected clock signal. When an overflow occurs, it generates a watchdog timer overflow signal ( $\overline{\text{WDTOVF}}$ ) in watchdog timer mode and an interrupt in interval timer mode. WTCNT is initialized to H'00 by a power-on reset caused by the $\overline{\text{RES}}$ pin or in software standby mode. Use word access to write to WTCNT, writing H'5A in the upper byte. Use byte access to read from WTCNT. Note: The method for writing to WTCNT differs from that for other registers to prevent erroneous writes. See section 10.3.4, Notes on Register Access, for details. ## 10.3.2 Watchdog Timer Control/Status Register (WTCSR) WTCSR is an 8-bit readable/writable register composed of bits to select the clock used for the count, overflow flags, and timer enable bit. WTCSR is initialized to H'18 by a power-on reset caused by the RES pin or in software standby mode. When used to count the clock oscillation settling time for canceling software standby mode, it retains its value after counter overflow. Use word access to write to WTCSR, writing H'A5 in the upper byte. Use byte access to read from WTCSR. Note: The method for writing to WTCSR differs from that for other registers to prevent erroneous writes. See section 10.3.4, Notes on Register Access, for details. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-------|-------|-----|---|---|-----|----------|-----| | | IOVF | WT/ĪT | TME | - | - | | CKS[2:0] | | | Initial value: | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | R/W: | R/(W) | R/W | R/W | R | R | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | IOVF | 0 | R/(W) | Interval Timer Overflow | | | | | | Indicates that WTCNT has overflowed in interval timer mode. This flag is not set in watchdog timer mode. | | | | | | 0: No overflow | | | | | | 1: WTCNT overflow in interval timer mode | | | | | | [Clearing condition] | | | | | | When 0 is written to IOVF after reading IOVF | | 6 | WT/IT | 0 | R/W | Timer Mode Select | | | | | | Selects whether to use the WDT as a watchdog timer or an interval timer. | | | | | | 0: Use as interval timer | | | | | | 1: Use as watchdog timer | | | | | | Note: When the WTCNT overflows in watchdog timer mode, the WDTOVF signal is output externally. If this bit is modified when the WDT is running, the counting-up may not be performed correctly. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | |--------|----------|------------------|-----|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------| | 5 | TME | 0 | R/W | Timer Enable | | | | | | | | when using the | os timer operation. (<br>e WDT in software s<br>g the clock frequenc | standby mode or | | | | | | 0: Timer disabl | led | | | | | | | Count-up sto | ops and WTCNT va | lue is retained | | | | | | 1: Timer enabl | ed | | | 4, 3 | _ | All 1 | R | Reserved | | | | | | | | These bits are should always | always read as 1. The 1. | The write value | | 2 to 0 | CKS[2:0] | 000 | R/W | Clock Select | | | | | | | | count from the<br>peripheral cloc<br>shown inside t | eight types obtaina<br>k (P\(\phi\)). The overflow<br>he parenthesis in the<br>heral clock (P\(\phi\)) is 2 | v period that is<br>e table is the value | | | | | | Bits 2 to 0 | Clock Ratio | Overflow Cycle | | | | | | 000: | $1 \times P\phi$ | 10.2 μs | | | | | | 001: | $1/64 \times P\phi$ | 655.4 μs | | | | | | 010: | $1/128 \times P\varphi$ | 1.3 ms | | | | | | 011: | 1/256 × Pφ | 2.6 ms | | | | | | 100: | 1/512 × P¢ | 5.2 ms | | | | | | 101: | 1/1024 × P¢ | 10.5 ms | | | | | | 110: | 1/4096 × P¢ | 41.9 ms | | | | | | 111: | $1/16384 \times P\varphi$ | 167.8 ms | | | | | | the WD<br>be perf | dified only when the | unting-up may not sure that these bits | # 10.3.3 Watchdog Reset Control/Status Register (WRCSR) WRCSR is an 8-bit readable/writable register that controls output of the internal reset signal generated by watchdog timer counter (WTCNT) overflow. WRCSR is initialized to H'1F by input of a reset signal from the $\overline{RES}$ pin, but is not initialized by the internal reset signal generated by overflow of the WDT. WRCSR is initialized to H'1F in software standby mode. Note: The method for writing to WRCSR differs from that for other registers to prevent erroneous writes. See section 10.3.4, Notes on Register Access, for details. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|-------|------|------|---|---|---|---|---|---| | | WOVF | RSTE | RSTS | - | - | - | - | - | ] | | Initial value: | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | - | | R/W: | R/(W) | R/W | R/W | R | R | R | R | R | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | WOVF | 0 | R/(W) | Watchdog Timer Overflow | | | | | | Indicates that the WTCNT has overflowed in watchdog timer mode. This bit is not set in interval timer mode. | | | | | | 0: No overflow | | | | | | 1: WTCNT has overflowed in watchdog timer mode | | | | | | [Clearing condition] | | | | | | When 0 is written to WOVF after reading WOVF | | 6 | RSTE | 0 | R/W | Reset Enable | | | | | | Selects whether to generate a signal to reset the LSI internally if WTCNT overflows in watchdog timer mode. In interval timer mode, this setting is ignored. | | | | | | 0: Not reset when WTCNT overflows* | | | | | | 1: Reset when WTCNT overflows | | | | | | Note: * LSI not reset internally, but WTCNT and WTCSR reset within WDT. | | | | Initial | | | |--------|----------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 5 | RSTS | 0 | R/W | Reset Select | | | | | | Selects the type of reset when the WTCNT overflows in watchdog timer mode. In interval timer mode, this setting is ignored. | | | | | | 0: Power-on reset | | | | | | 1: Manual reset | | 4 to 0 | _ | All 1 | R | Reserved | | | | | | These bits are always read as 1. The write value should always be 1. | ## 10.3.4 Notes on Register Access The watchdog timer counter (WTCNT), watchdog timer control/status register (WTCSR), and watchdog reset control/status register (WRCSR) are more difficult to write to than other registers. The procedures for reading or writing to these registers are given below. # (1) Writing to WTCNT and WTCSR These registers must be written by a word transfer instruction. They cannot be written by a byte or longword transfer instruction. When writing to WTCNT, set the upper byte to H'5A and transfer the lower byte as the write data, as shown in figure 10.2. When writing to WTCSR, set the upper byte to H'A5 and transfer the lower byte as the write data. This transfer procedure writes the lower byte data to WTCNT or WTCSR. Figure 10.2 Writing to WTCNT and WTCSR ## (2) Writing to WRCSR WRCSR must be written by a word access to address H'FFFE0004. It cannot be written by byte transfer or longword transfer instructions. Procedures for writing 0 to WOVF (bit 7) and for writing to RSTE (bit 6) are different, as shown in figure 10.3. To write 0 to the WOVF bit, the write data must be H'A5 in the upper byte and H'00 in the lower byte. This clears the WOVF bit to 0. The RSTE bit is not affected. To write to the RSTE bit, the upper byte must be H'5A and the lower byte must be the write data. The value of bit 6 of the lower byte is transferred to the RSTE bit, respectively. The WOVF bit is not affected. Figure 10.3 Writing to WRCSR # (3) Reading from WTCNT, WTCSR, and WRCSR WTCNT, WTCSR, and WRCSR are read in a method similar to other registers. WTCSR is allocated to address H'FFFE0000, WTCNT to address H'FFFE0002, and WRCSR to address H'FFFE0004. Byte transfer instructions must be used for reading from these registers. #### **WDT** Usage 10.4 #### 10.4.1 **Canceling Software Standby Mode** The WDT can be used to cancel software standby mode with an interrupt such as an NMI interrupt. The procedure is described below. (The WDT does not operate when resets are used for canceling, so keep the RES pin low until clock oscillation settles.) - 1. Before making a transition to software standby mode, always clear the TME bit in WTCSR to 0. When the TME bit is 1, an erroneous reset or interval timer interrupt may be generated when the count overflows. - 2. Set the type of count clock used in the CKS[2:0] bits in WTCSR and the initial value of the counter in WTCNT. These values should ensure that the time till count overflow is longer than the clock oscillation settling time. - 3. After setting the STBY bit of the standby control register (STBCR: see section 11, Power-Down Modes) to 1, the execution of a SLEEP instruction puts the system in software standby mode and clock operation then stops. - 4. The WDT starts counting by detecting the edge change of the NMI signal. - 5. When the WDT count overflows, the CPG starts supplying the clock and this LSI resumes operation. The WOVF flag in WRCSR is not set when this happens. #### 10.4.2 **Changing the Frequency** To change the frequency used by the PLL, use the WDT. When changing the frequency only by switching the divider, do not use the WDT. - 1. Before changing the frequency, always clear the TME bit in WTCSR to 0. When the TME bit is 1, an erroneous reset or interval timer interrupt may be generated when the count overflows. - 2. Set the type of count clock used in the CKS[2:0] bits in WTCSR and the initial value of the counter in WTCNT. These values should ensure that the time till count overflow is longer than the clock oscillation settling time. However, the WDT counts up using the clock after the setting. - 3. When the frequency control register (FRQCR) is written to, this LSI stops temporarily. The WDT starts counting. - 4. When the WDT count overflows, the CPG resumes supplying the clock and this LSI resumes operation. The WOVF flag in WRCSR is not set when this happens. - 5. The counter stops at the value of H'00. - 6. Before changing WTCNT after execution of the frequency change instruction, always confirm that the value of WTCNT is H'00 by reading from WTCNT. #### 10.4.3 Using Watchdog Timer Mode - 1. Set the WT/IT bit in WTCSR to 1 to set the type of count clock in the CKS2 to CKS0 bits, whether this LSI is to be reset internally or not in the RSTE bit in WRCSR, and the initial value of the counter in WTCNT. - 2. Set the TME bit in WTCSR to 1 to start the count in watchdog timer mode. - 3. While operating in watchdog timer mode, rewrite the counter periodically to H'00 to prevent the counter from overflowing. - 4. When the counter overflows, the WDT sets the WOVF flag in WRCSR to 1, and the WDTOVF signal is output externally (figure 10.4). The WDTOVF signal can be used to reset the system. The WDTOVF signal is output for 64 × Pφ clock cycles. - If the RSTE bit in WRCSR is set to 1, a signal to reset the inside of this LSI can be generated simultaneously with the WDTOVF signal. The internal reset signal is output for 128 × Pφ clock cycles. - 6. When a WDT overflow reset is generated simultaneously with a reset input on the $\overline{RES}$ pin, the $\overline{RES}$ pin reset takes priority, and the WOVF bit in WRCSR is cleared to 0. Figure 10.4 Operation in Watchdog Timer Mode ### 10.4.4 Using Interval Timer Mode When operating in interval timer mode, interval timer interrupts are generated at every overflow of the counter. This enables interrupts to be generated at set periods. - 1. Clear the WT/IT bit in WTCSR to 0, set the type of count clock in the CKS[2:0] bits in WTCSR, and set the initial value of the counter in WTCNT. - 2. Set the TME bit in WTCSR to 1 to start the count in interval timer mode. - 3. When the counter overflows, the WDT sets the IOVF bit in WTCSR to 1 and an interval timer interrupt request is sent to the INTC. The counter then resumes counting. Figure 10.5 Operation in Interval Timer Mode ## 10.5 Usage Notes Pay attention to the following points when using the WDT in either the interval timer or watchdog timer mode. #### 10.5.1 Timer Variation After timer operation has started, the period from the power-on reset point to the first count up timing of WTCNT varies depending on the time period that is set by the TME bit of WTCSR. The shortest such time period is thus one cycle of the peripheral clock, $P\phi$ , while the longest is the result of frequency division according to the value in the CKS[2:0] bits. The timing of subsequent incrementation is in accord with the selected frequency division ratio. Accordingly, this time difference is referred to as timer variation. This also applies to the timing of the first incrementation after WTCNT has been written to during timer operation. #### 10.5.2 Prohibition against Setting H'FF to WTCNT When the value in WTCNT reaches H'FF, the WDT assumes that an overflow has occurred. Accordingly, when H'FF is set in WTCNT, an interval timer interrupt or WDT reset will occur immediately, regardless of the current clock selection by the CKS[2:0] bits. # 10.5.3 System Reset by WDTOVF Signal If the WDTOVF signal is input to the RES pin of this LSI, this LSI cannot be initialized correctly. Avoid input of the $\overline{WDTOVF}$ signal to the $\overline{RES}$ pin of this LSI through glue logic circuits. To reset the entire system with the $\overline{WDTOVF}$ signal, use the circuit shown in figure 10.6. Figure 10.6 Example of System Reset Circuit Using WDTOVF Signal ### 10.5.4 Manual Reset in Watchdog Timer Mode When a manual reset occurs in watchdog timer mode, the bus cycle is continued. If a manual reset occurs while the bus is released or during DMAC burst transfer, manual reset exception handling will be pended until the CPU acquires the bus mastership. However, if the duration from generation of the manual reset to the bus cycle end is equal to or longer than the duration of the internal manual reset activated, the occurrence of the internal manual reset source is ignored instead of being pended, and the manual reset exception handling is not executed. # Section 11 Power-Down Modes In power-down modes, operation of some of the internal peripheral modules and of the CPU stops. This leads to reduced power consumption. These modes are canceled by a reset or interrupt. #### 11.1 Features #### 11.1.1 Power-Down Modes This LSI has the following power-down modes and function: State\* - 1. Sleep mode - 2. Software standby mode - 3. Module standby function Table 11.1 shows the transition conditions for entering the modes from the program execution state, as well as the CPU and peripheral module states in each mode and the procedures for canceling each mode. **Table 11.1 States of Power-Down Modes** | | | State. | | | | | | | |--------------------------|---------------------------------------------------------------|--------|-------|-----------------|-----------------------------------------------------|----------------------------------|---------------------|-------------------------------------------| | Power-Down<br>Mode | Transition Conditions | CPG | CPU | CPU<br>Register | On-Chip<br>Memory | On-Chip<br>Peripheral<br>Modules | External<br>Memory | Canceling Procedure | | Sleep mode | Execute SLEEP instruction with STBY bit cleared to 0 in STBCR | Runs | Halts | Held | Runs | Runs | Auto-<br>refreshing | Interrupt Reset DMA address error | | Software<br>standby mode | Execute SLEEP instruction with STBY bit set to 1 in STBCR | Halts | Halts | Held | Halts<br>(contents are<br>held) | Halts | Self-<br>refreshing | NMI interrupt IRQ interrupt Reset | | Module standby function | Set the MSTP bits in<br>STBCR2, STBCR3, and<br>STBCR4 to 1 | Runs | Runs | Held | Specified<br>module halts<br>(contents are<br>held) | Specified module halts | Auto-<br>refreshing | Clear MSTP bit to 0 Reset | Note: \* The pin state is retained or set to high impedance. For details, see appendix A, Pin States. # 11.2 Register Descriptions The following registers are used in power-down modes. **Table 11.2 Register Configuration** | Register Name | Abbreviation | R/W | Initial<br>Value | Address | Access<br>Size | |----------------------------|--------------|-----|------------------|------------|----------------| | Standby control register | STBCR | R/W | H'00 | H'FFFE0014 | 8 | | Standby control register 2 | STBCR2 | R/W | H'00 | H'FFFE0018 | 8 | | Standby control register 3 | STBCR3 | R/W | H'00 | H'FFFE0408 | 8 | | Standby control register 4 | STBCR4 | R/W | H'00 | H'FFFE040C | 8 | | System control register 1 | SYSCR1 | R/W | H'FF | H'FFFE0402 | 8 | | System control register 2 | SYSCR2 | R/W | H'FF | H'FFFE0404 | 8 | | System control register 3 | SYSCR3 | R/W | H'00 | H'FFFE0418 | 8 | #### **Standby Control Register (STBCR)** 11.2.1 STBCR is an 8-bit readable/writable register that specifies the state of the power-down mode. This register is initialized to H'00 by a power-on reset but retains its previous value by a manual reset or in software standby mode. Only byte access is valid. | | | Initial | | | |--------|----------|---------|-----|-------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 7 | STBY | 0 | R/W | Software Standby | | | | | | Specifies transition to software standby mode. | | | | | | 0: Executing SLEEP instruction puts chip into sleep mode. | | | | | | <ol> <li>Executing SLEEP instruction puts chip into<br/>software standby mode.</li> </ol> | | 6 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | ## 11.2.2 Standby Control Register 2 (STBCR2) STBCR2 is an 8-bit readable/writable register that controls the operation of modules in power-down modes. STBCR2 is initialized to H'00 by a power-on reset but retains its previous value by a manual reset or in software standby mode. Only byte access is valid. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------------|-----------|-----------|-----------|---|---|---|---| | | MSTP<br>10 | MSTP<br>9 | MSTP<br>8 | MSTP<br>7 | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------| | 7 | MSTP10 | 0 | R/W | Module Stop 10 | | | | | | When the MSTP10 bit is set to 1, the supply of the clock to the H-UDI is halted. | | | | | | 0: H-UDI runs. | | | | | | 1: Clock supply to H-UDI halted. | | 6 | MSTP9 | 0 | R/W | Module Stop 9 | | | | | | When the MSTP9 bit is set to 1, the supply of the clock to the UBC is halted. | | | | | | 0: UBC runs. | | | | | | 1: Clock supply to UBC halted. | | 5 | MSTP8 | 0 | R/W | Module Stop 8 | | | | | | When the MSTP8 bit is set to 1, the supply of the clock to the DMAC is halted. | | | | | | 0: DMAC runs. | | | | | | 1: Clock supply to DMAC halted. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | MSTP7 | 0 | R/W | Module Stop 7 | | | | | | When the MSTP7 bit is set to 1, the clock supply to the FPU is halted. After the MSTP7 bit is set to 1, the value of 0 cannot be written for clearing. In other words, once the MSTP7 bit is set to 1 and the clock supply to the FPU is temporarily halted, then the clock supply to the FPU cannot be restarted by clearing the MSTP7 bit to 0. | | | | | | If the clock supply to the FPU is halted and then restarted, a power-on reset must be performed for this LSI. | | | | | | 0: FPUC runs. | | | | | | 1: Clock supply to FPU halted. | | 3 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | ## 11.2.3 Standby Control Register 3 (STBCR3) STBCR3 is an 8-bit readable/writable register that controls the operation of modules in power-down modes. STBCR3 is initialized to H'00 by a power-on reset but retains its previous value by a manual reset or in software standby mode. Only byte access is valid. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|------------|------------|------------|------------|------------|------------|------------| | | HIZ | MSTP<br>36 | MSTP<br>35 | MSTP<br>34 | MSTP<br>33 | MSTP<br>32 | MSTP<br>31 | MSTP<br>30 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | Initial | | | |-----|----------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 7 | HIZ | 0 | R/W | Port High Impedance | | | | | | Selects whether the state of a specified pin is retained or the pin is placed in the high-impedance state in software standby mode. See appendix A, Pin States to determine the pin to which this control is applied. | | | | | | Do not set this bit when the TME bit of WTSCR of the WDT is 1. When setting the output pin to the high-impedance state, set the HIZ bit with the TME bit being 0. | | | | | | 0: The pin state is held in software standby mode. | | | | | | <ol> <li>The pin state is set to the high-impedance state in<br/>software standby mode.</li> </ol> | | 6 | MSTP36 | 0 | R/W | Module Stop 36 | | | | | | When the MSTP36 bit is set to 1, the supply of the clock to the STIF1 is halted. | | | | | | 0: STIF1 runs. | | | | | | 1: Clock supply to STIF1 halted. | | 5 | MSTP35 | 0 | R/W | Module Stop 35 | | | | | | When the MSTP35 bit is set to 1, the supply of the clock to the STIF0 is halted. | | | | | | 0: STIF0 runs. | | | | | | 1: Clock supply to STIF0 halted. | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|----------------------------------------------------------------------------------| | 4 | MSTP34 | 0 | R/W | Module Stop 34 | | • | errer | v | .,,,, | When the MSTP34 bit is set to 1, the supply of the clock to the CMT is halted. | | | | | | 0: CMT runs. | | | | | | 1: Clock supply to CMT halted. | | 3 | MSTP33 | 0 | R/W | Module Stop 33 | | | | | | When the MSTP33 bit is set to 1, the supply of the clock to the IIC3 is halted. | | | | | | 0: IIC3 runs. | | | | | | 1: Clock supply to IIC3 halted. | | 2 | MSTP32 | 0 | R/W | Module Stop 32 | | | | | | When the MSTP32 bit is set to 1, the supply of the clock to the SCIF2 is halted. | | | | | | 0: SCIF2 runs. | | | | | | 1: Clock supply to SCIF2 halted. | | 1 | MSTP31 | 0 | R/W | Module Stop 31 | | | | | | When the MSTP31 bit is set to 1, the supply of the clock to the SCIF1 is halted. | | | | | | 0: SCIF1 runs. | | | | | | 1: Clock supply to SCIF1 halted. | | 0 | MSTP30 | 0 | R/W | Module Stop 30 | | | | | | When the MSTP30 bit is set to 1, the supply of the clock to the SCIF0 is halted. | | | | | | 0: SCIF0 runs. | | | | | | 1: Clock supply to SCIF0 halted. | ## 11.2.4 Standby Control Register 4 (STBCR4) STBCR4 is an 8-bit readable/writable register that controls the operation of modules in power-down modes. STBCR4 is initialized to H'00 by a power-on reset but retains its previous value by a manual reset or in software standby mode. Only byte access is valid. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|------------|------------|------------|------------|------------|------------|------------| | | _ | MSTP<br>46 | MSTP<br>45 | MSTP<br>44 | MSTP<br>43 | MSTP<br>42 | MSTP<br>41 | MSTP<br>40 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------| | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | MSTP46 | 0 | R/W | Module Stop 46 | | | | | | When the MSTP46 bit is set to 1, the supply of the clock to the SSI1 is halted. | | | | | | 0: SSI1 runs. | | | | | | 1: Clock supply to SSI1 halted. | | 5 | MSTP45 | 0 | R/W | Module Stop 45 | | | | | | When the MSTP45 bit is set to 1, the supply of the clock to the SSI0 is halted. | | | | | | 0: SSI0 runs. | | | | | | 1: Clock supply to SSI0 halted. | | 4 | MSTP44 | 0 | R/W | Module Stop 44 | | | | | | When the MSTP44 bit is set to 1, the supply of the clock to the HIF is halted. | | | | | | 0: HIF runs. | | | | | | 1: Clock supply to HIF halted. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------| | 3 | MSTP43 | 0 | R/W | Module Stop 43 | | | | | | When the MSTP43 bit is set to 1, the supply of the clock to the A-DMAC is halted. | | | | | | 0: A-DMAC runs. | | | | | | 1: Clock supply to A-DMAC halted. | | 2 | MSTP42 | 0 | R/W | Module Stop 42 | | | | | | When the MSTP42 bit is set to 1, the supply of the clock to the SDHI is halted. | | | | | | 0: SDHI runs. | | | | | | 1: Clock supply to SDHI halted. | | 1 | MSTP41 | 0 | R/W | Module Stop 41 | | | | | | When the MSTP41 bit is set to 1, the supply of the clock to the USB is halted. | | | | | | 0: USB runs. | | | | | | 1: Clock supply to USB halted. | | 0 | MSTP40 | 0 | R/W | Module Stop 40 | | | | | | When the MSTP40 bit is set to 1, the supply of the clock to the EtherC is halted. | | | | | | 0: EtherC runs. | | | | | | 1: Clock supply to EtherC halted. | ### 11.2.5 System Control Register 1 (SYSCR1) SYSCR1 is an 8-bit readable/writable register that enables or disables access to the on-chip RAM (high-speed). SYSCR1 is valid only in byte access. When an RAME bit is set to 1, the corresponding on-chip RAM (high-speed) area is enabled. When an RAME bit is cleared to 0, the corresponding on-chip RAM (high-speed) area cannot be accessed. In this case, an undefined value is returned when reading data or fetching an instruction from the on-chip RAM (high-speed), and writing to the on-chip RAM (high-speed) is ignored. The initial value of an RAME bit is 1. Note that when clearing the RAME bit to 0 to disable the on-chip RAM (high-speed), be sure to execute an instruction to read from or write to the same arbitrary address in each page before setting the RAME bit. If such an instruction is not executed, the data last written may not be written to the on-chip RAM (high-speed). Furthermore, an instruction to access the on-chip RAM (high-speed) should not be located immediately after the instruction to write to SYSCR1. If an on-chip RAM (high-speed) access instruction is set, normal access is not guaranteed. If this bit is set to 1 to enable the on-chip RAM (high-speed), the SYSCR1 read instruction must be placed immediately after the SYSCR1 write instruction. If the on-chip RAM (high-speed) access instruction is placed immediately after the SYSCR1 write instruction, then normal access will not be guaranteed. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|---|---|-------|-------|-------|-------| | | _ | _ | _ | _ | RAME3 | RAME2 | RAME1 | RAME0 | | - | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|---------------------------------------------------------------------------------| | 7 to 4 | _ | All 1 | R | Reserved | | | | | | These bits are always read as 1. The write value should always be 1. | | 3 | RAME3 | 1 | R/W | RAM Enable 3 (corresponding RAM addresses: Page 3 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) disabled | | | | | | 1: On-chip RAM (high-speed) enabled | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------| | 2 | RAME2 | 1 | R/W | RAM Enable 2 (corresponding RAM addresses: Page 2 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) disabled | | | | | | 1: On-chip RAM (high-speed) enabled | | 1 | RAME1 | 1 | R/W | RAM Enable 1 (corresponding RAM addresses: Page 1 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) disabled | | | | | | 1: On-chip RAM (high-speed) enabled | | 0 | RAME0 | 1 | R/W | RAM Enable 0 (corresponding RAM addresses: Page 0 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) disabled | | | | | | 1: On-chip RAM (high-speed) enabled | Note: \* For specific address for each page, see section 27, On-Chip RAM. ### 11.2.6 System Control Register 2 (SYSCR2) SYSCR2 is an 8-bit readable/writable register that enables or disables write to the on-chip RAM (high-speed). SYSCR2 is valid only in byte access. When the RAMWE bit is set to 1, writing to the on-chip RAM (high-speed) is enabled. When an RAMWE bit is cleared to 0, the corresponding on-chip RAM (high-speed) area cannot be written to. In this case, writing to the on-chip RAM (high-speed) is ignored. The initial value of an RAMWE bit is 1. Note that when clearing the RAMWE bit to 0 to disable the on-chip RAM, be sure to execute an instruction to read from or write to the same arbitrary address in each page before setting the RAMWE bit. If such an instruction is not executed, the data last written may not be written to the on-chip RAM (high-speed). Furthermore, an instruction to access the on-chip RAM (high-speed) should not be located immediately after the instruction to write to SYSCR2. If an on-chip RAM (high-speed) access instruction is set, normal access is not guaranteed. If this bit is set to 1 to enable writing to the on-chip RAM (high-speed), the SYSCR2 read instruction must be placed immediately after the SYSCR2 write instruction. If the on-chip RAM (high-speed) access instruction is placed immediately after the SYSCR2 write instruction, then normal access will not be guaranteed. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|------------|------------|------------|------------| | | _ | _ | _ | _ | RAM<br>WE3 | RAM<br>WE2 | RAM<br>WE1 | RAM<br>WE0 | | Initial value: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|---------------------------------------------------------------------------------------| | 7 to 4 | _ | All 1 | R | Reserved | | | | | | These bits are always read as 1. The write value should always be 1. | | 3 | RAMWE3 | 1 | R/W | RAM Write Enable 3 (corresponding RAM addresses: Page 3 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) write disabled | | | | | | 1: On-chip RAM (high-speed) write enabled | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------| | 2 | RAMWE2 | 1 | R/W | RAM Write Enable 2 (corresponding RAM addresses: Page 2 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) write disabled | | | | | | 1: On-chip RAM (high-speed) write enabled | | 1 | RAMWE1 | 1 | R/W | RAM Write Enable 1 (corresponding RAM addresses: Page 1 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) write disabled | | | | | | 1: On-chip RAM (high-speed) write enabled | | 0 | RAMWE0 | 1 | R/W | RAM Write Enable 0 (corresponding RAM addresses: Page 0 in on-chip RAM (high-speed)*) | | | | | | 0: On-chip RAM (high-speed) write disabled | | | | | | 1: On-chip RAM (high-speed) write enabled | Note: \* For specific address for each page, see section 27, On-Chip RAM. ## 11.2.7 System Control Register 3 (SYSCR3) SYSCR3 is an 8-bit readable/writable register that controls the software reset for SSI0 and SSI1. SYSCR3 is valid only in byte access. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|---|---|--------------|--------------| | | _ | _ | _ | _ | _ | _ | SSI1<br>SRST | SSI0<br>SRST | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------| | 7 to 2 | — | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | SSI1SRST | 0 | R/W | SSI1 Software Reset | | | | | | Controls the SSI1 reset by software. | | | | | | 0: Cancels the SSI1 reset. | | | | | | 1: Places the SSI1 in reset state. | | 0 | SSI0SRST | 0 | R/W | SSI0 Software Reset | | | | | | Controls the SSI0 reset by software. | | | | | | 0: Cancels the SSI0 reset | | | | | | 1: Places the SSI0 in reset state. | # 11.3 Operation #### 11.3.1 Sleep Mode #### (1) Transition to Sleep Mode Executing the SLEEP instruction when the STBY bit in STBCR is 0 causes a transition from the program execution state to sleep mode. Although the CPU halts immediately after executing the SLEEP instruction, the contents of its internal registers remain unchanged. The on-chip modules continue to run in sleep mode. Clock pulses continue to be output on the CKIO pin in clock mode 0, 1, or 3. ### (2) Canceling Sleep Mode Sleep mode is canceled by an interrupt (NMI, IRQ, and on-chip peripheral module), DMA address error, or reset (power-on reset). - Canceling with an interrupt - When an NMI, IRQ, or on-chip peripheral module interrupt occurs, sleep mode is canceled and interrupt exception handling is executed. When the priority level of the generated interrupt is equal to or lower than the interrupt mask level that is set in the status register (SR) of the CPU, or the interrupt by the on-chip peripheral module is disabled on the module side, the interrupt request is not accepted and sleep mode is not canceled. - Canceling with a DMA address error When a DMA address error occurs, sleep mode is canceled and DMA address error exception handling is executed. - Canceling with a reset Sleep mode is canceled by a power-on reset. ### 11.3.2 Software Standby Mode ### (1) Transition to Software Standby Mode The LSI switches from a program execution state to software standby mode by executing the SLEEP instruction when the STBY bit in STBCR is 1. In software standby mode, not only the CPU but also the clock and on-chip peripheral modules halt. The clock output from the CKIO pin also halts in clock mode 0, 1, or 3. The contents of the CPU remain unchanged. Some registers of on-chip peripheral modules are, however, initialized. Regarding the states of on-chip peripheral module registers in software standby mode, see section 28.3, Register States in Each Operating Mode. The CPU takes one cycle to finish writing to STBCR, and then executes processing for the next instruction. However, it takes one or more cycles to actually write. Therefore, execute a SLEEP instruction after reading STBCR to have the values written to STBCR by the CPU to be definitely reflected in the SLEEP instruction. The procedure for switching to software standby mode is as follows: - 1. Clear the TME bit in the WDT's timer control register (WTCSR) to 0 to stop the WDT. - 2. Set the WDT's timer counter (WTCNT) to 0 and the CKS[2:0] bits in WTCSR to appropriate values to secure the specified oscillation settling time. - 3. After setting the STBY bit in STBCR to 1, read STBCR. Then, execute a SLEEP instruction. #### (2) Canceling Software Standby Mode Software standby mode is canceled by interrupts (NMI or IRQ) or a reset (power-on reset). The CKIO pin starts outputting the clock in clock mode 0, 1, or 3. #### • Canceling with an interrupt When the falling edge or rising edge of the NMI pin (selected by the NMI edge select bit (NMIE) in interrupt control register 0 (ICR0) of the interrupt controller (INTC)) or the falling edge or rising edge of an IRQ pin (IRQ7 to IRQ0) (selected by the IRQn sense select bits (IRQn1S and IRQn0S) in interrupt control register 1 (ICR1) of the interrupt controller (INTC)) is detected, clock oscillation is started. This clock pulse is supplied only to the oscillation settling counter (WDT) used to count the oscillation settling time. After the elapse of the time set in the clock select bits (CKS[2:0]) in the watchdog timer control/status register (WTCSR) of the WDT before the transition to software standby mode, the WDT overflow occurs. Since this overflow indicates that the clock has been stabilized, the clock pulse will be supplied to the entire chip after this overflow. Software standby mode is thus cleared and NMI interrupt exception handling (IRQ interrupt exception handling in the case of IRQ) starts. However, if the priority level of IRQ interrupt is lower than the interrupt mask level set in the status register (SR) of the CPU, the interrupt request is not accepted and thus the software standby mode is not released. When canceling software standby mode by the NMI interrupt or IRQ interrupt, set the CKS[2:0] bits so that the WDT overflow period will be equal to or longer than the oscillation settling time. The clock output phase of the CKIO pin may be unstable immediately after detecting an interrupt and until software standby mode is canceled. When software standby mode is canceled by the falling edge of the NMI pin, the NMI pin should be high when the CPU enters software standby mode (when the clock pulse stops) and should be low when the CPU returns from software standby mode (when the clock is initiated after the oscillation settling). When software standby mode is canceled by the rising edge of the NMI pin, the NMI pin should be low when the CPU enters software standby mode (when the clock pulse stops) and should be high when the CPU returns from software standby mode (when the clock is initiated after the oscillation settling) (This is the same with the IRQ pin.) # Canceling with a reset When the $\overline{RES}$ pin is driven low, software standby mode is released and this LSI enters the power-on reset state. And if the $\overline{RES}$ pin is driven high after that, the power-on reset exception handling starts. Keep the $\overline{RES}$ pin low until the clock oscillation settles. #### 11.3.3 Software Standby Mode Application Example This example describes a transition to software standby mode on the falling edge of the NMI signal, and cancellation on the rising edge of the NMI signal. The timing is shown in figure 11.1. When the NMI pin is changed from high to low level while the NMI edge select bit (NMIE) in ICR is set to 0 (falling edge detection), the NMI interrupt is accepted. When the NMIE bit is set to 1 (rising edge detection) by the NMI exception service routine, the STBY bit in STBCR is set to 1, and a SLEEP instruction is executed, software standby mode is entered. Thereafter, software standby mode is canceled when the NMI pin is changed from low to high level. Figure 11.1 NMI Timing in Software Standby Mode (Application Example) #### 11.3.4 Module Standby Function ### (1) Transition to Module Standby Function Setting the standby control register MSTP bits to 1 halts the supply of clocks to the corresponding on-chip peripheral modules. This function can be used to reduce the power consumption in normal mode and sleep mode. Disable a module before placing it in the module standby mode. In addition, do not access the module's registers while it is in the module standby state. The register states are the same as those in software standby mode. For details, see section 28.3, Register States in Each Operating Mode. However, the states of the CMT registers are exceptional. In the CMT, all registers are initialized in software standby mode, but retain their previous values in module standby mode. ### (2) Canceling Module Standby Function The module standby function can be canceled by clearing the MSTP bits to 0, or by a power-on reset. When taking a module out of the module standby state by clearing the corresponding MSTP bit to 0, read the MSTP bit to confirm that it has been cleared to 0. # 11.4 Usage Notes When writing data to registers related to power-down modes, note the following suggestion. In a case where the CPU writes data to the registers related to power-down modes, if the CPU once starts executing the write instruction, the CPU keeps on executing the succeeding instructions without waiting for the completion of writing data to the registers. If reflecting a change of writing data to registers becomes necessary while the CPU is performing the succeeding instructions, execute a dummy read for the same register between the write instruction to the register and the succeeding instructions. # Section 12 Ethernet Controller (EtherC) This LSI has an on-chip Ethernet controller (EtherC) conforming to the Ethernet or the IEEE802.3 MAC (Media Access Control) layer standard. Connecting a physical-layer LSI (PHY-LSI) complying with this standard enables the Ethernet controller (EtherC) to perform transmission and reception of Ethernet/IEEE802.3 frames. This LSI has one MAC layer interface. The Ethernet controller is connected to the direct memory access controller for Ethernet controller (E-DMAC) inside this LSI, and carries out high-speed data transfer to and from the memory. Figure 12.1 shows a configuration of the EtherC. #### 12.1 **Features** - Transmission and reception of Ethernet/IEEE802.3 frames - Supports 10/100 Mbps receive/transfer - Supports full-duplex and half-duplex modes - Conforms to IEEE802.3u standard MII (Media Independent Interface) - Magic Packet detection and Wake-On-LAN (WOL) signal output - Conforms to IEEE802.3x flow control Figure 12.1 Configuration of EtherC # 12.2 Input/Output Pins Table 12.1 lists the pin configuration of the EtherC. **Table 12.1 Pin Configuration** | Port | Abbreviation | I/O | Function | |------|--------------|--------|--------------------------------------------------------------------------------------| | 0 | TX-CLK* | Input | Transmit Clock | | | | | Timing reference signal for the TX-EN, MII_TXD3 to MII_TXD0, TX-ER signals | | 0 | RX-CLK* | Input | Receive Clock | | | | | Timing reference signal for the RX-DV, MII_RXD3 to MII_RXD0, RX-ER signals | | 0 | TX-EN* | Output | Transmit Enable | | | | | Indicates that transmit data is ready on pins MII_TXD3 to MII_TXD0. | | 0 | MII_TXD3 to | Output | Transmit Data | | | MII_TXD0* | | 4-bit transmit data | | 0 | TX-ER* | Output | Transmit Error | | | | | Notifies the PHY-LSI of error during transmission | | 0 | RX-DV* | Input | Receive Data Valid | | | | | Indicates that valid receive data is on pins MII_RXD3 to MII_RXD0. | | 0 | MII_RXD3 to | Input | Receive Data | | | MII_RXD0* | | 4-bit receive data | | 0 | RX-ER* | Input | Receive Error | | | | | Identifies error state occurred during data reception. | | 0 | CRS | Input | Carrier Detection | | | | | Carrier detection signal | | 0 | COL | Input | Collision Detection | | | | | Collision detection signal | | 0 | MDC | Output | Management Data Clock | | | | | Reference clock signal for information transfer via MDIO | | 0 | MDIO | Input/ | Management Data I/O | | | | Output | Bidirectional signal for exchange of management information between this LSI and PHY | | | | | | | Port | Abbreviation | I/O | Function | |------|--------------|--------|-----------------------------------------------------| | 0 | LNKSTA | Input | Link Status | | | | | Inputs link status from PHY | | 0 | EXOUT | Output | General-Purpose External Output | | | | | Signal indicating value of register-bit (ECMR0-ELB) | | 0 | WOL | Output | Wake-On-LAN | | | | | Signal indicating reception of Magic Packet | Note: \* MII signal conforming to IEEE802.3u #### 12.3 **Register Description** The EtherC has the following registers. For details on addresses and access sizes of registers, see section 28, List of Registers. #### **MAC Layer Interface Control Registers:** - EtherC mode register (ECMR) - EtherC status register (ECSR) - EtherC interrupt permission register (ECSIPR) - PHY interface register (PIR) - MAC address high register (MAHR) - MAC address low register (MALR) - Receive frame length register (RFLR) - PHY status register (PSR) - Transmit retry over counter register (TROCR) - Delayed collision detect counter register (CDCR) - Lost carrier counter register (LCCR) - Carrier not detect counter register (CNDCR) - CRC error frame counter register (CEFCR) - Frame receive error counter register (FRECR) - Too-short frame receive counter register (TSFRCR) - Too-long frame receive counter register (TLFRCR) - Residual-bit frame counter register (RFCR) - Multicast address frame counter register (MAFCR) - IPG register (IPGR) - Automatic PAUSE frame set register (APR) - Manual PAUSE frame set register (MPR) - PAUSE frame retransfer count set register (TPAUSER) ### 12.3.1 EtherC Mode Register (ECMR) ECMR is a 32-bit readable/writable register and specifies the operating mode of the Ethernet controller. The settings in this register are normally made in the initialization process following a reset. The operating mode setting must not be changed while the transmitting and receiving functions are enabled. To switch the operating mode, return the EtherC and E-DMAC to their initial states by means of the SWR bit in EDMR before making settings again. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|-------|----|----|------|----|----|-----|-----|----|-----|-----|-----|------| | [ | - | - | - | - | - | - | - | - | - | - | - | - | ZPF | PFR | RXF | TXF | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | [ | - | - | - | PRCEF | - | - | MPDE | - | - | RE | TE | - | ILB | ELB | DM | PRM | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | B | R | B/W | B | R | DAM | ь | D | DAM | DAM | ь | DAM | DAM | D/M | D AM | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | |----------------|----|-------|-------------|---------------|-----|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------------|------------------------|-------------------------------------------------------------------------|-------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------|--|--|--|--| | R/W: | R | R | R<br>• | R/W | R | R | R/W | R | R | R/W | R/W | R | R/W | R/W | R/W | R/W | | | | | | Bit | Bi | t Naı | In<br>me Va | itial<br>alue | R/V | ٧ | Des | cripti | on | | | | | | | | | | | | | 31 to 20 | _ | | Al | 10 | R | | Res | Reserved | | | | | | | | | | | | | | | | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | | | | | | | | | | 19 | ZF | PF | 0 | | R/V | R/W 0 time parameter PAUSE Frame Use Enable | | | | | | | | | | | | | | | | | | | | | | | <ol><li>Disables PAUSE frame control in which the TIME<br/>parameter is 0.</li></ol> | | | | | | | | | | | | | | | | | | | | | | The next frame is transmitted after the time indicated by the Timer value has elapsed. When the EtherC receives a PAUSE frame with the time indicated by the Timer value set to 0, the PAUSE frame is discarded. | | | | | | | | | | | | | | | | | | | | | | | nable<br>aram | | | rame o | contro | ol in w | hich th | ne TIM | 1E | | | | | | | | | | | | | | ransm<br>TFO is<br>ndicat<br>ne Eth<br>ndicat | itted versions less less ed by nerC red by | when than the Tieceive | vith the the number the FC imer values a Painer values a Painer valued. | mber<br>FTR<br>alue I<br>AUSE | of dat<br>value<br>nas no<br>fram | ta in the before b | ne rec<br>e the to<br>sed. \<br>the ti | eive<br>time<br>When<br>me | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | PFR | 0 | R/W | PAUSE Frame Receive Mode | | | | | | 0: PAUSE frame is not transferred to the E-DMAC | | | | | | 1: PAUSE frame is transferred to the E-DMAC | | 17 | RXF | 0 | R/W | Receive Flow Control Operating Mode | | | | | | 0: PAUSE frame detection function is disabled | | | | | | 1: Receive flow control function is enabled | | 16 | TXF | 0 | R/W | Transmit Flow Control Operating mode | | | | | | 0: Transmit flow control function is disabled | | | | | | 1: Transmit flow control function is enabled | | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | PRCEF | 0 | R/W | Permit Receive CRC Error Frame | | | | | | <ol> <li>A frame with a CRC error is received as a frame<br/>with an error.</li> </ol> | | | | | | <ol> <li>A frame with a CRC error is received as a frame<br/>without an error.</li> </ol> | | | | | | For a frame with an error, a CRC error is reflected in<br>the ECSR of the E-DMAC and the status of the receive<br>descriptor. For a frame without an error, the frame is<br>received as normal frame. | | 11, 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | MPDE | 0 | R/W | Magic Packet Detection Enable | | | | | | Enables or disables Magic Packet detection by hardware to allow activation from the Ethernet. | | | | | | 0: Magic Packet detection is not enabled | | | | | | 1: Magic Packet detection is enabled | | 8, 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | RE | 0 | R/W | Reception Enable | | | | | | If a frame is being received when this bit is switched from receive function enabled (RE = 1) to disabled (RE = 0), the receive function will be enabled until reception of the corresponding frame is completed. | | | | | | 0: Receive function is disabled | | | | | | 1: Receive function is enabled | | 5 | TE | 0 | R/W | Transmission Enable | | | | | | If a frame is being transmitted when this bit is switched from transmit function enabled (TE = 1) to disabled (TE = 0), the transmit function will be enabled until transmission of the corresponding frame is completed. | | | | | | 0: Transmit function is disabled | | | | | | 1: Transmit function is enabled | | 4 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 3 | ILB | 0 | R/W | Internal Loop Back Mode | | | | | | Specifies loopback mode in the EtherC. | | | | | | 0: Normal data transmission/reception is performed. | | | | | | <ol> <li>When DM = 1, data loopback is performed inside<br/>the MAC in the EtherC.</li> </ol> | | 2 | ELB | 0 | R/W | External Loop Back Mode | | | | | | This bit value is output directly to this LSI's general-purpose external output pin (EXOUT). This bit is used for loopback mode directives, etc., in the LSI, using the EXOUT pin. In order for LSI loopback to be implemented using this function, the LSI must have a pin corresponding to the EXOUT pin. | | | | | | 0: Low-level output from the EXOUT pin | | | | | | 1: High-level output from the EXOUT pin | | 1 | DM | 0 | R/W | Duplex Mode | | | | | | Specifies the EtherC transfer method. | | | | | | 0: Half-duplex transfer is specified | | | | | | 1: Full-duplex transfer is specified | | | | Initial | | | |-----|----------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 0 | PRM | 0 | R/W | Promiscuous Mode | | | | | | Setting this bit enables all Ethernet frames to be received. All Ethernet frames means all receivable frames, irrespective of differences or enabled/disabled status (destination address, broadcast address, multicast bit, etc.). | | | | | | 0: EtherC performs normal operation | | | | | | 1: EtherC performs promiscuous mode operation | ### 12.3.2 EtherC Status Register (ECSR) ECSR is a 32-bit readable/writable register and indicates the status in the EtherC. This status can be notified to the CPU by interrupts. When 1 is written to the PSRTO, LCHNG, MPD, and ICD, the corresponding flags can be cleared. Writing 0 does not affect the flag. For bits that generate interrupt, the interrupt can be enabled or disabled according to the corresponding bit in ECSIPR. The interrupts generated due to this status register are indicated in the ECI bit in EESR. | Initial value: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|-------|----|-------|-----|-----| | | - | - | - | 1 | - | 1 | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | 1 | 1 | 1 | - | - | - | - | - | PSRTO | - | LCHNG | MPD | ICD | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | PSRTO | 0 | R/W | PAUSE Frame Retransfer Retry Over | | | | | | Indicates that during the retransfer of PAUSE frames when the flow control is enabled, the number of retries has exceeded the upper limit set in the automatic PAUSE frame retransfer count set register (TPAUSER). | | | | | | Number of PAUSE frame retransfers has not exceeded the upper limit | | | | | | Number of PAUSE frame retransfers has exceeded the upper limit | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | LCHNG | 0 | R/W | Link Signal Change | | | | | | Indicates that the LNKSTA signal input from the PHY has changed from high to low or low to high. | | | | | | To check the current Link state, refer to the LMON bit in the PHY status register (PSR). | | | | | | 0: Changes in the LNKSTA signal are not detected | | | | | | <ol> <li>Changes in the LNKSTA signal are detected (high<br/>to low or low to high)</li> </ol> | | 1 | MPD | 0 | R/W | Magic Packet Detection | | | | | | Indicates that a Magic Packet has been detected on the line. | | | | | | 0: Magic Packet has not been detected | | | | | | 1: Magic Packet has been detected | | 0 | ICD | 0 | R/W | Illegal Carrier Detection | | | | | | Indicates that the PHY has detected an illegal carrier on the line. If a change in the signal input from the PHY occurs before the software recognition period, the correct information may not be obtained. Refer to the timing specification for the PHY used. 0: LSI has not detected an illegal carrier on the line | | | | | | 1: LSI has detected an illegal carrier on the line | ### 12.3.3 EtherC Interrupt Permission Register (ECSIPR) ECSIPR is a 32-bit readable/writable register that enables or disables the interrupt sources indicated by ECSR. Each bit can disable or enable interrupts corresponding to the bits in ECSR. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|-------------|----|-------------|-----------|-----------| | | - | - | - | - | - | 1 | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | - | - | - | - | - | - | - | - | PSRTO<br>IP | - | LCHNG<br>IP | MPD<br>IP | ICD<br>IP | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R/W | R/W | R/W | | | | Initial | | | |---------|----------|---------|-----|----------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | PSRTOIP | 0 | R/W | PAUSE Frame Retransfer Retry Over Interrupt Enable | | | | | | 0: Interrupt notification by the PSRTO bit is disabled | | | | | | 1: Interrupt notification by the PSRTO bit is enabled | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | LCHNGIP | 0 | R/W | LINK Signal Changed Interrupt Enable | | | | | | 0: Interrupt notification by the LCHNG bit is disabled | | | | | | 1: Interrupt notification by the LCHNG bit is enabled | | 1 | MPDIP | 0 | R/W | Magic Packet Detection Interrupt Enable | | | | | | 0: Interrupt notification by the MPD bit is disabled | | | | | | 1: Interrupt notification by the MPD bit is enabled | | 0 | ICDIP | 0 | R/W | Illegal Carrier Detection Interrupt Enable | | | | | | 0: Interrupt notification by the ICD bit is disabled | | | | | | 1: Interrupt notification by the ICD bit is enabled | # 12.3.4 PHY Interface Register (PIR) PIR is a 32-bit readable/writable register that provides a means of accessing the PHY registers via the MII. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | 1 | 1 | - | 1 | 1 | 1 | 1 | 1 | 1 | 1 | MDI | MDO | MMD | MDC | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Undefined | d 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | | D:a | Dit Name | Initial | DAM | Description | |---------|----------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | <u>'</u> | | 31 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 3 | MDI | Undefined | R | MII Management Data-In | | | | | | Indicates the level of the MDIO pin. | | 2 | MDO | 0 | R/W | MII Management Data-Out | | | | | | Outputs the value set to this bit from the MDIO pin, when the MMD bit is 1. | | 1 | MMD | 0 | R/W | MII Management Mode | | | | | | Specifies the data read/write direction with respect to the MII. | | | | | | 0: Read direction is indicated | | | | | | 1: Write direction is indicated | | 0 | MDC | 0 | R/W | MII Management Data Clock | | | | | | Outputs the value set to this bit from the MDC pin and supplies the MII with the management data clock. For the method of accessing the MII registers, see section 12.4.4, Accessing MII Registers. | #### 12.3.5 MAC Address High Register (MAHR) MAHR is a 32 -bit readable/writable register that specifies the upper 32 bits of the 48-bit MAC address. The settings in this register are normally made in the initialization process after a reset. The MAC address setting must not be changed while the transmitting and receiving functions are enabled. To switch the MAC address setting, return the EtherC and E-DMAC to their initial states by means of the SWR bit in EDMR before making settings again. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | MA[4 | 7:32] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | MA[3 | 1:16] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: R/W | | | | Initial | | | |---------|-----------|---------|-----|------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 0 | MA[47:16] | All 0 | R/W | MAC Address Bits | | | | | | These bits are used to set the upper 32 bits of the MAC address. | | | | | | If the MAC address is 01-23-45-67-89-AB (hexadecimal), the value set in this register is H'01234567. | #### 12.3.6 MAC Address Low Register (MALR) MALR is a 32-bit readable/writable register that specifies the lower 16 bits of the 48-bit MAC address. The settings in this register are normally made in the initialization process after a reset. The MAC address setting must not be changed while the transmitting and receiving functions are enabled. To switch the MAC address setting, return the EtherC and E-DMAC to their initial states by means of the SWR bit in EDMR before making settings again. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----|-------|-----|-----|-----|-----|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | MA[ | 15:0] | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|------------------------------------------------------------------------------------------------------| | 31 to 16 | i — | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | MA[15:0] | All 0 | R/W | MAC Address Bits 15 to 0 | | | | | | These bits are used to set the lower 16 bits of the MAC address. | | | | | | If the MAC address is 01-23-45-67-89-AB (hexadecimal), the value set in this register is H'000089AB. | ### 12.3.7 Receive Frame Length Register (RFLR) RFLR is a 32-bit readable/writable register and it specifies the maximum frame length (in bytes) that can be received by this LSI. The settings in this register must not be changed while the receiving function is enabled. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | 1 | | | | | | RFL[ | 11:0] | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 12 | | All 0 | R | Reserved | | 31 10 12 | _ | All U | n | These bits are always read as 0. The write value should always be 0. | | 11 to 0 | RFL[11:0] | All 0 | R/W | Receive Frame Length 11 to 0 | | | | | | The frame length described here refers to all fields from the destination address up to and including the CRC data. Frame contents from the destination address up to and including the data are actually transferred to memory. CRC data is not included in the transfer. | | | | | | When data that exceeds the specified value is received, the part of the data that exceeds the specified value is discarded. | | | | | | H'000 to H'5EE: 1,518 bytes | | | | | | H'5EF: 1,519 bytes | | | | | | H'5F0: 1,520 bytes | | | | | | : | | | | | | : | | | | | | H'7FF: 2,047 bytes | | | | | | H'800 to H'FFF: 2,048 bytes | # 12.3.8 PHY Status Register (PSR) PSR is a read-only register that can read interface signals from the PHY. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | LMON | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | undefined | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | Initial | | | |---------|----------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | LMON | 0 | R | LNKSTA Pin Status | | | | | | The Link status can be read by connecting the Link signal output from the PHY to the LNKSTA pin. For the polarity, refer to the PHY specifications to be connected. | #### 12.3.9 Transmit Retry Over Counter Register (TROCR) TROCR is a 32-bit counter that indicates the number of frames that were unable to be transmitted in 16 transmission attempts including the retransfer. When 16 transmission attempts have failed, TROCR is incremented by 1. When the value in this register reaches H'FFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------| | 31 to 0 | TROC[31:0] | All 0 | R/W | Transmit Retry Over Count | | | | | | These bits indicate the number of frames that were unable to be transmitted in 16 transmission attempts including the retransfer. | ### 12.3.10 Delayed Collision Detect Counter Register (CDCR) CDCR is a 32-bit counter that indicates the number of delayed collisions on all lines from a start of transmission. When the value in this register reaches H'FFFFFFF, count-up is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit | : 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------------|--------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | | COSDO | [31:16] | | | | | | | | | Initial value<br>R/W | : 0<br>: R/W | 0<br>R/W | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | COSD | C[15:0] | | | | | | | | | Initial value | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R/W | | | | | lı | nitial | | | | | | | | | | | | | | Bit | Bit N | ame | ٧ | 'alue | R | /W | Des | criptio | on | | | | | | | | | 31 to 0 | COSI | DC[31 | :0] A | II O | R | /W | Dela | yed C | ollisio | n Det | ect Co | ount | | | | | | | | | | | | | | | | | | | delay | ed co | llision | S | ### 12.3.11 Lost Carrier Counter Register (LCCR) LCCR is a 32-bit counter that indicates the number of times the carrier was lost during data transmission. When the value in this register reaches H'FFFFFFF, the count is halted. The counter value is cleared to 0 by writing to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | LCC[ | 31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | LCC[ | 15:0] | | | | | | | | | Initial value: 0 | 0<br>R/W 0<br>B/W | 0<br>R/W | 0<br>R/W | 0<br>R/W | 0<br>R/W | 0<br>B/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|----------------------------------------------------------------------------------------| | 31 to 0 | LCC[31:0] | All 0 | R/W | Lost Carrier Count | | | | | | These bits indicate the number of times the carrier was lost during data transmission. | ### 12.3.12 Carrier Not Detect Counter Register (CNDCR) CNDCR is a 32-bit counter that indicates the number of times the carrier could not be detected while the preamble was being sent. When the value in this register reaches H'FFFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------|-----|-----|-----|-----|-----|-----|------|---------|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | CNDC | [31:16] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: R/W | | | | | | | | | | | | | | | | | | | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | CNDC | [15:0] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|-----------------------------------------------------------------------| | 31 to 0 | CNDC[31:0] | All 0 | R/W | Carrier Not Detect Count | | | | | | These bits indicate the number of times the carrier was not detected. | # 12.3.13 CRC Error Frame Counter Register (CEFCR) CEFCR is a 32-bit counter that indicates the number of times a frame with a CRC error was received. When the value in this register reaches H'FFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | CEFC | [31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | CEFC | [15:0] | | | | | | | | | Initial value: 0 | 0<br>R/W 0<br>B/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|-------------------------------------------------------------| | 31 to 0 | CEFC[31:0] | All 0 | R/W | CRC Error Frame Count | | | | | | These bits indicate the count of CRC error frames received. | ### 12.3.14 Frame Receive Error Counter Register (FRECR) FRECR is a 32-bit counter that indicates the number of frames input from the PHY for which a receive error was indicated by the RX-ER pin. FRECR is incremented each time the RX-ER pin becomes active. When the value in this register reaches H'FFFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | FREC | [31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | FREC | [15:0] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|-----------------------------------------------------------------| | 31 to 0 | FREC[31:0] | All 0 | R/W | Frame Receive Error Count | | | | | | These bits indicate the count of errors during frame reception. | ### 12.3.15 Too-Short Frame Receive Counter Register (TSFRCR) TSFRCR is a 32-bit counter that indicates the number of frames of fewer than 64 bytes that have been received. When the value in this register reaches H'FFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | TSFC | [31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | TSFC | [15:0] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|---------------------------------------------------------------------------------------| | 31 to 0 | TSFC[31:0] | All 0 | R/W | Too-Short Frame Receive Count | | | | | | These bits indicate the count of frames received with a length of less than 64 bytes. | #### 12.3.16 Too-Long Frame Receive Counter Register (TLFRCR) TLFRCR is a 32-bit counter that indicates the number of frames received with a length exceeding the value specified by the receive frame length register (RFLR). When the value in this register reaches H'FFFFFFFF, the count is halted. TLFRCR is not incremented when a frame containing residual bits is received. In this case, the reception of the frame is indicated in the residual-bit frame counter register (RFCR). The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | TLFC[ | 31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | TLFC | [15:0] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W 0<br>B/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|---------------------------------------------------------------------------------------------| | 31 to 0 | TLFC[31:0] | All 0 | R/W | Too-Long Frame Receive Count | | | | | | These bits indicate the count of frames received with a length exceeding the value in RFLR. | ### **Residual-Bit Frame Counter Register (RFCR)** RFCR is a 32-bit counter that indicates the number of frames received containing residual bits (less than an 8-bit unit). When the value in this register reaches H'FFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | RFC[ | 31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RFC[ | [15:0] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Initial value: 0 | 0<br>R/W | 0<br>B/W | 0<br>B/W | 0<br>B/W | 0<br>B/W | 0<br>B/W | | | 0<br>R/W | 0<br>B/W | 0<br>B/W | 0<br>B/W | 0<br>B/W | 0<br>B/W | 0<br>B/M | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|----------------------------------------------------------------------------| | 31 to 0 | RFC[31:0] | All 0 | R/W | Residual-Bit Frame Count | | | | | | These bits indicate the count of frames received containing residual bits. | ### 12.3.18 Multicast Address Frame Counter Register (MAFCR) MAFCR is a 32-bit counter that indicates the number of frames received with a specified multicast address. When the value in this register reaches H'FFFFFFFF, the count is halted. The counter value is cleared to 0 by a write to this register with any value. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | MAFC | [31:16] | | | | | | | | | Initial value: 0<br>R/W: R/W | 0<br>R/W | 1000. 1000 | 11/ ** | 10,00 | 10,00 | 11/ ** | 11/ ** | 10,00 | 11/ ** | 10,00 | 10,00 | 11/ ** | 10,00 | 10,00 | 11/ ** | 11/ ** | 10,00 | | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | MAFC | [15:0] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|-------------------------------------------------------------| | 31 to 0 | MAFC[31:0] | All 0 | R/W | Multicast Address Frame Count | | | | | | These bits indicate the count of multicast frames received. | ### 12.3.19 IPG Register (IPGR) IPGR sets the IPG (Inter Packet Gap). This register must not be changed while the transmitting and receiving functions of the EtherC mode register (ECMR) are enabled. (For details, refer to section 12.4.6, Operation by IPG Setting.) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----------|-----|-----| | | - | - | 1 | 1 | - | - | - | - | - | - | - | - | 1 | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | - | - | - | - | - | - | - | - | - | | | IPG[4:0] | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------| | 31 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 to 0 | IPG[4:0] | H'13 | R/W | Inter Packet Gap | | | | | | Sets the IPG value every 4-bit time. | | | | | | H'00: 20-bit time | | | | | | H'01: 24-bit time | | | | | | : : | | | | | | H'13: 96-bit time (Initial value) | | | | | | : : | | | | | | H'1F: 144-bit time | ### 12.3.20 Automatic PAUSE Frame Set Register (APR) APR sets the TIME parameter value of the automatic PAUSE frame. When transmitting the automatic PAUSE frame, the value set in this register is used as the TIME parameter of the PAUSE frame. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|-----|-----|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | AP[1 | 5:0] | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R/W | | | Initial | | | |----------|----------|---------|-----|-----------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 16 | S — | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | AP[15:0] | All 0 | R/W | Automatic PAUSE | | | | | | Sets the TIME parameter value of the automatic PAUSE frame. At this time, 1 bit means 512-bit time. | ### 12.3.21 Manual PAUSE Frame Set Register (MPR) MPR sets the TIME parameter value of the manual PAUSE frame. When transmitting the manual PAUSE frame, the value set to this register is used as the TIME parameter of the PAUSE frame. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|-----|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | MP[1 | 15:0] | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | Initial | | | |----------|----------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 16 | S — | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | MP[15:0] | All 0 | R/W | Manual PAUSE | | | | | | Sets the TIME parameter value of the manual PAUSE frame. At this time, 1 bit means 512-bit time. Read values are undefined. | # 12.3.22 PAUSE Frame Retransfer Count Set Register (TPAUSER) TPAUSER sets the upper limit of the number of times of the PAUSE frame retransfer. TPAUSER must not be changed while the transmitting function is enabled. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|-----|-------|---------|-----|-----|-----|-----|-----|-----|-----| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | TPAUS | E[15:0] | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|--------------|------------------|-----|----------------------------------------------------------------------| | 31 to 16 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | TPAUSE[15:0] | All 0 | R/W | Upper Limit of the Number of Times of PAUSE Frame Retransfer | | | | | | H'0000: Unlimited number of times of retransfer | | | | | | H'0001: Retransfer once | | | | | | : : | | | | | | H'FFFF: Number of times of retransfer is 65535 | # 12.4 Operation The overview of the Ethernet controller (EtherC) are shown below. The EtherC transmits and receives PAUSE frames conforming to the Ethernet/IEEE802.3 frames. #### 12.4.1 Transmission The EtherC transmitter assembles the transmit data on the frame and outputs to MII when there is a transmit request from the E-DMAC. The data transmitted via the MII is transmitted to the lines by PHY-LSI. Figure 12.2 shows the state transition of the EtherC transmitter. **Figure 12.2 EtherC Transmitter State Transitions** - 1. When the transmit enable (TE) bit is set, the transmitter enters the transmit idle state. - 2. When a transmit request is issued by the transmit E-DMAC, the EtherC sends the preamble after a transmission delay equivalent to the frame interval time. If full-duplex transfer is selected, which does not require carrier detection, the preamble is sent as soon as a transmit request is issued by the E-DMAC. - 3. The transmitter sends the SFD, data, and CRC sequentially. At the end of transmission, the transmit E-DMAC generates a transmission complete interrupt (TC). If a collision or the carrier-not-detected state occurs during data transmission, these are reported as interrupt sources. - 4. After waiting for the frame interval time, the transmitter enters the idle state, and if there is more transmit data, continues transmitting. #### 12.4.2 Reception The EtherC receiver separates the frame data (MII into preamble, SFD, DA (destination address), SA (Source address), type/length, Data, and CRC data) and outputs DA, SA, type/length, Data to the E-DMAC. Figure 12.3 shows the state transitions of the EtherC receiver. Figure 12.3 EtherC Receiver State Transmissions - 1. When the receive enable (RE) bit is set, the receiver enters the receive idle state. - 2. When an SFD (start frame delimiter) is detected after a receive packet preamble, the receiver starts receive processing. Discards a frame with an invalid pattern. - 3. In normal mode, if the destination address matches the receiver's own address, or if broadcast or multicast transmission or promiscuous mode is specified, the receiver starts data reception. - 4. Following data reception from the MII, the receiver carries out a CRC check. The result is indicated as a status bit in the descriptor after the frame data has been written to memory. Reports an error status in the case of an abnormality. - 5. After one frame has been received, if the receive enable bit is set (RE = 1) in the EtherC mode register, the receiver prepares to receive the next frame. #### 12.4.3 MII Frame Timing Each MII Frame timing is shown in figure 12.4. Figure 12.4 (1) MII Frame Transmit Timing (Normal Transmission) Figure 12.4 (2) MII Frame Transmit Timing (Collision) Figure 12.4 (3) MII Frame Transmit Timing (Transmit Error) Figure 12.4 (4) MII Frame Receive Timing (Normal Reception) Figure 12.4 (5) MII Frame Receive Timing (Reception Error (1)) Figure 12.4 (6) MII Fame Receive Timing (Reception Error (2)) #### 12.4.4 Accessing MII Registers MII registers in the PHY are accessed via this LSI's PHY interface register (PIR). Connection is made as a serial interface in accordance with the MII frame format specified in IEEE802.3u. MII Management Frame Format: The format of an MII management frame is shown in figure 12.5. To access an MII register, a management frame is implemented by the program in accordance with the procedures shown in MII Register Access Procedure. | Access Type | MII Management Frame | | | | | | | | | |----------------|----------------------|----|----|-------|-------|----|------|------|--| | Item | PRE | ST | OP | PHYAD | REGAD | TA | DATA | IDLE | | | Number of bits | 32 | 2 | 2 | 5 | 5 | 2 | 16 | | | | Read | 11 | 01 | 10 | 00001 | RRRRR | Z0 | DD | | | | Write | 11 | 01 | 01 | 00001 | RRRRR | 10 | DD | Х | | [Legend] PRE: 32 consecutive 1s ST: Write of 01 indicating start of frame OP: Write of code indicating access type PHYAD: Write of 0001 if the PHY address is 1 (sequential write starting with the MSB). This bit changes depending on the PHY address. REGAD: Write of 0001 if the register address is 1 (sequential write starting with the MSB). This bit changes depending on the PHY register address. TA: Time for switching data transmission source on MII interface (a) Write: 10 written (b) Read: Bus release (notation: Z0) performed DATA: 16-bit data. Sequential write or read from MSB (a) Write: 16-bit data write (b) Read: 16-bit data read IDLE: Wait time until next MII management format input (a) Write: Independent bus release (notation: X) performed (b) Read: Bus already released in TA; control unnecessary Figure 12.5 MII Management Frame Format **MII Register Access Procedure:** The program accesses MII registers via the PHY interface register (PIR). Access is implemented by a combination of 1-bit-unit data write, 1-bit-unit data read, bus release, and independent bus release. Figure 12.6 shows the MII register access timing. The timing will differ depending on the PHY type. Figure 12.6 (1) 1-Bit Data Write Flowchart Figure 12.6 (2) Bus Release Flowchart (TA in Read in Figure 12.5) Figure 12.6 (3) 1-Bit Data Read Flowchart Figure 12.6 (4) Independent Bus Release Flowchart (IDLE in Write in Figure 12.5) #### 12.4.5 Magic Packet Detection The EtherC has a Magic Packet detection function. This function provides a Wake-On-LAN (WOL) facility that activates various peripheral devices connected to a LAN from the host device or other source. This makes it possible to construct a system in which a peripheral device receives a Magic Packet sent from the host device or other source, and activates itself. When the Magic Packet is detected, data is stored in the FIFO of the E-DMAC by the broadcast packet that has received data previously and the EtherC is notified of the receiving status. To return to normal operation from the interrupt processing, initialize the EtherC and E-DMAC by using the SWR bit in the E-DMAC mode register (EDMR). With a Magic Packet, reception is performed regardless of the destination address. As a result, this function is valid, and the WOL pin enabled, only in the case of a match with the destination address specified by the format in the Magic Packet. Further information on Magic Packets can be found in the technical documentation published by AMD Corporation. The procedure for using the WOL function with this LSI is as follows. - 1. Disable interrupt source output by means of the various interrupt enable/mask registers. - 2. Set the Magic Packet detection enable bit (MPDE) in the EtherC mode register (ECMR). - 3. Set the Magic Packet detection interrupt enable bit (MPDIP) in the EtherC interrupt enable register (ECSIPR) and clear the other bits in ECSIPR. Set the EtherC status register interrupt permission bit (ECIIP) of the EtherC/E-DMAC status interrupt permission register (EESIPR) in the Ethernet controller direct memory access controller (E-DMAC) and clear the other bits in EESIPR. - 4. If necessary, set the CPU operating mode to sleep mode or set supporting functions to module standby mode. - 5. When a Magic Packet is detected, an interrupt is sent to the CPU. The WOL pin notifies peripheral LSIs that the Magic Packet has been detected. #### 12.4.6 Operation by IPG Setting The EtherC has a function to change the non-transmission period IPG (Inter Packet Gap) between transmit frames. By changing the set values of the IPG setting register (IPGR), the transmission efficiency can be raised and lowered from the standard value. IPG settings are prescribed in IEEE802.3 standards. When changing settings, adequately check that the respective devices can operate smoothly on the same network. Figure 12.7 Changing IPG and Transmission Efficiency #### 12.4.7 Flow Control The EtherC supports flow control functions conforming to IEEE802.3x in full-duplex operations. Flow control can be applied to both receive and transmit operations. The methods for transmitting PAUSE frames when controlling flow are as follows: **Automatic PAUSE Frame Transmission:** For receive frames, PAUSE frames are automatically transmitted when the number of data in the receive FIFO (included in E-DMAC) reaches the value set in the flow control FIFO threshold register (FCFTR) of the E-DMAC. The TIME parameter included in the PAUSE frame at this time is set by the automatic PAUSE frame setting register (APR). The automatic PAUSE frame transmission is repeated until the number of data in the receive FIFO becomes less than the FCFTR setting as the receive data is read from the FIFO. The upper limit of the number of retransfers of the PAUSE frame can also be set by the automatic PAUSE frame retransfer count set register (TPAUSER). In this case, PAUSE frame transmission is repeated until the number of data becomes FCFTR value set or below, or the number of transmits reaches the value set by TPAUSER. The automatic PAUSE frame transmission is enabled when the TXF bit in the EtherC mode register (ECMR) is 1. **Manual PAUSE Frame Transmission:** PAUSE frames are transmitted by directives from the software. When writing the Timer value to the manual PAUSE frame set register (MPR), manual PAUSE frame transmission is started. With this method, PAUSE frame transmission is carried out only once. **PAUSE Frame Reception:** The next frame is not transmitted until the time indicated by the Timer value elapses after receiving a PAUSE frame. However, the transmission of the current frame is continued. A received PAUSE frame is valid only when the RXF bit in the EtherC mode register (ECMR) is set to 1. #### 12.5 Connection to PHY-LSI Figure 12.8 shows the example of connection to a DP83846AVHG by National Semiconductor Corporation. Figure 12.8 Example of Connection to DP83846AVHG # 12.6 Usage Notes • Conditions for Setting LCHNG Bit Even if the level of the signal input to the LNKSTA pin is not changed, the LCHNG bit in ECSR may be set. It may happen when the pin function is changed from port to LNKSTA by PCCRH2 of the PFC or when a software reset caused by the SWR bit in EDMR is cleared while the LNKSTA pin is being driven high. This is because the LNKSTA signal is internally fixed low when the pin functions as a port or during the software reset state regardless of the external pin level. Clear the LCHNG bit before setting the LCHNGIP bit in ECSIPR not to request a LINK signal changed interrupt accidentally. # Section 13 Ethernet Controller Direct Memory Access Controller (E-DMAC) This LSI includes a direct memory access controller (E-DMAC) directly connected to the Ethernet controller (EtherC). A large proportion of buffer management is controlled by the E-DMAC itself using descriptors. This lightens the load on the CPU and enables efficient control of data transfer. Figure 13.1 shows the configuration of the E-DMAC, and the descriptors and transmit/receive buffers in memory. #### 13.1 Features The E-DMAC has the following features: - The load on the CPU is reduced by means of a descriptor management system - Transmit/receive frame status information is indicated in descriptors - Achieves efficient system bus utilization through the use of block transfer (16-byte units) - Supports single-frame/multi-buffer operation Figure 13.1 Configuration of E-DMAC, and Descriptors and Buffers # 13.2 Register Descriptions The E-DMAC has the following registers. For addresses and access sizes of these registers, see section 28, List of Registers. - E-DMAC mode register (EDMR) - E-DMAC transmit request register (EDTRR) - E-DMAC receive request register (EDRRR) - Transmit descriptor list address register (TDLAR) - Receive descriptor list address register (RDLAR) - EtherC/E-DMAC status register (EESR) - EtherC/E-DMAC status interrupt permission register (EESIPR) - Transmit/receive status copy enable register (TRSCER) - Receive missed-frame counter register (RMFCR) - Transmit FIFO threshold register (TFTR) - FIFO depth register (FDR) - Receiving method control register (RMCR) - E-DMAC operation control register (EDOCR) - Receive buffer write address register (RBWAR) - Receive descriptor fetch address register (RDFAR) - Transmit buffer read address register (TBRAR) - Transmit descriptor fetch address register (TDFAR) - Flow control FIFO threshold register (FCFTR) - Receive data padding setting register (RPADIR) - Transmit interrupt register (TRIMD) - Checksum mode register (CSMR) - Checksum skipped bytes monitor register (CSSBM) - Checksum monitor register (CSSMR) #### 13.2.1 E-DMAC Mode Register (EDMR) EDMR is a 32-bit readable/writable register that specifies the operating mode of the E-DMAC. The settings in this register are normally made in the initialization process following a reset. If the EtherC and E-DMAC are initialized by means of this register during data transmission, abnormal data may be sent onto the line. Operating mode settings must not be changed while the transmit and receive functions are enabled. To change the operating mode, the EtherC and E-DMAC modules are got into at their initial state by means of the software reset bit (SWR) in this register, then make new settings. It takes 64 cycles of the internal bus clock Bφ to initialize the EtherC and E-DMAC. Therefore, registers of the EtherC and E-DMAC should be accessed after 64 cycles of the internal bus clock Bφ has elapsed. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|----|----|-----| | [ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | | _ | _ | _ | _ | _ | _ | DE | DL1 | DL0 | _ | l | _ | SWR | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R | R | R | R/W | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 6 | DE | 0 | R/W | E-DMAC Data Endian Convert | | | | | | Selects whether or not the endian format is converted on data transfer by the E-DMAC. However, the endian format of the descriptors and E-DMAC register values are not converted regardless of this bit setting. | | | | | | 0: Endian format not converted (big endian) | | | | | | 1: Endian format converted (little endian) | | | | Initial | | | |--------|----------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 5 | DL1 | 0 | R/W | Descriptor Length | | 4 | DL0 | 0 | R/W | These bits specify the descriptor length. | | | | | | 00: 16 bytes | | | | | | 01: 32 bytes | | | | | | 10: 64 bytes | | | | | | 11: Reserved (setting prohibited) | | 3 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | SWR | 0 | R/W | Software Reset | | | | | | Writing 1 in this bit initializes registers of the E-DMAC other than TDLAR, RDLAR, and RMFCR and registers of the EtherC. While a software reset is being executed (64 cycles of the internal bus clock Bφ), accesses to the all Ethernet-related registers are prohibited. | | | | | | Software reset period (example): | | | | | | When $B\phi = 100$ MHz: 0.64 $\mu$ s | | | | | | When $B\phi = 75$ MHz: 0.85 $\mu$ s | | | | | | This bit is always read as 0. | | | | | | <ol><li>Writing 0 is ignored (E-DMAC operation is not affected)</li></ol> | | | | | | Writing 1 resets the EtherC and E-DMAC and then automatically cleared | ## 13.2.2 E-DMAC Transmit Request Register (EDTRR) The EDTRR is a 32-bit readable/writable register that issues transmit directives to the E-DMAC. When transmission of one frame is completed, the next descriptor is read. If the transmit descriptor active bit in this descriptor has the "active" setting, transmission is continued. If the transmit descriptor active bit has the "inactive" setting, the TR bit is cleared and operation of the transmit DMAC is halted. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | - | ĺ | ĺ | - | _ | _ | ĺ | _ | ĺ | ĺ | - | - | _ | TR | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | TR | 0 | R/W | Transmit Request | | | | | | 0: Transmission-halted state. Writing 0 does not stop transmission. Termination of transmission is controlled by the active bit in the transmit descriptor | | | | | | 1: Start of transmission. The relevant descriptor is read and a frame is sent with the transmit active bit set to 1 | #### 13.2.3 E-DMAC Receive Request Register (EDRRR) EDRRR is a 32-bit readable/writable register that issues receive directives to the E-DMAC. When the receive request bit is set, the E-DMAC reads the relevant receive descriptor. If the receive descriptor active bit in the descriptor has the "active" setting, the E-DMAC prepares for a receive request from the EtherC. When one receive buffer of data has been received, the E-DMAC reads the next descriptor and prepares to receive the next frame. If the receive descriptor active bit in the descriptor has the "inactive" setting, the RR bit is cleared and operation of the receive DMAC is halted. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----| | | _ | _ | | | _ | | _ | _ | _ | _ | _ | _ | | | | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | RR | | _ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | | | Initial | | | |---------|----------|---------|-----|----------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | RR | 0 | R/W | Receive Request | | | | | | 0: The receive function is disabled* | | | | | | A receive descriptor is read and the E-DMAC is ready to receive | Note: \* If the receive function is disabled during frame reception, write-back is not performed successfully to the receive descriptor. Following pointers to read a receive descriptor become abnormal and the E-DMAC cannot operate successfully. In this case, to make the E-DMAC reception enabled again, execute a software reset by the SWR bit in EDMR. To make the E-DMAC reception disabled without executing a software reset, set the RE bit in ECMR. Next, after the E\_DMAC has completed the receiven and write-back to the receive descriptor has been confirmed, disable the receive function of this register. #### Transmit Descriptor List Address Register (TDLAR) 13.2.4 TDLAR is a 32-bit readable/writable register that specifies the start address of the transmit descriptor list. Descriptors have a boundary configuration in accordance with the descriptor length indicated by the DL bit in EDMR. This register must not be written to during transmission. Modifications to this register should only be made while transmission is disabled by the TR bit (= 0) in the E-DMAC transmit request register (EDTRR). | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | TDLA | [31:16] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | TDLA | [15:0] | | | | | | | | | Initial Value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | TDLA | | | | | | | 0<br>R/W | | | | | Initial | | | |---------|------------|---------|-----|---------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 0 | TDLA[31:0] | All 0 | R/W | Transmit Descriptor Start Address | | | | | | The lower bits are set as follows according to the specified descriptor length. | | | | | | 16-byte boundary: TDLA3 to TDLA0 = 0000 | | | | | | 32-byte boundary: TDLA4 to TDLA0 = 00000 | | | | | | 64-byte boundary: TDLA5 to TDLA0 = 000000 | # 13.2.5 Receive Descriptor List Address Register (RDLAR) RDLAR is a 32-bit readable/writable register that specifies the start address of the receive descriptor list. Descriptors have a boundary configuration in accordance with the descriptor length indicated by the DL bit in EDMR. This register must not be written to during reception. Modifications to this register should only be made while reception is disabled by the RR bit (= 0) in the E-DMAC Receive Request Register (EDRRR). | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | RDLA | [31:16] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RDLA | [15:0] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | | | Initial | | | |---------|------------|---------|-----|---------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 0 | RDLA[31:0] | All 0 | R/W | Receive Descriptor Start Address | | | | | | The lower bits are set as follows according to the specified descriptor length. | | | | | | 16-byte boundary: RDLA3 to RDLA0 = 0000 | | | | | | 32-byte boundary: RDLA4 to RDLA0 = 00000 | | | | | | 64-byte boundary: RDLA5 to RDLA0 = 000000 | #### 13.2.6 EtherC/E-DMAC Status Register (EESR) EESR is a 32-bit readable/writable register that shows communications status information on the E-DMAC in combination with the EtherC. The information in this register is reported in the form of interrupts. Individual bits are cleared by writing 1 (however, bit 22 (ECI) is a read-only bit and not to be cleared by writing 1) and are not affected by writing 0. Each interrupt source can also be masked by means of the corresponding bit in the EtherC/E-DMAC status interrupt permission register (EESIPR). The interrupts generated by this register are EINTO. For interrupt priority, see section 6.5, Interrupt Exception Handling Vector Table and Priority. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|-----|----|----|-----|------|------|-------|------|-----|-----|-----|------|------|-----|------| | | _ | TWB | _ | _ | _ | TABT | RABT | RFCOF | ADE | ECI | TC | TDE | TFUF | FR | RDE | RFOF | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | R | R | R | R/W | R/W | R/W | R/W | R | R/W | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | - | CND | DLC | CD | TRO | RMAF | _ | _ | RRF | RTLF | RTSF | PRE | CERF | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R | R | R/W | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 30 | TWB | 0 | R/W | Write-Back Complete | | | | | | Indicates that write-back from the E-DMAC to the corresponding descriptor has completed. This operation is enabled when the TIS bit in TRIMD is set to 1. | | | | | | Write-back has not completed, or no transmission directive | | | | | | 1: Write-back has completed | | 29 to 27 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26 | TABT | 0 | R/W | Transmit Abort Detection | | | | | | Indicates that frame transmission by the EtherC has been aborted because of an error during transmission. | | | | | | Frame transmission has not been aborted or no transmit directive | | | | | | 1: Frame transmit has been aborted | | 25 | RABT | 0 | R/W | Receive Abort Detection | | | | | | Indicates that frame reception by the EtherC has been aborted because of an error during reception. | | | | | | 0: Frame reception has not been aborted or no receive directive | | | | | | 1: Frame receive has been aborted | | 24 | RFCOF | 0 | R/W | Receive Frame Counter Overflow | | | | | | Indicates that the receive FIFO frame counter has overflowed. | | | | | | 0: Receive frame counter has not overflowed | | | | | | 1: Receive frame counter overflows | | 23 | ADE | 0 | R/W | Address Error | | | | | | Indicates that the memory address that the E-DMAC tried to transfer is found illegal. | | | | | | <ol> <li>Illegal memory address not detected (normal operation)</li> </ol> | | | | | | 1: Illegal memory address detected | | | | | | Note: When an address error is detected, the E-DMAC halts transmitting/receiving. To resume the operation, set the E-DMAC again after software reset by means of the SWR bit in EDMR. | | 22 | ECI | 0 | R | EtherC Status Register Interrupt Source | | | | | | This bit is a read-only bit. When the source of an ECSR interrupt in the EtherC is cleared, this bit is also cleared. | | | | | | EtherC status interrupt source has not been detected | | | | | | 1: EtherC status interrupt source has been detected | | Bit | Bit Name | Initial<br>value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 21 | TC | 0 | R/W | Frame Transmit Complete | | | | | | Indicates that all the data specified by the transmit descriptor has been transmitted to the EtherC. The transfer status is written back to the relevant descriptor. When 1-frame transmission is completed for 1-frame/1-buffer processing, or when the last data in the frame is transmitted and the transmission descriptor valid bit (TACT) in the next descriptor is not set for multiple-frame buffer processing, transmission is completed and this bit is set to 1. After frame transmission, the E-DMAC writes the transmission status back to the descriptor. | | | | | | 0: Transfer not complete, or no transfer directive | | | | | | 1: Transfer complete | | 20 | TDE | 0 | R/W | Transmit Descriptor Empty | | | | | | Indicates that the transmission descriptor valid bit (TACT) in the descriptor is not set when the E-DMAC reads the transmission descriptor when the previous descriptor is not the last one of the frame for multiple-buffer frame processing. As a result, an incomplete frame may be transmitted. | | | | | | 0: Transmit descriptor active bit TACT = 1 detected | | | | | | 1: Transmit descriptor active bit TACT = 0 detected | | | | | | When transmission descriptor empty (TDE = 1) occurs, execute a software reset and initiate transmission. In this case, the address that is stored in the transmit descriptor list address register (TDLAR) is transmitted first. | | 19 | TFUF | 0 | R/W | Transmit FIFO Underflow | | | | | | Indicates that underflow has occurred in the transmit FIFO during frame transmission. Incomplete data is sent onto the line. | | | | | | 0: Underflow has not occurred | | | | | | 1: Underflow has occurred | SH7670 Group | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | FR | 0 | R/W | Frame Reception | | | | | | Indicates that a frame has been received and the receive descriptor has been updated. This bit is set to 1 each time a frame is received. | | | | | | 0: Frame not received | | | | | | 1: Frame received | | 17 | RDE | 0 | R/W | Receive Descriptor Empty | | | | | | When receive descriptor empty (RDE = 1) occurs, receiving can be restarted by setting RACT = 1 in the receive descriptor and initiating receiving. | | | | | | 0: Receive descriptor active bit RACT = 1 not detected | | | | | | 1: Receive descriptor active bit RACT = 0 detected | | 16 | RFOF | 0 | R/W | Receive FIFO Overflow | | | | | | Indicates that the receive FIFO has overflowed during frame reception. | | | | | | 0: Overflow has not occurred | | | | | | 1: Overflow has occurred | | 15 to 12 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11 | CND | 0 | R/W | Carrier Not Detect | | | | | | Indicates the carrier detection status. | | | | | | 0: A carrier is detected when transmission starts | | | | | | 1: A carrier is not detected when transmission starts | | 10 | DLC | 0 | R/W | Detect Loss of Carrier | | | | | | Indicates that loss of the carrier has been detected during frame transmission. | | | | | | 0: Loss of carrier not detected | | | | | | 1: Loss of carrier detected | | 9 | CD | 0 | R/W | Delayed Collision Detect | | | | | | Indicates that a delayed collision has been detected during frame transmission. | | | | | | 0: Delayed collision not detected | | | | | | 1: Delayed collision detected | | Bit | Bit Name | Initial<br>value | R/W | Description | |------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | TRO | 0 | R/W | Transmit Retry Over | | | | | | Indicates that a retry-over condition has occurred during frame transmission. Total 16 transmission retries including 15 retries based on the back-off algorithm are failed after the EtherC transmission starts. | | | | | | 0: Transmit retry-over condition not detected | | | | | | 1: Transmit retry-over condition detected | | 7 | RMAF | 0 | R/W | Receive Multicast Address Frame | | | | | | 0: Multicast address frame has not been received | | | | | | 1: Multicast address frame has been received | | 6, 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | RRF | 0 | R/W | Receive Residual-Bit Frame | | | | | | 0: Residual-bit frame has not been received | | | | | | 1: Residual-bit frame has been received | | 3 | RTLF | 0 | R/W | Receive Too-Long Frame | | | | | | Indicates that the frame more than the number of receive frame length upper limit set by RFLR of the EtherC has been received. | | | | | | 0: Too-long frame has not been received | | | | | | 1: Too-long frame has been received | | 2 | RTSF | 0 | R/W | Receive Too-Short Frame | | | | | | Indicates that a frame of fewer than 64 bytes has been received. | | | | | | 0: Too-short frame has not been received | | | | | | 1: Too-short frame has been received | | 1 | PRE | 0 | R/W | PHY Receive Error | | | | | | 0: PHY receive error not detected | | | | | | 1: PHY receive error detected | | 0 | CERF | 0 | R/W | CRC Error on Received Frame | | | | | | 0: CRC error not detected | | | | | | 1: CRC error detected | | | | | | | ## 13.2.7 EtherC/E-DMAC Status Interrupt Permission Register (EESIPR) EESIPR is a 32-bit readable/writable register that enables interrupts corresponding to individual bits in the EtherC/E-DMAC status register (EESR). An interrupt is enabled by writing 1 to the corresponding bit. In the initial state, interrupts are not enabled. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|-------|----|----|-------|--------|--------|-------------|--------|-------|------|-------|--------|--------|-------|--------| | [ | _ | TWBIP | _ | _ | - | TABTIP | RABTIP | RFCOF<br>IP | ADEIP | ECIIP | TCIP | TDEIP | TFUFIP | FRIP | RDEIP | RFOFIP | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | R | R | R | R/W | R/W | R/W | R/W | R | R/W | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | [ | _ | _ | _ | _ | CNDIP | DLCIP | CDIP | TROIP | RMAFIP | _ | _ | RRFIP | RTLFIP | RTSFIP | PREIP | CERFIP | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R | R | R/W | R/W | R/W | R/W | R/W | | | | Initial | | | |----------|----------|---------|-----|----------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 30 | TWBIP | 0 | R/W | Write-Back Complete Interrupt Permission | | | | | | 0: Write-back complete interrupt is disabled | | | | | | 1: Write-back complete interrupt is enabled | | 29 to 27 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 26 | TABTIP | 0 | R/W | Transmit Abort Detection Interrupt Permission | | | | | | 0: Transmit abort detection interrupt is disabled | | | | | | 1: Transmit abort detection interrupt is enabled | | 25 | RABTIP | 0 | R/W | Receive Abort Detection Interrupt Permission | | | | | | 0: Receive abort detection interrupt is disabled | | | | | | 1: Receive abort detection interrupt is enabled | | 24 | RFCOFIP | 0 | R/W | Receive Frame Counter Overflow Interrupt Permission | | | | | | 0: Receive frame counter overflow interrupt is disabled | | | | | | 1: Receive frame counter overflow interrupt is enabled | | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------| | 23 | ADEIP | 0 | R/W | Address Error Interrupt Permission | | | | | | 0: Address error interrupt is disabled | | | | | | 1: Address error interrupt is enabled | | 22 | ECIIP | 0 | R/W | EtherC Status Register Interrupt Permission | | | | | | 0: EtherC status interrupt is disabled | | | | | | 1: EtherC status interrupt is enabled | | 21 | TCIP | 0 | R/W | Frame Transmit Complete Interrupt Permission | | | | | | 0: Frame transmit complete interrupt is disabled | | | | | | 1: Frame transmit complete interrupt is enabled | | 20 | TDEIP | 0 | R/W | Transmit Descriptor Empty Interrupt Permission | | | | | | 0: Transmit descriptor empty interrupt is disabled | | | | | | 1: Transmit descriptor empty interrupt is enabled | | 19 | TFUFIP | 0 | R/W | Transmit FIFO Underflow Interrupt Permission | | | | | | 0: Underflow interrupt is disabled | | | | | | 1: Underflow interrupt is enabled | | 18 | FRIP | 0 | R/W | Frame Received Interrupt Permission | | | | | | 0: Frame received interrupt is disabled | | | | | | 1: Frame received interrupt is enabled | | 17 | RDEIP | 0 | R/W | Receive Descriptor Empty Interrupt Permission | | | | | | 0: Receive descriptor empty interrupt is disabled | | | | | | 1: Receive descriptor empty interrupt is enabled | | 16 | RFOFIP | 0 | R/W | Receive FIFO Overflow Interrupt Permission | | | | | | 0: Receive FIFO overflow interrupt is disabled | | | | | | 1: Receive FIFO overflow interrupt is enabled | | 15 to 12 | | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11 | CNDIP | 0 | R/W | Carrier Not Detect Interrupt Permission | | | | | | 0: Carrier not detect interrupt is disabled | | | | | | 1: Carrier not detect interrupt is enabled | | Bit | Bit Name | Initial<br>value | R/W | Description | |------|----------|------------------|-----|-------------------------------------------------------------------| | 10 | DLCIP | 0 | R/W | Detect Loss of Carrier Interrupt Permission | | | | | | 0: Detect loss of carrier interrupt is disabled | | | | | | 1: Detect loss of carrier interrupt is enabled | | 9 | CDIP | 0 | R/W | Delayed Collision Detect Interrupt Permission | | | | | | 0: Delayed collision detect interrupt is disabled | | | | | | 1: Delayed collision detect interrupt is enabled | | 8 | TROIP | 0 | R/W | Transmit Retry Over Interrupt Permission | | | | | | 0: Transmit retry over interrupt is disabled | | | | | | 1: Transmit retry over interrupt is enabled | | 7 | RMAFIP | 0 | R/W | Receive Multicast Address Frame Interrupt Permission | | | | | | 0: Receive multicast address frame interrupt is disabled | | | | | | 1: Receive multicast address frame interrupt is enabled | | 6, 5 | _ | All 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | RRFIP | 0 | R/W | Receive Residual-Bit Frame Interrupt Permission | | | | | | 0: Receive residual-bit frame interrupt is disabled | | | | | | 1: Receive residual-bit frame interrupt is enabled | | 3 | RTLFIP | 0 | R/W | Receive Too-Long Frame Interrupt Permission | | | | | | 0: Receive too-long frame interrupt is disabled | | | | | | 1: Receive too-long frame interrupt is enabled | | 2 | RTSFIP | 0 | R/W | Receive Too-Short Frame Interrupt Permission | | | | | | 0: Receive too-short frame interrupt is disabled | | | | | | 1: Receive too-short frame interrupt is enabled | | 1 | PREIP | 0 | R/W | PHY-LSI Receive Error Interrupt Permission | | | | | | 0: PHY-LSI receive error interrupt is disabled | | | | | | 1: PHY-LSI receive error interrupt is enabled | | 0 | CERFIP | 0 | R/W | CRC Error on Received Frame | | | | | | 0: CRC error on received frame interrupt is disabled | | | | | | 1: CRC error on received frame interrupt is enabled | ## 13.2.8 Transmit/Receive Status Copy Enable Register (TRSCER) TRSCER specifies whether or not transmit and receive status information reported by bits in the EtherC/E-DMAC status register is to be indicated in bits TFS26 to TFS0 and RFS26 to RFS0 in the corresponding descriptor. Bits in this register correspond to bits 11 to 0 in the EtherC/E-DMAC status register (EESR). When a bit is cleared to 0, the transmit status (bits 11 to 8 in EESR) is indicated in bits TFS3 to TFS0 in the transmit descriptor, and the receive status (bits 7 to 0 in EESR) is indicated in bits RFS7 to RFS0 of the receive descriptor. When a bit is set to 1, the occurrence of the corresponding interrupt is not indicated in the descriptor. After this LSI is reset, all bits are cleared to 0. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|-------|-------|------|-------|------------|----|----|-------|------------|------------|-------|------------| | | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | CNDCE | DLCCE | CDCE | TROCE | RMAF<br>CE | _ | _ | RRFCE | RTLF<br>CE | RTSF<br>CE | PRECE | CERF<br>CE | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R | R | R/W | R/W | R/W | R/W | R/W | | | | Initial | | | |----------|----------|---------|-----|---------------------------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 12 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11 | CNDCE | 0 | R/W | CND Bit Copy Directive | | | | | | 0: Indicates the CND bit state in bit TFS3 in the transmit descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit TFS3 of the transmit descriptor | | 10 | DLCCE | 0 | R/W | DLC Bit Copy Directive | | | | | | 0: Indicates the DLC bit state in bit TFS2 of the transmit descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit TFS2 of the transmit descriptor | | Bit | Bit Name | Initial<br>value | R/W | Description | |------|----------|------------------|-----|---------------------------------------------------------------------------------------------------| | 9 | CDCE | 0 | R/W | CD Bit Copy Directive | | | | | | 0: Indicates the CD bit state in bit TFS1 of the transmit descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit TFS1 of the transmit descriptor | | 8 | TROCE | 0 | R/W | TRO Bit Copy Directive | | | | | | 0: Indicates the TRO bit state in bit TFS0 of the receive descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit TFS0 of the receive descriptor | | 7 | RMAFCE | 0 | R/W | RMAF Bit Copy Directive | | | | | | <ol> <li>Indicates the RMAF bit state in bit RFS7 of the<br/>receive descriptor</li> </ol> | | | | | | Occurrence of the corresponding interrupt is not indicated in bit RFS7 of the receive descriptor | | 6, 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | RRFCE | 0 | R/W | RRF Bit Copy Directive | | | | | | 0: Indicates the RRF bit state in bit RFS4 of the receive descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit RFS4 of the receive descriptor | | 3 | RTLFCE | 0 | R/W | RTLF Bit Copy Directive | | | | | | 0: Indicates the RTLF bit state in bit RFS3 of the receive descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit RFS3 of the receive descriptor | | 2 | RTSFCE | 0 | R/W | RTSF Bit Copy Directive | | | | | | <ol> <li>Indicates the RTSF bit state in bit RFS2 of the<br/>receive descriptor</li> </ol> | | | | | | Occurrence of the corresponding interrupt is not indicated in bit RFS2 of the receive descriptor | | Bit | Bit Name | Initial<br>value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------| | 1 | PRECE | 0 | R/W | PRE Bit Copy Directive | | | | | | 0: Indicates the PRF bit state in bit RFS1 of the receive descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit RFS1 of the receive descriptor | | 0 | CERFCE | 0 | R/W | CERF Bit Copy Directive | | | | | | 0: Indicates the CERF bit state in bit RFS0 of the receive descriptor | | | | | | Occurrence of the corresponding interrupt is not indicated in bit RFS0 of the receive descriptor | #### 13.2.9 Receive Missed-Frame Counter Register (RMFCR) RMFCR is a 16-bit counter that indicates the number of frames missed (discarded, and not transferred to the receive buffer) during reception. When the receive FIFO overflows, the receive frames in the FIFO are discarded. The number of frames discarded at this time is counted. When the value in this register reaches H'FFFF, counting-up is halted. When this register is read, the counter value is cleared to 0. Write operations to this register have no effect. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |----------------|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|---| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 1 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | MFC[ | [15:0] | | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|-----------|------------------|-----|--------------------------------------------------------------------------------------------------------------| | 31 to 16 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | MFC[15:0] | All 0 | R | Missed-Frame Counter | | | | | | Indicate the number of frames that are discarded and not transferred to the receive buffer during reception. | ## 13.2.10 Transmit FIFO Threshold Register (TFTR) TFTR is a 32-bit readable/writable register that specifies the transmit FIFO threshold at which the first transmission is started. The actual threshold is 4 times the set value. The EtherC starts transmission when the amount of data in the transmit FIFO exceeds the number of bytes specified by this register, when the transmit FIFO is full, or when 1-frame write is executed. When setting this register, do so in the transmission-halt state. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|-----|-----|-----|-----|-----|----------|-----|-----|-----|-----|-----| | [ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | [ | _ | _ | _ | _ | _ | | | | | | TFT[10:0 | ] | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R/W | Bit | Bit Name | Initial value | R/W | Description | |----------|-----------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------| | 31 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 to 0 | TFT[10:0] | All 0 | R/W | Transmit FIFO threshold | | | | | | When setting a transmit FIFO, the FIFO must be set to a smaller value than the specified value of the FIFO capacity by FDR. | | | | | | H'00: Store and forward modes | | | | | | H'01 to H'0C: Setting prohibited | | | | | | H'0D: 52 bytes | | | | | | H'0E: 56 bytes | | | | | | : : | | | | | | H'1F: 124 bytes | | | | | | H'20: 128 bytes | | | | | | : : | | | | | | H'3F: 252 bytes | | | | | | H'40: 256 bytes | | | | | | : : | | | | | | H'7F: 508 bytes | | | | | | H'80: 512 bytes | | | | | | H'81 to H'200: Setting prohibited | Note: When starting transmission before one frame of data write has completed, take care the generation of the underflow. # FIFO Depth Register (FDR) FDR is a 32-bit readable/writable register that specifies the depth of the transmit and receive FIFOs. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|------|------|------|----|----|----|----|----|------|------|------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | | _ | TFD2 | TFD1 | TFD0 | _ | _ | _ | _ | _ | RFD2 | RFD1 | RFD0 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | R/W: | R | R | R | R | R | R/W | R/W | R/W | R | R | R | R | R | R/W | R/W | R/W | | | | Initial | | | |----------|----------|---------|-----|-----------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 | TFD2 | 0 | R/W | Transmit FIFO Depth | | 9 | TFD1 | 0 | R/W | These bits specify the depth of the transmit FIFO. | | 8 | TFD0 | 1 | R/W | After the start of the transmission and reception, the setting cannot be changed. | | | | | | 000: 256 bytes | | | | | | 001: 512 bytes | | | | | | Other than above: Setting prohibited | | 7 to 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 | RFD2 | 0 | R/W | Receive FIFO Depth | | 1 | RFD1 | 0 | R/W | These bits specify the depth of the receive FIFO. After | | 0 | RFD0 | 1 | R/W | the start of the transmission and reception, the setting cannot be changed. | | | | | | 000: 256 bytes | | | | | | 001: 512 bytes | | | | | | Other than above: Setting prohibited | ## 13.2.12 Receiving Method Control Register (RMCR) RMCR is a 32-bit readable/writable register that specifies the control method for the RR bit in EDRRR when a frame is received. This register must be set during the receiving-halt state. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----| | [ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | RNC | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | RNC | 0 | R/W | Receive Enable Control | | | | | | 0: When reception of one frame is completed, the E-<br>DMAC writes the receive status into the descriptor<br>and clears the RR bit in EDRRR | | | | | | <ol> <li>When reception of one frame is completed, the E-<br/>DMAC writes the receive status into the descriptor,<br/>reads the next descriptor, and prepares to receive<br/>the next frame</li> </ol> | # 13.2.13 E-DMAC Operation Control Register (EDOCR) EDOCR is a 32-bit readable/writable register that specifies the control methods used in E-DMAC operation. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | FEC | AEC | EDH | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R | | | | Initial | | | |---------|----------|---------|-----|-----------------------------------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 3 | FEC | 0 | R/W | FIFO Error Control | | | | | | Specifies E-DMAC operation when transmit FIFO underflow or receive FIFO overflow occurs. | | | | | | E-DMAC operation continues when underflow or<br>overflow occurs | | | | | | E-DMAC operation halts when underflow or<br>overflow occurs | | 2 | AEC | 0 | R/W | Address Error Control | | | | | | Indicates detection of an illegal memory address in an attempted E-DMAC transfer. | | | | | | Illegal memory address not detected (normal operation) | | | | | | E-DMAC stops its operation due to illegal memory address detection | | | | | | Note: To resume the operation, set the E-DMAC again after software reset by means of the SWR bit in EDMR. | | Bit | Bit Name | Initial<br>value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------| | 1 | EDH | 0 | R/W | E-DMAC Halted | | | | | | 0: The E-DMAC is operating normally | | | | | | The E-DMAC has been halted by NMI pin assertion. E-DMAC operation is restarted by writing 0 | | 0 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | #### 13.2.14 Receiving-Buffer Write Address Register (RBWAR) RBWAR stores the address of data to be written in the receiving buffer when the E-DMAC writes data to the receiving buffer. Which addresses in the receiving buffer are processed by the E-DMAC can be recognized by monitoring addresses displayed in this register. The address that the E-DMAC is actually processing may be different from the value read from this register. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|------|----|----|------|---------|----|----|----|----|----|----|----| | | | | | | | | | RBWA | [31:16] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 4 | 0 | | Ы. | 15 | 14 | 13 | 12 | - 11 | 10 | 9 | | | 0 | 5 | 4 | 3 | | | | | L | | | | | | | | RBW | \[15:0] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|------------|------------------|-----|-----------------------------------------------------| | 31 to 0 | RBWA[31:0] | All 0 | R | Receiving-Buffer Write Address | | | | | | These bits can only be read. Writing is prohibited. | #### 13.2.15 Receiving-Descriptor Fetch Address Register (RDFAR) RDFAR stores the descriptor start address that is required when the E-DMAC fetches descriptor information from the receiving descriptor. Which receiving descriptor information is used for processing by the E-DMAC can be recognized by monitoring addresses displayed in this register. The address from which the E-DMAC is actually fetching a descriptor may be different from the value read from this register. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----| | | | | | | | | | RDFA | [31:16] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RDFA | [15:0] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial value | R/W | Description | |---------|------------|---------------|-----|-----------------------------------------------------| | 31 to 0 | RDFA[31:0] | All 0 | R | Receiving-Descriptor Fetch Address | | | | | | These bits can only be read. Writing is prohibited. | ## 13.2.16 Transmission-Buffer Read Address Register (TBRAR) TBRAR stores the address of the transmission buffer when the E-DMAC reads data from the transmission buffer. Which addresses in the transmission buffer are processed by the E-DMAC can be recognized by monitoring addresses displayed in this register. The address from which the E-DMAC is actually reading in the buffer may be different from the value read from this register. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----| | | | | | | | | | TBRA[ | [31:16] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | TBRA | [15:0] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial value | R/W | Description | |---------|------------|---------------|-----|-----------------------------------------------------| | 31 to 0 | TBRA[31:0] | All 0 | R | Transmission-Buffer Read Address | | | | | | These bits can only be read. Writing is prohibited. | #### 13.2.17 Transmission-Descriptor Fetch Address Register (TDFAR) TDFAR stores the descriptor start address that is required when the E-DMAC fetches descriptor information from the transmission descriptor. Which transmission descriptor information is used for processing by the E-DMAC can be recognized by monitoring addresses displayed in this register. The address from which the E-DMAC is actually fetching a descriptor may be different from the value read from this register. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|------|---------|----|----|-----|----|----|----|----| | | | | | | | | | TDFA | [31:16] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Γ | | | | | | | | | [15:0] | | | · · | | | • | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | Initial | | | |---------|------------|---------|-----|-----------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 0 | TDFA[31:0] | All 0 | R | Transmission-Descriptor Fetch Address | | | | | | These bits can only be read. Writing is prohibited. | #### 13.2.18 Flow Control FIFO Threshold Register (FCFTR) FCFTR is a 32-bit readable/writable register that sets the flow control of the EtherC (setting the threshold on automatic PAUSE transmission). The threshold can be specified by the depth of the receive FIFO data (RFD2 to RFD0) and the number of receive frames (RFF2 to RFF0). The condition to start the flow control is decided by taking OR operation on the two thresholds. Therefore, the flow control by the two thresholds is independently started. When flow control is performed according to the RFD bits setting, if the setting is the same as the depth of the receive FIFO specified by the FIFO depth register (FDR), flow control is started when the remaining FIFO is (FIFO data -64) bytes. For instance, when RFD in FDR = 1 and RFD in FCFTR = 1, flow control is started when (512 -64) bytes of data is stored in the receive FIFO. The value set in the RFD bits in this register should be equal to or less than those in FDR. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|----------|----------|----------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | RFF[2:0] | | | Initial Value:<br>R/W: | 0<br>R 1<br>R/W | 1<br>R/W | 1<br>R/W | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | - | _ | - | _ | _ | _ | _ | _ | | RFD[2:0] | | | Initial Value:<br>R/W: | 0<br>B 0<br>R | 0<br>B | 0<br>R/W | 0<br>R/W | 0<br>R/W | | | | Initial | | | |----------|----------|---------|-----|----------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 19 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 18 to 16 | RFF[2:0] | 111 | R/W | Receive Frame Number Flow Control Threshold | | | | | | 000: When one receive frame has been stored in the receive FIFO | | | | | | 001: When two receive frames have been stored in the receive FIFO | | | | | | : : | | | | | | 110: When seven receive frames have been stored in the receive FIFO | | | | | | 111: When eight receive frames have been stored in the receive FIFO | | 15 to 3 | _ | All 0 | _ | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 to 0 | RFD[2:0] | 000 | R/W | Receive Byte Flow Control Threshold | | | | | | 000: When (256 – 64) bytes of data is stored in the receive FIFO | | | | | | 001: When (512 – 64) bytes of data is stored in the receive FIFO | | | | | | Other than above: Setting prohibited | SH7670 Group ## 13.2.19 Receive Data Padding Setting Register (RPADIR) RPADIR is a 32-bit readable/writable register that performs the padding of receive data. Before setting this register again, reset the software with the SWR bit in the E-DMAC mode register (EDMR). | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|-----|-----|------|--------|-------|-------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | PADS1 | PADS0 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | PADE | R[5:0] | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | | | Initial | | | |----------|-----------|---------|-----|---------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 to 18 | _ | All 0 | _ | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 17 | PADS1 | 0 | R/W | Padding size | | 16 | PADS0 | 0 | R/W | 00: No padding | | | | | | 01: Padding of one byte | | | | | | 10: Padding of two bytes | | | | | | 11: Padding of three bytes | | 15 to 6 | _ | All 0 | _ | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 5 to 0 | PADR[5:0] | 000000 | R/W | Padding Range | | | | | | H'00: Data equivalent to the padding size is inserted in the first byte. | | | | | | H'01: Data equivalent to the padding size is inserted in the second byte. | | | | | | : : | | | | | | H'3E: Data equivalent to the padding size is inserted in the 63rd byte. | | | | | | H'3F: Data equivalent to the padding size is inserted in the 64th byte. | #### 13.2.20 Transmit Interrupt Register (TRIMD) TRIMD is a 32-bit readable/writable register that specifies whether or not to notify write-back completion for each frame using the TWB bit in EESR and an interrupt on transmit operations. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit:_ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | TIS | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------| | 31 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | TIS | 0 | R/W | Transmit Interrupt Setting | | | | | | 0: Write-back completion for each frame is not notified | | | | | | Write-backed completion for each frame using the TWB bit in EESR is notified | # 13.2.21 Checksum Mode Register (CSMR) CSMR is a 32-bit readable/writable register that specifies the checksum operating mode. Set this register when reception is stopped. | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |---------------|-------|------|----|----|----|----|----|----|----|----|-----|-----|-----|------|-----|-----| | | CSEBL | CSMD | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | | Initial Value | : 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | R/W | R/W | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | SB[ | 5:0] | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | | | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | CSEBL | 1 | R/W | Operation Setting for Checksum Calculation Function | | | | | | <ol> <li>The result of checksum calculation is not written<br/>back to the receive descriptor.</li> </ol> | | | | | | <ol> <li>The result of checksum calculation is written back<br/>to the receive descriptor.</li> </ol> | | 30 | CSMD | 1 | R/W | Setting for Checksum Calculation Mode | | | | | | <ol> <li>Checksums are calculated on all the remaining<br/>data after skipping the number of bytes specified in<br/>SB5 to SB0 from the beginning of the MAC layer<br/>packet.</li> </ol> | | | | | | <ol> <li>Packet checksums for the upper layer such as TCP<br/>or UDP are calculated along with the analysis of<br/>the MAC/IP layer packet.</li> </ol> | | 29 to 6 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 5 to 0 | SB[5:0]* | 011010 | R/W | Bytes Skipped in Checksum Calculation | | | | | | These bits specify the number of bytes to be skipped from the beginning of a receive MAC packet. | | | | | | H'00: Byte 0 (checksum calculation starts from the beginning of a receive MAC packet) | | | | | | H'02: Byte 2 | | | | | | : : | | | | | | H'1A: Byte 26 | | | | | | : : | | | | | | H'3E: Byte 62 | Note \* Setting is possible only when CSEBL = 1 and CSMD = 0. Otherwise, 6'h00 should be set. ## 13.2.22 Checksum Skipped Bytes Monitor Register (CSSBM) CSSBM is a 32-bit read-only register that stores the number of skipped bytes during the processing of received packets in the E-DMAC. The number of skipped bytes can be recognized by monitoring the value displayed by this register. Note that the number of items of data received by the E-DMAC may be different from the number of skipped bytes. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|-----|--------|----|----| | | _ | _ | _ | _ | - | 1 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | SBM | I[5:0] | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|-----------------------------------------------------------------------| | 31 to 6 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 5 to 0 | SBM[5:0] | 000000 | R/W | Number of Skipped Bytes | | | | | | These bits can only be read. Writing is prohibited. | | | | | | These bits are initialized to 0 at the beginning of a receive packet. | Note \* The value is valid only when CSEBL = 1 and CSMD = 0. ## 13.2.23 Checksum Monitor Register (CSSMR) CSSMR is a 32-bit read-only register that stores the value of a checksum during the processing of received packets in E-DMAC. The checksum value can be recognized by monitoring the value displayed by this register. Note that the value of the data received by E-DMAC may be different from the checksum value. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----| | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | CS[1 | 5:0] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------| | 31 to 16 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | CS[15:0] | 0 | R | Checksum Value | | | | | | These bits can only be read. Writing is prohibited. | | | | | | These bits are initialized to 0 at the beginning of a receive packet. | Note \* The value is valid only when CSEBL = 1 and CSMD = 0. # 13.3 Operation The E-DMAC is connected to the EtherC, and performs efficient transfer of transmit/receive data between the EtherC and memory (buffers) without the intervention of the CPU. The E-DMAC itself reads control information, including buffer pointers called descriptors, relating to the buffers. The E-DMAC reads transmit data from the transmit buffer and writes receive data to the receive buffer in accordance with this control information. By setting up a number of consecutive descriptors (a descriptor list), it is possible to execute transmission and reception continuously. #### 13.3.1 Descriptor List and Data Buffers Before starting transmission/reception, the communication program creates transmit and receive descriptor lists in memory. The start addresses of these lists are then set in the transmit and receive descriptor list start address registers. The descriptor start address must be aligned so that it matches the address boundary according to the descriptor length set by the E-DMAC mode register (EDMR). The transmit buffer start address can be aligned with a byte, a word, and a longword boundary. #### (1) Transmit Descriptor Figure 13.2 shows the relationship between a transmit descriptor and the transmit buffer. According to the specification in this descriptor, the relationship between the transmit frame and transmit buffer can be defined as one frame/one buffer or one frame/multi-buffer. Figure 13.2 Relationship between Transmit Descriptor and Transmit Buffer # (a) Transmit Descriptor 0 (TD0) TD0 indicates the transmit frame status. The CPU and E-DMAC use TD0 to report the frame transmission status. | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | TACT | TDLE | TFP1 | TFP0 | TFE | | | | | Т | FS[26:16 | 6] | | | | | | Initial Value | 0<br>R/W | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | TFS[ | 15:0] | | | | | | | | | Initial Value: | 0<br>R/W | | | Initial | | | |-----|----------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | value | R/W | Description | | 31 | TACT | 0 | R/W | Transmit Descriptor Active | | | | | | Indicates that this descriptor is active. The CPU sets this bit after transmit data has been transferred to the transmit buffer. The E-DMAC resets this bit on completion of a frame transfer or when transmission is suspended. | | | | | | 0: The transmit descriptor is invalid. | | | | | | Indicates that valid data has not been written to this bit by the CPU, or this bit has been reset by a write-back operation on termination of E-DMAC frame transfer processing (completion or suspension of transmission) | | | | | | If this state is recognized in an E-DMAC descriptor read, the E-DMAC terminates transmit processing and transmit operations cannot be continued (a restart is necessary) | | | | | | 1: The transmit descriptor is valid. | | | | | | Indicates that valid data has been written to the transmit buffer by the CPU and frame transfer processing has not yet been executed, or that frame transfer is in progress | | | | | | When this state is recognized in an E-DMAC descriptor read, the E-DMAC continues with the transmit operation | | Bit | Bit Name | Initial<br>value | R/W | W Description | | | | | | | | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 30 | TDLE | 0 | R/W | Transmit Descriptor List End | | | | | | | | | | | | | After completion of the corresponding buffer transfer, the E-DMAC references the first descriptor. This specification is used to set a ring configuration for the transmit descriptors. | | | | | | | | | | | | | 0: This is not the last transmit descriptor list | | | | | | | | | | | | | 1: This is the last transmit descriptor list | | | | | | | | | 29 | TFP1 | 0 | R/W | Transmit Frame Position 1, 0 | | | | | | | | | 28 | TFP0 | 0 | R/W | These two bits specify the relationship between the transmit buffer and transmit frame. In the preceding and following descriptors, a logically positive relationship must be maintained between the settings of this bit and the TDLE bit. | | | | | | | | | | | | | 00: Frame transmission for transmit buffer indicated by this descriptor continues (frame is not concluded) | | | | | | | | | | | | | 01: Transmit buffer indicated by this descriptor contains end of frame (frame is concluded) | | | | | | | | | | | | | <ol> <li>Transmit buffer indicated by this descriptor is start<br/>of frame (frame is not concluded)</li> </ol> | | | | | | | | | | | | | <ol> <li>Contents of transmit buffer indicated by this<br/>descriptor are equivalent to one frame (one<br/>frame/one buffer)</li> </ol> | | | | | | | | | 27 | TFE | 0 | R/W | Transmit Frame Error | | | | | | | | | | | | | Indicates that one or other bit of the transmit frame status indicated by bits 26 to 0 is set. Whether or not the transmit frame status information is copied into this bit is specified by the transmit/receive status copy enable register. | | | | | | | | | | | | | 0: No error during transmission | | | | | | | | | | | | | 1: An error occurred during transmission | | | | | | | | | Bit | Bit Name | Initial<br>value | R/W | Description | |---------|----------|------------------|-----|-------------------------------------------------------------------------| | 26 to 0 | TFS26 to | All 0 | R/W | Transmit Frame Status | | | TFS0 | | | TFS26 to TFS4: Reserved (The write value should always be 0.) | | | | | | TFS8: Detect Transmit Buffer Underflow (corresponds to TDE bit in EESR) | | | | | | TFS3: Carrier Not Detect (corresponds to CND bit in EESR) | | | | | | TFS2: Detect Loss of Carrier (corresponds to DLC bit in EESR) | | | | | | TFS1: Delayed Collision Detect (corresponds to CD bit in EESR) | | | | | | TFS0: Transmit Retry Over (corresponds to TRO bit in EESR) | ## (b) Transmit Descriptor 1 (TD1) TD1 specifies the transmit buffer length (maximum 64 Kbytes). | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | TDL[15:0] | | | | | | | | | | | | | | | | | | Initial Value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|-----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 16 | TDL[15:0] | All 0 | R/W | Transmit Buffer Data Length | | | | | | These bits specify the valid transfer byte length in the corresponding transmit buffer. | | | | | | When the one frame/multi-buffer system is specified (TD0 and TFP = 10 or 00), the transfer byte length specified in the descriptors at the start and midway can be set in byte units. | | 15 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | # (c) Transmit Descriptor 2 (TD2) TD2 specifies the 32-bit transmit buffer start address. The transmit buffer start address setting can be aligned with a byte, a word, or a longword boundary. #### **(2) Receive Descriptor** Figure 13.3 shows the relationship between a receive descriptor and the receive buffer. In frame reception, the E-DMAC performs data rewriting up to a receive buffer 16-byte boundary, regardless of the receive frame length. Finally, the actual receive frame length is reported in the lower 16 bits of RD1 in the descriptor. Data transfer to the receive buffer is performed automatically by the E-DMAC to give a one frame/one buffer or one frame/multi-buffer configuration according to the size of one received frame. Figure 13.3 Relationship between Receive Descriptor and Receive Buffer # (a) Receive Descriptor 0 (RD0) RD0 indicates the receive frame status. The CPU and E-DMAC use RD0 to report the frame receive status. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | F | RACT | RDLE | RFP | [1:0] | RFE | RCSE | | | | | RFS[9:0] | | | | | | | Initial Value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RCS | [15:0] | | | | | | | | | Initial Value:<br>R/W: | 0<br>R/W | Bit | Bit Name | Initial<br>value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RACT | 0 | R/W | Receive Descriptor Active | | | | | | Indicates that this descriptor is active. The E-DMAC resets this bit after receive data has been transferred to the receive buffer. On completion of receive frame processing, the CPU sets this bit to prepare for reception. | | | | | | 0: The receive descriptor is invalid. | | | | | | Indicates that the receive buffer is not ready (access disabled by E-DMAC), or this bit has been reset by a write-back operation on termination of E-DMAC frame transfer processing (completion or suspension of reception). | | | | | | If this state is recognized in an E-DMAC descriptor read, the E-DMAC terminates receive processing and receive operations cannot be continued. | | | | | | Reception can be restarted by setting RACT to 1 and executing receive initiation. | | | | | | 1: The receive descriptor is valid | | | | | | Indicates that the receive buffer is ready (access enabled) and processing for frame transfer from the FIFO has not been executed, or that frame transfer is in progress. | | | | | | When this state is recognized in an E-DMAC | receive operation. descriptor read, the E-DMAC continues with the | Bit | Bit Name | Initial<br>value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 30 | RDLE | 0 | R/W | Receive Descriptor List Last | | | | | | After completion of the corresponding buffer transfer, the E-DMAC references the first receive descriptor. This specification is used to set a ring configuration for the receive descriptors. | | | | | | 0: This is not the last receive descriptor list | | | | | | 1: This is the last receive descriptor list | | 29, 28 | RFP[1:0] | 00 | R/W | Receive Frame Position | | | | | | These two bits specify the relationship between the receive buffer and receive frame. | | | | | | 00: Frame reception for receive buffer indicated by this descriptor continues (frame is not concluded) | | | | | | <ol> <li>Receive buffer indicated by this descriptor<br/>contains end of frame (frame is concluded)</li> </ol> | | | | | | <ol> <li>Receive buffer indicated by this descriptor is start<br/>of frame (frame is not concluded)</li> </ol> | | | | | | <ol> <li>Contents of receive buffer indicated by this<br/>descriptor are equivalent to one frame (one<br/>frame/one buffer)</li> </ol> | | 27 | RFE | 0 | R/W | Receive Frame Error | | | | | | Indicates that one or other bit of the receive frame status indicated by bits 25 to 16 is set. Whether or not the receive frame status information is copied into this bit is specified by the transmit/receive status copy enable register. | | | | | | 0: No error during reception | | | | | | 1: A certain kind of error occurred during reception | | 26 | RCSE | 0 | R/W | Determination of Receive Packet Checksum Value | | | | | | When CSEBL = 1 and CSMD = 1, the setting shown in table 13.1 occurs depending on the received packet and data. | | | | | | The information in this bit will be invalid if operation is based on any setting other than the above. | | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|-----------|------------------|-----|-----------------------------------------------------------------------------------| | 25 to 16 | RFS[9:0] | All 0 | R/W | Receive Frame Status | | | | | | These bits indicate the error status during frame reception. | | | | | | RFS9: Receive FIFO overflow (corresponds to RFOF bit in EESR) | | | | | | RFS8: Reserved (The write value should always be 0.) | | | | | | RFS7: Multicast address frame received (corresponds to RMAF bit in EESR) | | | | | | RFS6: CAM entry unregistered frame received (corresponds to the RUAF bit in EESR) | | | | | | RSF5: Reserved (The write value should always be 0.) | | | | | | RFS4: Receive residual-bit frame error (corresponds to RRF bit in EESR) | | | | | | RFS3: Receive too-long frame error (corresponds to RTLF bit in EESR) | | | | | | RFS2: Receive too-short frame error (corresponds to RTSF bit in EESR) | | | | | | RFS1: PHY-LSI receive error (corresponds to PRE bit in EESR) | | | | | | RFS0: CRC error on received frame (corresponds to CERF bit in EESR) | | 15 to 0 | RCS[15:0] | All 0 | R/W | Receive Packet Checksum Value | Table 13.1 Types of Receive Packets and the RCSE State of Receive Data | Frame Type | | When Data Is | s Normal | When Data Is Abnormal | | | | | |------------|-----------------------------|--------------|-----------|-----------------------|-----------|--|--|--| | IP version | Option and extension header | RCS[15:0] | RCSE | RCS[15:0] | RCSE | | | | | IPv4 | None | 16'hFFFF | 0 | Undefined | 1 | | | | | | | 16'h0000 | | | | | | | | | Fragment | Undefined | Undefined | Undefined | Undefined | | | | | | Option | 16'hFFFF | 0 | Undefined | 1 | | | | | | | 16'h0000 | | | | | | | | IPv6 | None | 16'hFFFF | 0 | Undefined | 1 | | | | | IPv6 | | 16'h0000 | | | | | | | | | Hop-by-hop | 16'hFFFF | 0 | Undefined | 1 | | | | | | | 16'h0000 | | | | | | | | | Routing | 16'hFFFF | 0 | Undefined | 1 | | | | | | | 16'h0000 | | | | | | | | | End-point option | 16'hFFFF | 0 | Undefined | 1 | | | | | | | 16'h0000 | | | | | | | | | AH | 16'hFFFF | 0 | Undefined | 1 | | | | | | | 16'h0000 | | | | | | | | | Fragment | Undefined | Undefined | Undefined | Undefined | | | | | | ESP | 16'h0000 | 1 | 16'h0000 | 1 | | | | | | MobileIPv6 | 16'h0000 | 1 | 16'h0000 | 1 | | | | | | Others | 16'h0000 | 1 | 16'h0000 | 1 | | | | | | | 16'h0000 | 0 | 16'h0000 | 0 | | | | # (b) Receive Descriptor 1 (RD1) RD1 specifies the receive buffer length (maximum 64 Kbytes). | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | RBL[15:0] | | | | | | | | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RDL | [15:0] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit | Bit Name | Initial<br>value | R/W | Description | |----------|-----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 16 | RBL[15:0] | All 0 | R/W | Receive Buffer Length | | | | | | These bits specify the maximum reception byte length in the corresponding receive buffer. | | | | | | The transfer byte length must align with a 16-byte boundary (bits 19 to 16 cleared to 0). The maximum receive frame length with one frame per buffer is 1,514 bytes, excluding the CRC data. Therefore, for the receive buffer length specification, a value of 1,520 bytes (H'05F0) that takes account of a 16-byte boundary is set as the maximum receive frame length. | | 15 to 0 | RDL[15:0] | All 0 | R/W | Receive Data Length | | | | | | These bits specify the data length of a receive frame stored in the receive buffer. | | | | | | The receive data transferred to the receive buffer does not include the 4-byte CRC data at the end of the frame. The receive frame length is reported as the number of words (valid data bytes) not including this CRC data. | # (c) Receive Descriptor 2 (RD2) RD2 specifies the 32-bit receive buffer start address. The receive buffer start address must be aligned with a longword boundary. However, when SDRAM is connected, it must be aligned with a 16-byte boundary. ### 13.3.2 Transmission When the transmit function is enabled and the transmit request bit (TR) is set in the E-DMAC transmit request register (EDTRR), the E-DMAC reads the descriptor used last time from the transmit descriptor list (in the initial state, the descriptor indicated by the transmission descriptor start address register (TDLAR)). If the setting of the TACT bit in the read descriptor is active, the E-DMAC reads transmit frame data sequentially from the transmit buffer start address specified by TD2, and transfers it to the EtherC. The EtherC creates a transmit frame and starts transmission to the MII. After DMA transfer of data equivalent to the buffer length specified in the descriptor, the following processing is carried out according to the TFP value. - TFP = 00 or 01 (frame continuation): Descriptor write-back is performed after DMA transfer. - 2. TFP = 01 or 11 (frame end):Descriptor write-back is performed after completion of frame transmission. The E-DMAC continues reading descriptors and transmitting frames as long as the setting of the TACT bit in the read descriptors is "active." When a descriptor with an "inactive" TACT bit is read, the E-DMAC resets the transmit request bit (TR) in the transmit register and ends transmit processing (EDTRR). Figure 13.4 Sample Transmission Flowchart ### 13.3.3 Reception When the receive function is enabled and the CPU sets the receive request bit (RR) in the E-DMAC receive request register (EDRRR), the E-DMAC reads the descriptor following the previously used one from the receive descriptor list (the descriptor indicated by the receive descriptor list's starting address register (RDLA) is used at the initial state), and then enters the receive-standby state. If the setting of the RACT bit is "active" and an own-address frame is received, the E-DMAC transfers the frame to the receive buffer specified by RD2. If the data length of the received frame is greater than the buffer length given by RD1, the E-DMAC performs write-back to the descriptor when the buffer is full (RFP = 10 or 00), then reads the next descriptor. The E-DMAC then continues to transfer data to the receive buffer specified by the new RD2. When frame reception is completed, or if frame reception is suspended because of a certain kind of error, the E-DMAC performs write-back to the relevant descriptor (RFP = 11 or 01), and then ends the receive processing. The E-DMAC then reads the next descriptor and enters the receive-standby state again. To receive frames continuously, the receive enable control bit (RNC) must be set to 1 in the receive control register (RCR). After initialization, this bit is cleared to 0. Figure 13.5 Sample Reception Flowchart ### 13.3.4 Multi-Buffer Frame Transmit/Receive Processing ### **Multi-Buffer Frame Transmit Processing** If an error occurs during multi-buffer frame transmission, the processing shown in figure 13.6 is carried out by the E-DMAC. Where the transmit descriptor is shown as inactive (TACT bit = 0) in the figure, buffer data has already been transmitted normally, and where the transmit descriptor is shown as active (TACT bit = 1), buffer data has not been transmitted. If a frame transmit error occurs in the first descriptor part where the transmit descriptor is active (TACT bit = 1), transmission is halted, and the TACT bit cleared to 0, immediately. The next descriptor is then read, and the position within the transmit frame is determined on the basis of bits TFP1 and TFP0 (continuing [B'00] or end [B'01]). In the case of a continuing descriptor, the TACT bit is cleared to 0, only, and the next descriptor is read immediately. If the descriptor is the final descriptor, not only is the TACT bit cleared to 0, but write-back is also performed to the TFE and TFS bits at the same time. Data in the buffer is not transmitted between the occurrence of an error and write-back to the final descriptor. If error interrupts are enabled in the EtherC/E-DMAC status interrupt permission register (EESIPR), an interrupt is generated immediately after the final descriptor write-back. Figure 13.6 E-DMAC Operation after Transmit Error ### **Multi-Buffer Frame Receive Processing** If an error occurs during multi-buffer frame reception, the processing shown in figure 13.7 is carried out by the E-DMAC. Where the receive descriptor is shown as inactive (RACT bit = 0) in the figure, buffer data has already been received normally, and where the receive descriptor is shown as active (RACT bit = 1), this indicates a buffer for which reception has not yet been performed. If a frame receive error occurs in the first descriptor part where the RACT bit = 1 in the figure, reception is halted immediately and a status write-back to the descriptor is performed. If error interrupts are enabled in the EtherC/E-DMAC status interrupt permission register (EESIPR), an interrupt is generated immediately after the write-back. If there is a new frame receive request, reception is continued from the buffer after that in which the error occurred. Figure 13.7 E-DMAC Operation after Receive Error ### 13.3.5 Padding Receive Data The E-DMAC can pad one to three bytes anywhere in the receive data to increase the efficiency of processing of receive data. For example, by padding two bytes after the 14-byte MAC header of an Ethernet frame with this function, the subsequent data can be placed at the beginning of the four-byte boundary. Figure 13.8 Padding Receive Data ### 13.3.6 Checksum Calculation Function Page 490 of 1278 Checksum calculation for receive packets is accelerated in the following two modes: - Checksum calculation mode of MAC/IP packet analysis type - All-data checksum calculation mode of skipped bytes designation type # (1) Checksum Calculation Mode of MAC/IP Packet Analysis Type (CSEBL = 1 and CSMD = 1) Any receive packet included in the table below will be the target of calculation. Note that even when a receive packet is included in the table, checksum calculation is not done if the MAC packet payload contains padding data that has been inserted because the IP packet is small. | IPver | Item | | | | | | | | | |-------|-------------------------------------------------------|--|--|--|--|--|--|--|--| | IPv4 | No option | | | | | | | | | | | Option provided | | | | | | | | | | | Fragment*1 | | | | | | | | | | IPv6 | No extension header | | | | | | | | | | | Length of the extension header of a hop-by-hop option | | | | | | | | | | | Length of the extension header of routing | | | | | | | | | | | Length of the extension header of a fragment*1 | | | | | | | | | | | Length of the extension header of an end-point option | | | | | | | | | | | Length of the extension header of AH | | | | | | | | | | | Length of the extension header of ESP*2 | | | | | | | | | | | Length of the extension header of MobileIPv6*2 | | | | | | | | | Notes: \*1. This is the target of calculation, but both RCS15 to RCS0 and RCSE will be undefined even if the data is normal. <sup>\*2.</sup> No calculation is performed on RCS15 to RCS0, and RCSE is set to 1. The following shows the areas as the target of calculation of an IPv4 packet. The shaded portions are the target of calculation. Note: \* This is changed to the octet basis and undergoes a subtraction during checksum calculation. During calculation, {8'h00, protocol No.[7:0]} is used. Jun 21, 2011 The following shows the areas as the target of calculation of an IPv6 packet. The shaded portions are the target of calculation. Note: 1. Calculation applies only to TCP/UDP. Calculation requires an expansion to {8'h00, next header[7:0]}. 2. This is changed to the octet basis and undergoes a subtraction during checksum calculation. ### All-Data Checksum Calculation Mode of Skipped Bytes Designation Type (CSEBL = 1 **(2)** and CSMD = 0) The data equivalent to the number of bytes specified by SB5 to SB0 is skipped from the beginning of a packet, and checksums are calculated on all of the subsequent valid data. (Example: 14-byte skip) #### 13.3.7 **Usage Notes** The checksum calculation function is not affected by the padding function specified through the receive data padding setting register (RPADIR). Checksums are calculated when the receive data is transferred from the EtherC to the E-DMAC, whereas the receive data is padded when it is transferred from the E-DMAC to the receive buffer in memory. # Section 14 DMAC That Works with Encryption/Decryption and Forward Error Correction Core (A-DMAC) #### 14.1 Overview The A-DMAC is a high-level descriptor-mode DMAC having error correction function. This DMAC provides data transfer with memory via an internal shared bus (I-BUS) and data transfer with an external MPEG device via STIF. #### 14.1.1 **Features** The functions and features of this A-DMAC are as follows: #### **(1)** Channels for checksum processing - Number of channels: 2 - Transfer direction: Memory $\leftarrow \rightarrow$ memory, memory $\leftarrow \rightarrow$ STIF - Descriptor structure: Structure that enables checksum operation, etc., to be continuously performed - Error check: Checksum calculation function #### **FEC** channels **(2)** - Number of channels: 1 - Descriptor structure: Structure that enables processing of any number of data items with a small number of buffers - Error correction (FEC): XOR calculation function ### (3) Other features - Supported endian: Big endian/little endian - Number of STIFs connected: Two channels - Channel arbitration: Round robin scheduling that provides highly efficient use of encryption modules and buses - Channel operation: Parallel processing ### 14.1.2 Overall Configuration of the A-DMAC The A-DMAC is configured as shown in figure 14.1. Table 14.1 gives an overview of A-DMAC submodules. The A-DMAC is connected to the I-BUS via the I-BUS interface, to the STIF0 via the STIF0 interface, and to the STIF1 via the STIF1 interface. The I-BUS is a shared bus in this LSI operating on the B clock. The STIF is an I/O port for MPEG-2 TS/PS format data. The STIF0 is fixed at CH0 and the STIF1 fixed at CH1. The A-DMAC has two channels for checksum operation that operate on descriptors. Aside from these channels, the A-DMAC has an FEC channel dedicated for FEC operation. This FEC channel performs XOR operation of FEC operation. These modules operate in parallel. For example, when the bus for channel 0 for checksum processing is accessed, channel 1 for checksum processing can perform checksum operation. The arbiter is a module that arbitrates the requests sent from each checksum processing channel and each initiator of the FEC channel. The arbiter arbitrates requests from an initiator in round robin scheduling. If you want to execute CH0 and CH1 simultaneously and raise the priority of CH0 or CH1, the arbiter controls the priorities in descriptor ring units (example: When the descriptor of CH0 or CH1, whichever has a lower priority, runs dry, the arbiter piles up the next descriptor after a certain idling) or controls the priorities by suspending channel processing of lower priority. Figure 14.1 Block Diagram of A-DMAC # **Table 14.1 A-DMAC Submodules** | Submodule Name | Function | |----------------------|--------------------------------------------------------------------------------| | Channel for checksum | DMA automatic processing based on descriptors | | processing | Checksum operation | | | Continuous execution of checksum | | FEC channel | DMA automatic processing based on descriptors | | | <ul> <li>XOR operation for any number of data items</li> </ul> | | Arbiter | Arbitrates requests from the channel for checksum processing | | | and FEC channel. | | | Channel arbitration mode is round robin scheduling. | | I-BUS interface | Conversion between I-BUS protocol and A-DMAC protocol | | | <ul> <li>Distribution of register R/W requests from the CPU to each</li> </ul> | | | module | | STIF interface | Conversion between STIF protocol and A-DMAC protocol | | | <ul> <li>STIF0 is fixed at channel 0 for encryption/authentication.</li> </ul> | | | STIF1 is fixed at channel 1 for encryption/authentication. | #### 14.1.3 Restrictions on the A-DMAC The following restrictions apply to the A-DMAC: - The A-DMAC supports only register access in 32-bit units. - If the channel processor, or FEC processor is running, write to registers related to the appropriate processor is inhibited. However, you can write data to the following two registers by verifying them after the write even if the appropriate processor is running. Write data repeatedly till verify succeeds. - Channel [i] processing control register (C[i]C) (However, do not rewrite the C[i]C\_R bit of the running channel processor.) - Channel [i] processing interrupt request register (C[i]I) - Descriptors of data size 0 are inhibited. # 14.2 Register Descriptions The A-DMAC has the following registers. For details on the addresses of these registers and the register status in each processing state, see section 28, List of Registers. - Channel [i] processing control register (C[i]C) (i = 0, 1) - Channel [i] processing mode register (C[i]M) (i = 0, 1) - Channel [i] processing interrupt request register (C[i]I) (i = 0, 1) - Channel [i] processing descriptor start address register (C[i]DSA) (i = 0, 1) - Channel [i] processing descriptor current address register (C[i]DCA) (i = 0, 1) - Channel [i] processing descriptor 0 register (C[i]D0) [control] (i = 0, 1) - Channel [i] processing descriptor 1 register (C[i]D1) [source address] (i = 0, 1) - Channel [i] processing descriptor 2 register (C[i]D2) [destination address] (i = 0, 1) - Channel [i] processing descriptor 3 register (C[i]D3) [data length] (i = 0, 1) - Channel [i] processing descriptor 4 register (C[i]D4) [checksum value write address] (i = 0, 1) - FEC DMAC processing control register (FECC) - FEC DMAC processing interrupt request register (FECI) - FEC DMAC processing descriptor start address register (FECDSA) - FEC DMAC processing descriptor current address register (FECDCA) - FEC DMAC processing descriptor 0 register (FECD00) [control] - FEC DMAC processing descriptor 1 register (FECD01D0A) [destination address] - FEC DMAC processing descriptor 2 register (FECD02S0A) [source 0 address] - FEC DMAC processing descriptor 3 register (FECD03S1A) [source 1 address] # 14.2.1 Channel [i] Processing Control Register (C[i]C) (i = 0, 1) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|---------| | | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | C[i]C_R | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | | C[i]C_<br>DWF | _ | l | | C[i]C_<br>VLD | _ | _ | | C[i]C_<br>EIE | ı | _ | _ | C[i]C_E | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W | R | R | R | R/W | R | R | R | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 17 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 16 | C[i]C_R | 0 | R/W | Reset | | | | | | Writing 1 to this bit when the channel [i] processor is halted causes the channel [i] calculation sequence to be reset. This bit is automatically and immediately set to 0. Setting both this bit and the C[i]C_E bit to 1 causes channel [i] processing to be newly started. | | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | C[i]C_DWF | 0 | R | WAIT State Flag after Descriptor Processing End | | | | | | 0: Non-WAIT state | | | | | | 1: WAIT state | | | | | | There are two methods for understanding the processing state of the DMAC channel [i] descriptor. In one, when the DMAC channel [i] descriptor is set, C[i]DWE is set to 1 and then C[i]DIE is set to 1 to accept the "1 descriptor processing end" interrupt request. In the other, the processing state is observed till this bit is set to 1. | | 11 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | C[i]C_VLD | 0 | R/W | Variable-Length Descriptor Control Flag | | | | | | 0: Fixed-length descriptor (32 bytes) | | | | | | 1: Variable-length descriptor (16/32 bytes) | | | | | | The A-DMAC channel uses the 32-byte fixed length structure or 16/32-byte variable-length structure. If this bit is set to 0 to define the descriptor as the fixed-length, the descriptor is always read as 32 bytes. If this bit is set to 1 to define the descriptor as the variable-length, the first 16 bytes are read, and if r_cid4/r_cid5/r_cid6/r_cid7 information is required, the remaining 16 bytes are read according to the contents of r_cidm/r_cihm. | | 7 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | C[i]C_EIE | 0 | R/W | "Processing End" Interrupt Request Enable | | | | | | When processing ends, specifies whether to enable or disable the "processing end" interrupt request. | | | | | | 0: Disables the "processing end" interrupt request. | | | | | | 1: Enables the "processing end" interrupt request. | | | | | | A-DMAC channel [i] processing end means fetching of depleted descriptors (invalid descriptors (descriptors where C[i]F0 is set to 0)). | | 3 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | C[i]C_E | 0 | R/W | Execution Request | | | | | | Setting this bit to 1 causes channel [i] processing to be started. Setting this bit to 0 causes channel [i] processing to be suspended. When 0 is written to this bit, 0 is read immediately but the channel [i] processor does not stop immediately. That is, the processor stops after it writes back to the descriptor being processed. To understand the channel operating state, set the C[i]C_EIE bit to 1 to accept the "operation end" interrupt request or poll the "operation end" interrupt request flag. To start new processing, the channel [i] of the STIF must be initialized. | | | | | | 0: Channel [i] processing is halted. | | | | | | 1: Channel [i] processing is in progress. | | | | | | Determine if channel [i] processing is suspended when the processor writes back to the descriptor. | # 14.2.2 Channel [i] Processing Mode Register (C[i]M) (i = 0, 1) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |----------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|--| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | | | Bit:_ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | C[i]M_<br>LIE | _ | | _ | _ | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R | R | R | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------| | 31 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | C[i]M_LIE | 0 | R/W | "Last Data Descriptor End Processing" Interrupt<br>Request Enable | | | | | | When last data (C[i]F2=1) descriptor end processing ends, specifies whether to enable or disable the interrupt request. | | | | | | Disables the "last data descriptor processing end" interrupt request. | | | | | | <ol> <li>Enables the "last data descriptor processing end"<br/>interrupt request.</li> </ol> | | 3 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | # 14.2.3 Channel [i] Processing Interrupt Request Register (C[i]I) (i = 0, 1) ad\_irqc[i]\_n is asserted as negation of logical OR of all bits in this register. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|--------------|----|----|----|--------------|----|----|----|----|----|----|----|--------------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | C[i]I_<br>DI | | _ | _ | C[i]I_<br>LI | _ | _ | | | _ | | _ | C[i]I_<br>EI | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | D /// | D | D | D | D/M | D | D | D | D/M | D | D | D | D | D | D | D | DAM | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | C[i]l_DI | 0 | R/W | "1 Descriptor Processing End" Interrupt Request (interrupt request to notify you that the processor ended descriptor processing and wrote back the descriptor) | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. | | | | | | <ol><li>The "1 descriptor processing end" interrupt is not<br/>requested.</li></ol> | | | | | | The "1 descriptor processing end" interrupt is requested. | | 11 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | C[i]I_LI | 0 | R/W | "Continuous Data Last Descriptor Processing End" Interrupt Request (interrupt request to notify you that processing described in the descriptor where C[i]F2 is set to 1 ended) | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. | | | | | | The "last descriptor processing end" interrupt is not requested. | | | | | | The "last descriptor processing end" interrupt is requested. | | 7 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | C[i]I_EI | 0 | R/W | "Processing End" Interrupt Request | | | | | | This bit indicates whether the "processing end" interrupt is requested. | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. | | | | | | 0: The "processing end" interrupt is not requested. | | | | | | 1: The "processing end" interrupt is requested. | | | | | | "Processing end" means fetching of depleted descriptors (invalid descriptors (descriptors where C[i]F0 is set to 0)). | # 14.2.4 Channel [i] Processing Descriptor Start Address Register (C[i]DSA) (i = 0, 1) Do not write any value to this register when C[i]C\_E is set to 1. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | | C[i]DSA | [31:16] | | | | | | | | | Initial Value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | [ | | | | | | C[i]DS | A[15:4] | | | | | | | C[i]DS | SA[3:0] | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|---------------|------------------|-----|--------------------------------------------------------------------------------| | 31 to 4 | C[i]DSA[31:4] | All 0 | R/W | Descriptor Ring Start Address | | 3 to 0 | C[i]DSA[3:0] | All 0 | R | Specify a descriptor ring start address. Set a 16-byte boundary address value. | # 14.2.5 Channel [i] Processing Descriptor Current Address Register (C[i]DCA) (i = 0, 1) Do not write any value to this register when C[i]C\_E is set to 1. | В | it: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |---------------------|----------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | | C[i]DCA | (31:16] | | | | | | | | | Initial Valu<br>R/V | e: 0<br>V: R/W | 0<br>R/W | В | it: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | C[i]DC | A[15:4] | | | | | | | C[i]DC | A[3:0] | | | Initial Valu | e: 0<br>V: R/W | 0<br>B/W | 0<br>B/W | 0<br>R/W 0<br>B | 0<br>B | 0<br>B | 0<br>B | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|---------------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 4 | C[i]DCA[31:4] | All 0 | R/W | Descriptor Current Address | | 3 to 0 | C[i]DCA[3:0] | All 0 | R | Specify the start address of descriptor processing. Set a 16-byte boundary address value. When descriptor processing is in progress, these bits indicate the address of descriptor currently being processed. After descriptor write-back, these bits indicate the address of the next descriptor. | #### Channel [i] Processing Descriptor 0 Register (C[i]D0) [Control] (i = 0, 1) 14.2.6 Do not write any value to this register when C[i]C\_E is set to 1. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | C[i]CRI | DO[3:0] | | | C[i]CHI | 00[3:0] | | | C[i]S0 | D[3:0] | | C[i]DA | C[i]SA | C[i]CS | M[1:0] | | Initial Value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | | | - | - | _ | _ | _ | _ | _ | C[i]F2 | C[i]F1 | C[i]F0 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|---------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 28 | C[i]CRDO[3:0] | All 0 | R/W | Transfer Data Destination Data Sequence | | | | | | Specify a swap method for writing transfer data after encryption processing from the A-DMAC to memory such as the STIF and SDRAM or after checksum operation. Specify a swap method for writing the checksum operation result obtained from body data in the C[i]CHDO3 to C[i]CHDO0 bits, not these bits. | | Bit | Bit Name | Initial<br>Value | R/W | De | scription | |----------|---------------|------------------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 28 | C[i]CRDO[3:0] | All 0 | R/W | • | When the destination is not the STIF (C[i]DA bit | | | | | | | = 0) C[i]CRDO3: Data swap in two-byte units (longword swap in word units) | | | | | | | 0: As-is<br>1: Swap | | | | | | | C[i]CRDO2: Data swap in one-byte units (word swap in byte units) | | | | | | | 0: As-is<br>1: Swap | | | | | | | C[i]CRDO1: Inversion of bit 1 at address when one or two bytes are accessed | | | | | | | 0: As-is<br>1: Inversion | | | | | | | C[i]CRDO0: Inversion of bit 0 at address when one byte is accessed | | | | | | | 0: As-is<br>1: Inversion | | | | | | | C[i]CRDO1 and C[i]CRDO0 function for endian adjustment. Note that if an endian different from the endian of this LSI is used, up to three different addresses are accessed from the address where the start and end addresses are specified when an area is allocated. | | | | | | • | When the destination is the STIF (C[i]DA bit = 1) | | | | | | | C[i]CRDO3: Data swap in two-byte units (longword swap in word units) | | | | | | | 0: As-is<br>1: Swap | | | | | | | C[i]CRDO2: Data swap in one-byte units (word swap in byte units) | | | | | | | 0: As-is<br>1: Swap | | | | | | | C[i]CRDO1: Data swap in one-bit units (byte swap in one-bit units) | | | | | | | 0: As-is<br>1: Swap | | | | | | | C[i]CRDO0: Set this bit to 0 as reserved. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|---------------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27 to 24 | C[i]CHDO[3:0] | All 0 | R/W | Checksum Operation Result Destination Data<br>Sequence | | | | | | Specify a swap method for writing the checksum operation result from the A-DMAC to memory such as SDRAM. Specify a swap method for writing body data after checksum operation in the C[i]CRDO3 to C[i]CRDO0 bits. | | | | | | C[i]CHDO3: Data swap in two-byte units (longword swap in word units) | | | | | | 0: As-is | | | | | | 1: Swap | | | | | | C[i]CHDO2: Data swap in one-byte units (word swap in byte units) | | | | | | 0: As-is | | | | | | 1: Swap | | | | | | C[i]CHDO1: Inversion of bit 1 at address when one or two bytes are accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | C[i]CHDO0: Inversion of bit 0 at address when one byte is accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | C[i]CHDO1 and C[i]CHDO0 function for endian adjustment. Note that if an endian different from the endian of this LSI is used, up to three different addresses are accessed from the address where the start and end addresses are specified when an area is allocated. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-------------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23 to 20 | C[i]SO[3:0] | All 0 | R/W | Source Data Sequence | | | | | | Specify a swap method for reading data from memory such as the STIF and SDRAM to the A-DMAC. | | | | | | • When the source is not the STIF (C[i]SA bit = 0) | | | | | | C[i]SO3: Data swap in two-byte units (longword swap in word units) | | | | | | 0: As-is<br>1: Swap | | | | | | C[i]SO2: Data swap in one-byte units (word swap in byte units) 0: As-is 1: Swap | | | | | | C[i]SO1: Inversion of bit 1 at address when one or two bytes are accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | C[i]SO0: Inversion of bit 0 at address when one byte is accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | C[i]SO1 and C[i]SO0 function for endian adjustment. Note that if an endian different from the endian of this LSI is used, up to three different addresses are accessed from the address where the start and end addresses are specified when an area is allocated. | | | | | | • When the source is the STIF (C[i]SA bit = 1) | | | | | | C[i]SO3: Data swap in two-byte units (longword swap in word units) | | | | | | 0: As-is<br>1: Swap | | | | | | C[i]SO2: Data swap in one-byte units (word swap in byte units) | | | | | | 0: As-is<br>1: Swap | | | | | | C[i]SO1: Data swap in one-bit units (byte swap in one-bit units) | | | | | | 0: As-is<br>1: Swap | | | | | | C[i]SO0: Set this bit to 0 as reserved. | | | | | | This bit is referenced in AES encryption/decryption, DES/3DES encryption/decryption, SHA hash generation, HMAC keyed hash generation, target data read for checksum operation, and data copy from memory to the STIF and from the STIF to memory. However, this bit is not referenced in key copy and initial vector copy. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | C[i]DA | 0 | R/W | Destination Attribute | | | | | | Specifies whether the data read source uses the channel [i] (the destination address is not used) of the STIF or the destination address (memory such as SDRAM). | | | | | | 0: Uses the destination address (memory such as SDRAM). | | | | | | 1: Uses the channel [i] of the STIF | | 18 | C[i]SA | 0 | R/W | Source Attribute | | | | | | Specifies whether the data read source uses the channel [i] (the source address is not used) of the STIF or the source address (memory such as SDRAM). | | | | | | 0: Uses the source address (memory such as SDRAM). | | | | | | 1: Uses the channel [i] of the STIF | | 17, 16 | C[i]CSM[1:0] | 00 | R/W | Checksum Mode | | | | | | 00: Checksum (not initialized, not written back) | | | | | | Not beginning of data | | | | | | Not end of data | | | | | | 01: Checksum (not initialized, written back) | | | | | | Not beginning of data End of data | | | | | | 10: Checksum (initialized, not written back) | | | | | | Beginning of data | | | | | | Not end of data | | | | | | 11: Checksum (initialized, written back) | | | | | | Beginning of data End of data | | 15 to 3 | _ | All 0 | R/W | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | C[i]F2 | 0 | R/W | Descriptor Execution Flag 2 | | | | | | When splitting continuous data into several descriptors for execution, set this bit to 1 in the descriptor that processes the last data part (because the pointer in the A-DMAC must be initialized to process the next descriptor). | | | | | | Use this flag when splitting and executing descriptors because the encryption/decryption part, authentication part, and checksum operation part in data such as IPsec/TLS differ. | | | | | | 0: Non-last descriptor that processes continuous data | | | | | | 1: Last descriptor that processes continuous data | | 1 | C[i]F1 | 0 | R/W | Descriptor Execution Flag 1 | | | | | | When this bit is 1, the A-DMAC regards this descriptor as the last descriptor in the descriptor ring area. When processing of this descriptor ends, the A-DMAC returns to the beginning (descriptor start address) of the descriptor ring area. | | | | | | 0: Non-last descriptor ring | | | | | | 1: Last descriptor ring | | 0 | C[i]F0 | 0 | R/W | Descriptor Execution Flag 0 | | | | | | When this bit is 0, the A-DMAC ends processing because this descriptor is invalid. When this bit is 1, this descriptor is valid. When this bit is 1 (valid descriptor), the A-DMAC sets this bit to 0 and writes back to the original address after processing of this descriptor ends. | | | | | | 0: Invalid descriptor | | | | | | 1: Valid descriptor | ## 14.2.7 Channel [i] Processing Descriptor 1 Register (C[i]D1) [Source Address] (i = 0, 1) | Bit: 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | | C[i]D1 | 31:16] | | | | | | | | | Initial Value:<br>R/W: R | 0<br>R/W | Bit: 1 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | C[i]D1 | [15:0] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------| | 31 to 0 | C[i]D1[31:0] | All 0 | R/W | Source Address | | | | | | Specify a source address. This register is used when source access involves memory reference. It is not used in the STIF. | | | | | | When copying a key or initial vector from the source, set 0000 in the lower four bits (16-byte boundary). | | | | | | When splitting continuous data into several descriptors for execution, specify the same source address in all the descriptors. | # 14.2.8 Channel [i] Processing Descriptor 2 Register (C[i]D2) [Destination Address] (i = 0, 1) Do not write any value to this register when C[i]C\_E is set to 1. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | C[i]D2 | [31:16] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | C[i]D2 | [15:0] | | | | | | | | | Initial Value: 0 | 0<br>R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------| | 31 to 0 | C[i]D2[31:0] | All 0 | R/W | Transfer Data Destination Address | | | | | | Specify a destination address to which to write back the transfer data. | | | | | | When splitting continuous data into several descriptors for execution, specify the same source address in all the descriptors. | ## 14.2.9 Channel [i] Processing Descriptor 3 Register (C[i]D3) [Data Length] (i = 0, 1) | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | _ | - | C[i]DWE | C[i]DIE | | _ | _ | | | _ | _ | _ | _ | - | _ | _ | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | C[i]D3 | [15:0] | | | | | | | | | Initial Value: 0 | 0<br>R/W 0<br>B/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31, 30 | _ | All 0 | R/W | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 29 | C[i]DWE | 0 | R/W | "1 Descriptor Processing End" Interrupt Release Wait Enable | | | | | | If this bit is 1 and the "1 descriptor processing" interrupt is requested, the A-DMAC waits for the interrupt release before it moves to next descriptor processing. | | | | | | 0: Does not observe the "1 descriptor processing end" interrupt. | | | | | | <ol> <li>Enables "1 descriptor processing end" interrupt<br/>release wait.</li> </ol> | | 28 | C[i]DIE | 0 | R/W | "1 Descriptor Processing End" Interrupt Request Enable | | | | | | Specifies whether to enable or disable the "1 descriptor processing end" interrupt when processing of this descriptor ends. Processing does not end even if the "1 descriptor processing end" interrupt request is enabled. | | | | | | 0: Disables the "1 descriptor processing end" | | | | | | interrupt request. | | | | | | <ol> <li>Enables the "1 descriptor processing end"<br/>interrupt request.</li> </ol> | | 27 to 16 | _ | All 0 | R/W | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 0 | C[i]D3[15:0] | All 0 | R/W | Target Data Size (Byte Length) | | | | | | The target data size range that can be specified in these bits is as follows: | | | | | | 0 < C[I]D3[15:0] <= 2^16-96 | | | | | | Basically, set a multiple of the length of block to be processed. For checksum, set a multiple of 2 bytes. | | | | | | When using continuous data over several descriptors, set the total of sizes specified in each descriptor in multiples of the block length. | | | | | | Also set the total size not to exceed 2^32. | # 14.2.10 Channel [i] Processing Descriptor 4 Register (C[i]D4) [Checksum Value Write Address] (i=0,1) | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | C[i]D4 | [31:16] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | С | [i]D4[15: | 1] | | | | | | | - | | Initial Value: 0<br>R/W: R/W | 0<br>R/W 0<br>R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|-------------------------------------------------------------------| | 31 to 1 | C[i]D4[31:1] | All 0 | R/W | Write address of the checksum calculation result. | | 0 | _ | 0 | R | The lower four bits should be 0. Set a two-byte boundary address. | ### **14.2.11** FEC DMAC Processing Control Register (FECC) A suspension direction is evaluated after descriptor processing in progress is completed (descriptor write-back). If FECC\_E is 1 when the suspension direction is evaluated, the FEC DMAC enters the WAIT cycle. If the FEC DMAC is restarted because 1 was written to FECC\_E during the WAIT cycle, the FEC DMAC moves to next descriptor read unless the descriptor written back just before is the last descriptor. If the descriptor is the last descriptor, the FEC DMAC ends processing and enters the IDLE state. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|--------------|----|----|----|--------------|----|----|----|--------------|----|----|----|--------------| | | _ | _ | _ | FECC_<br>R | _ | _ | _ | FECC_<br>DWF | _ | _ | _ | FECC_<br>DWE | _ | _ | _ | FECC_<br>DIE | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W | R | R | R | R | R | R | R | R/W | R | R | R | R/W | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | - | _ | FECC_<br>LIE | _ | _ | | FECC_<br>NIE | _ | _ | _ | FECC_<br>EIE | _ | _ | _ | FECC_<br>E | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W | R | R | R | R/W | R | R | R | R/W | R | R | R | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 29 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 28 | FECC_R | 0 | R/W | Reset | | | | | | Writing 1 to this bit during stop causes the FEC processing sequence to be reset. This bit is automatically and immediately set to 0. Setting both this bit and the FECC_E bit to 1 causes FEC processing to be newly started except when the following bits are set to 1: | | | | | | FECC_DWE, FECC_DIE, FECC_LIE, FECC_NIE, FECC_EIE, FECC_E, FECDSA, and FECDCA | | 27 to 25 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|--------------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 24 | FECC_DW | 0 | R | WAIT State Flag after Descriptor Processing End | | | F | | | 0: Non-WAIT state | | | | | | 1: WAIT state | | | | | | There are two methods for understanding the processing state of the FEC DMAC descriptor. In one, when the FEC DMAC is executed, FEC_DWE is set to 1 and then FECC_DIE is set to 1 to accept the "1 descriptor processing end" interrupt request. In the other, the processing state is observed till this bit is set to 1. | | 23 to 21 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 20 | FECC_DW<br>E | 0 | R/W | "1 Descriptor Processing End" Interrupt Request Release Wait Enable | | | E | | | When this bit is 1, the FEC DMAC ends processing of this descriptor and enters the WAIT state unless FECC_DIE is 0 after write-back. If the "1 descriptor processing end" interrupt is requested, the FEC DMAC waits for release of the interrupt before it moves to processing of the next descriptor. If this descriptor is the last descriptor when the interrupt is released, the FEC DMAC ends processing and enters the IDLE state. If this descriptor is not the last descriptor, the FEC DMAC reads the next descriptor. | | | | | | 0: The FEC DMAC does not enter the WAIT state when the "1 descriptor processing end" interrupt is requested. | | | | | | 1: The FEC DMAC enters the WAIT state when the "1 descriptor processing end" interrupt is requested. | | 19 to 17 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 16 | FECC_DIE | 0 | R/W | "1 Descriptor Processing End" Interrupt Request Enable | | | | | | Specifies whether to enable or disable the "1 descriptor processing end" interrupt request when processing of this descriptor ends. Processing does not end even if this interrupt is requested. This bit functions as the FECI_DI mask. | | | | | | 0: Disables the "1 descriptor processing end" interrupt request. | | | | | | 1: Enables the "1 descriptor processing end" interrupt request. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be $0$ . | | 12 | FECC_LIE | 0 | R/W | "Last Descriptor Processing End" Notification Interrupt Request<br>Enable | | | | | | Specifies whether to enable or disable the "last descriptor processing end" interrupt request when processing of the last descriptor ends (FECI_LI mask). | | | | | | Disables the "last descriptor processing end" interrupt request. | | | | | | Enables the "last descriptor processing end" interrupt request. | | 11 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be $0$ . | | 8 | FECC_NIE | 0 | R/W | "Invalid Descriptor" Notification Interrupt Request Enable | | | | | | Specifies whether to enable or disable the "invalid descriptor" notification interrupt request when the invalid descriptor is fetched (FECI_NI mask). | | | | | | 0: Disables the "invalid descriptor" notification interrupt request. | | | | | | 1: Enables the "invalid descriptor" notification interrupt request. | | 7 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be $0$ . | | 4 | FECC_EIE | 0 | R/W | "Processing End" Interrupt Request Enable | | | | | | Specifies whether to enable or disable the "processing end" interrupt request when processing ends (FECI_EI mask). | | | | | | 0: Disables the "processing end" interrupt request. | | | | | | 1: Enables the "processing end" interrupt request. | | 3 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | FECC_E | 0 | R/W | Execution Request | | | | | | Setting this bit to 1 causes FEC processing to be started. Setting this bit to 0 during FEC processing causes FEC processing to be suspended. After FEC processing ends, this bit is automatically set to 0. There are two methods for understanding the FEC DMAC operating state. In one, when the FEC DMAC is executed, FECC_EIE is set to 1 to accept the "operation end" interrupt request. In the other, the operating state is observed till the key of this bit is set to 0. | | | | | | 0: FEC processing is halted. | | | | | | 1: FEC processing is in progress. | #### FEC DMAC Processing Interrupt Request Register (FECI) ad\_irqfec\_n is asserted as negation of logical OR of all bits in this register. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|-------------|----|----|----|-------------|----|----|----|-------------|----|----|----|-------------| | | _ | _ | _ | _ | | _ | _ | _ | ı | _ | _ | _ | ı | ı | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | FECI_<br>DI | _ | _ | _ | FECI_<br>LI | | _ | _ | FECI_<br>NI | _ | | _ | FECI_<br>EI | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W | R | R | R | R/W | R | R | R | R/W | R | R | R | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | FECI_DI | 0 | R/W | "1 Descriptor Processing End" Interrupt Notification Request | | | | | | This interrupt notifies you that the FEC DMAC ended 1 descriptor processing and wrote back the descriptor. | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. | | | | | | This interrupt is masked by the FECC_DIE bit of the descriptor. | | | | | | 0: The "1 descriptor processing end" interrupt is not requested. | | | | | | The "1 descriptor processing end" interrupt is requested. | | 11 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 | FECI_LI | 0 | R/W | "Last Descriptor (descriptor where FECD00_F2 is 1)<br>Processing End" Interrupt Notification Request | | | | | | This interrupt notifies you that the FEC DMAC wrote back the last descriptor and ended last descriptor processing. The FEC DMAC enters the IDLE state after it ended last descriptor processing. | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. If this bit is set, the FEC DMAC is in the initial state because descriptors ran dry. In this case, replenish new descriptors and then restart the FEC DMAC. | | | | | | This interrupt is masked by the FECC_LIE bit of the FECC. | | | | | | 0: The "last descriptor processing end" interrupt is | | | | | | not requested. | | | | | | The "last descriptor processing end" interrupt is requested. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | FECI_NI | 0 | R/W | "Invalid Descriptor (descriptor where FECD00_F0 is 0) Interrupt | | | | | | Interrupt request for read end notification. When this interrupt request is made, the FEC DMAC ends processing and enters the IDLE state. | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. This interrupt is masked by the FECC_NIE bit of the FECC. If this bit is set, the FEC DMAC is in the initial state because descriptors ran dry. In this case, replenish new descriptors and then restart the FEC DMAC. | | | | | | 0: The "invalid descriptor processing end" interrupt is not requested. | | | | | | The "invalid descriptor processing end" interrupt is requested. | | 3 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | FECI_EI | 0 | R/W | "Processing End" Interrupt Request | | | | | | This interrupt notifies you that processing ended due to the FECI_LI or FECI_NI interrupt source and the FEC DMAC is now in the IDLE state. | | | | | | This bit is cleared to 0 by writing 1 to it. When 0 is written to this bit, the current state is retained. This interrupt is masked by the FECC_EIE bit of the FECC. | | | | | | If this bit is set, the FEC DMAC is in the initial state because descriptors ran dry. In this case, replenish new descriptors and then restart the FEC DMAC. | | | | | | 0: The "processing end" interrupt is not requested. | | | | | | 1: The "processing end" interrupt is requested. | ## 14.2.13 FEC DMAC Processing Descriptor Start Address Register (FECDSA) | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | FECDS | A[31:16] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | FECDS | A[15:4] | | | | | | | FECD | SA[3:0] | | | Initial Value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|--------------------------------------------------------------------------------| | 31 to 4 | FECDSA[31:4] | All 0 | R/W | Descriptor Ring Start Address | | 3 to 0 | FECDSA[3:0] | All 0 | R | Specify a descriptor ring start address. Set a 16-byte boundary address value. | ## 14.2.14 FEC DMAC Processing Descriptor Current Address Register (FECDCA) | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------|----------------|-------------------------|--------------------------------------|-------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------| | | | | | | | FECDC | A[31:16] | | | | | | | | | 0<br>R/W | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FECDO | A[15:4] | | | | | | | FECD | CA[3:0] | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0<br>B | | | 0<br>R/W<br>14 | 0 0<br>R/W R/W<br>14 13 | 0 0 0 0 R/W R/W R/W 14 13 12 0 0 0 0 | 0 0 0 0 0 R/W R/W R/W R/W 14 13 12 11 0 0 0 0 0 | 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W 14 13 12 11 10 FECDO | 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W P/W P/W R/W R/W 14 13 12 11 10 9 FECDCA[15:4] 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Tecdo Tecd | Second S | Second S | FECDCA[31:16] | O | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 4 | FECDSA[31:4] | All 0 | R/W | Descriptor Current Address | | 3 to 0 | FECDSA[3:0] | All 0 | R | Specify the start address of descriptor processing. Set a 16-byte boundary address value. When descriptor processing is in progress, these bits indicate the address of descriptor currently being processed. After descriptor write-back, these bits indicate the address of the next descriptor. When the FEC DMAC enters the IDLE state after it has processed the descriptor where the last flag is set, this register indicates the address of the next descriptor of the descriptor where the last flag is set. | ## 14.2.15 FEC DMAC Processing Descriptor 0 Register (FECD00) [Control] | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-----------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------------|---------------|---------------|---------------| | | | | | | | | F | ECD00 | _SZ[15:0 | ] | | | | | | | | Inital Value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | FECD00 | _DO[3:0] | ] | | FECD00 | _SO[3:0] | | | FECD00 | _SN[3:0] | | FECD00_<br>DRE | FECD00_<br>F2 | FECD00_<br>F1 | FECD00_<br>F0 | | Inital Value: | 0 | 0<br>B/W | 0 | 0 | 0 | 0 | 0 | 0 | 0<br>P/W | 0 | 0 | 0<br>B/M | 0<br>P/W | 0<br>P/W | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------------|------------------|-----|---------------------------------------------------------------------------------------------------------------------| | 31 to 16 | FECD00_SZ[15:0] | All 0 | R/W | Data Size (Byte Length) | | | | | | Specify the byte size of data to be processed. Set a value from 0 to 65504. Do not set a value from 65505 to 65536. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 12 | FECD00_DO[3:0] | All 0 | R/W | These bits function when the destination is read or written. | | | | | | FECD00_DO3: | | | | | | Data swap in two-byte units (longword swap in word units) | | | | | | 0: As-is<br>1: Swap | | | | | | FECD00_DO2: | | | | | | Data swap in one-byte units (word swap in byte units) | | | | | | 0: As-is<br>1: Swap | | | | | | FECD00_DO1: | | | | | | Inversion of bit 1 at address when one or two bytes are accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | FECD00_DO0: | | | | | | Inversion of bit 0 at address when one byte is accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | FECD00_DO1 and FECD00_DO0 function for endian adjustment. Note that if an endian different from the endian of this LSI is used, up to three different addresses are accessed from the address where the start and end addresses are specified when an area is allocated. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 to 8 | FECD00_SO[3:0] | All 0 | R/W | These bits function when the source is read. | | | | | | FECD00_SO3: | | | | | | Data swap in two-byte units (longword swap in word units) | | | | | | 0: As-is<br>1: Swap | | | | | | FECD00_SO2: | | | | | | Data swap in one-byte units (word swap in byte units) | | | | | | 0: As-is<br>1: Swap | | | | | | FECD00_SO1: | | | | | | Inversion of bit 1 at address when one or two bytes are accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | FECD00_SO0: | | | | | | Inversion of bit 0 at address when one byte is accessed | | | | | | 0: As-is<br>1: Inversion | | | | | | FECD00_SO1 and FECD00_SO0 function for endian adjustment. Note that if an endian different from the endian of this LSI is used, up to three different addresses are accessed from the address where the start and end addresses are specified when an area is allocated. | | 7 to 4 | FECD00_SN[3:0] | All 0 | R/W | Number of Source Addresses | | | | | | Specify the number of source addresses subject to FEC operation. | | | | | | 0000: The number of source addresses is 1. | | | | | | 0001: The number of source addresses is 2. | | | | | | Others: Reserved (setting prohibited) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | FECD00_DRE | 0 | R/W | Destination Read Enable | | | | | | 0: Does not read the destination. | | | | | | Reads the destination and updates the read values. | | 2 | FECD00_F2 | 0 | R/W | Descriptor Execution Flag 2 | | | | | | When 1, this bit explicitly indicates that this descriptor is the last descriptor that should operate. (Another method for explicitly indicating that this descriptor is the last descriptor is to place an invalid descriptor immediately after this descriptor.) | | | | | | This descriptor is not the last descriptor that should operate. | | | | | | 1: This descriptor is the last descriptor that should | | | | | | operate. | | 1 | FECD00_F1 | 0 | R/W | Descriptor Execution Flag 1 | | | | | | When this bit is 1, the FEC DMAC regards this descriptor as the last descriptor in the descriptor ring area and returns to the beginning (descriptor start address) of the descriptor ring area when processing of this descriptor ends. | | | | | | 0: This descriptor is not regarded as the last | | | | | | descriptor in the descriptor ring area. | | | | | | <ol> <li>This descriptor is regarded as the last descriptor<br/>in the descriptor ring area.</li> </ol> | | 0 | FECD00_F0 | 0 | R/W | Descriptor Execution Flag 0 | | | | | | When this bit is 0, processing of this descriptor ends because this descriptor is invalid. If the descriptor where FECD00_F0 is 0 is processed, the FEC DMAC suspends FEC processing on the assumption that FECC_E is 0. | | | | | | When this bit is 1, this descriptor is valid. If this descriptor is valid, the FEC DMAC sets this bit to 0 and writes back to the original address when processing of this descriptor ends. | | | | | | 0: This descriptor is invalid. | | | | | | 1: This descriptor is valid. | # 14.2.16 FEC DMAC Processing Descriptor 1 Register (FECD01D0A) [Destination Address] Do not write any value to this register when FECC\_E is set to 1. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | F | ECD01D | 0A[31:16 | 6] | | | | | | | | Initial Value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | F | ECD01 | D0A[15:0 | ] | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------------|------------------|-----|-----------------------------------------------------------| | 31 to 0 | FECD01D0A[31:0] | All 0 | R/W | Destination Address | | | | | | Specify a processing data write-back destination address. | ## 14.2.17 FEC DMAC Processing Descriptor 2 Register (FECD02S0A) [Source 0 Address] | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | F | ECD02S | 0A[31:16 | 6] | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | F | ECD028 | S0A[15:0 | ] | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------------|------------------|-----|---------------------------------------------| | 31 to 0 | FECD02S0A[31:0] | All 0 | R/W | Specify the start address of source 0 data. | # 14.2.18 FEC DMAC Processing Descriptor 3 Register (FECD03S1A) [Source 1 Address] | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | FECD03S1A[31:16] | | | | | | | | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | F | ECD03 | S1A[15:0 | ] | | | | | | | | Initial Value: 0 | 0<br>R/W 0<br>B/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------------|------------------|-----|---------------------------------------------| | 31 to 0 | FECD03S1A[31:0] | All 0 | R/W | Specify the start address of source 1 data. | ## 14.3 Functions Table 14.2 lists A-DMAC security/network functions. Table 14.2 A-DMAC Security/Network Functions | Classification | Item | Description | Conforming/<br>Supported Standard | |------------------|----------|-----------------------------------------------------------|-----------------------------------| | Error detection | Checksum | 1's complement sum operation | RFC1071 support | | Error correction | FEC | FEC XOR operation | RFC2733 | | | | <ul> <li>Support of any number of FEC matrixes</li> </ul> | Pro-MPEG support | #### 14.3.1 DMAC Channel Function The A-DMAC has two DMAC channels for checksum processing. #### 14.3.2 Checksum Checksum is a data error detection scheme. Checksum splits the entered data in 16-bit units and calculates their 1's complement sum to detect an error. For example, TCP checksum used to detect packet errors on the receiving side splits information called an IP pseudo header, TCP header, and TCP payload data in 16-bit units and calculates their 1's complement sum. If the obtained 1's complement sum is H'FFFF or H'0000, it indicates that no packet error occurred. If the 1's complement sum is not H'FFFF and H'0000, it indicates that a packet error occurred. The A-DMAC has a function to calculate the 1's complement sum of data obtained via DMA transfer. #### 14.3.3 FEC Channel The A-DMAC has one channel for FEC operation. This channel can perform XOR operation for the data obtained via DMA transfer and write back to memory because it is of a descriptor structure that can cope with FEC operation of any number of rows. #### 14.3.4 **FEC Operation** FEC is an error correction method. This method enables the receiving side to repair the lost packet without requesting packet retransmission. When repairing the lost packet by using FEC, the transmitting side uses the original packet group to generate a redundant packet (FEC packet). When transmitting 100 packets, for example, the transmitting side generates a 10 x 10 packet matrix, XORs the ten original packets aligned to one row or column, and generates one FEC packet per row (column). In this example, 20 FEC packets are generated. The transmitting side transmits the original data packet group and FEC packets to the receiving side. To check whether the original packets are lost, the receiving side aligns the original packets and FEC packets to the matrix as in the transmitting side. If a lost original packet is found, the transmitting side can repair the packet by XORing the other packets in the row and column to which the lost packet belongs with the FEC packets. Like this, the transmitting side and receiving side need to share the number of rows and columns of matrix aligned to generate FEC packets before transmitting and receiving the packets. The A-DMAC has the XOR calculation function used for FEC operation and supports the following FEC specifications of RFC2733 and Pro-MPEG: - XOR calculation of any number of rows (columns) A variable-length descriptor supports the FEC structure of theoretically infinite length. - One-dimensional FEC Not only two-dimensional FEC but also one-dimensional FEC is supported because processing is performed per row (column). The CPU must perform the following operations: - FEC matrix alignment - Lost packet detection - Unification of the lengths of packets that constitute a row (column) (Packets less than the maximum packet length are padded with 0.) - Repair of a portion of timestamp and payload type from the result obtained from the A-DMAC #### 14.4 Channel Operation #### 14.4.1 Descriptor Format The A-DMAC can automatically perform DMA transfer between memory and the STIF without the CPU based on the descriptor containing information such as a buffer pointer and its data size. The A-DMAC automatically performs operations such as reading data from memory and writing the decrypted data to the STIF according to the information stored in this descriptor. Figure 14.2 shows the descriptor format. The gray parts in the figure are ignored when descriptor processing is started and "0" is written back to these parts after descriptor processing ends. For details on each bit, see section 14.2.6, Channel [i] Processing Descriptor 0 Register (C[i]D0) [Control] (i = 0, 1), to section 14.2.10, Channel [i] Processing Descriptor 4 Register (C[i]D4) [Checksum Value Write Address] (i = 0, 1). | Bit<br>Address | 31 | 30 | 29 | 28 | 27-26 | 25-24 | 23-20 | 19 | 18 | 17-16 | 15-3 | 2-1 | 0 | |----------------|----|--------------------------------------------|----|----|-------|-------|-------|----|-------|-------|------|-----|---| | 0 | ( | CRDO[3:0] CHDO[3:0] SO[3:0] DA SA CSM[1:0] | | | | | | | | F[2:0 | )] | | | | +4 | | | | | | | | | D1 [ | 31:0] | | | | | +8 | | | | | | | | | D2 [ | 31:0] | | | | | +12 | | DWE DIE D3 [15:0] | | | | | | | | | | | | | +16 | | | | | | | | D. | 4 [31 | :1] | | | | | +20 | | | | | | | | | | | | | | | +24 | | | | | | | | | | | | | | | +28 | | | | | | | | | | | | | | Figure 14.2 Descriptor Format A descriptor is 16/32-byte variable length or 32-byte fixed length. Select variable length or fixed length from the variable-length descriptor control flag (C[i]C\_VLD) of the channel [i] processing control register (C[i]C). If C[i]C\_VLD is set to 1 to operate the descriptor as the variable-length descriptor, the remaining 16 bytes are read when the following conditions are met: • Checksum calculation result write-back is set (C[i]CSM0 = 1). #### 14.4.2 **Basic Channel Operation** When "1" is written to the C[i]C E bit of the channel [i] processing control register (C[i]C), channel [i] reads the descriptor from the C[i]DCA31 to C[i]DCA4 addresses. If a fixed length is set in C[i]C VLD, the first 32 bytes are continuously read. If variable length is set, the remaining 16 bytes are read according to the previously explained conditions. If the C[i]F0 flag of the first longword of a descriptor is 1, the descriptor is fetched to the appropriate register of channel [i] processing descriptor 0 (C[i]D0) to channel [i] processing descriptor 4 (C[i]D4). After 1-descriptor processing ends, channel [i] sets the C[i]F0 flag to 0 and writes back to the original area. Any number of descriptors can be allocated onto memory in the ring form. Processing is started from the descriptor allocated to the address indicated by the channel [i] processing descriptor current address register (C[i]DCA). If descriptors where the C[i]F0 flag of channel [i] processing descriptor 0 (C[i]D0) is set to 1 continue, channel [i] processes them one after another. If the C[i]F1 flag of channel [i] processing descriptor 0 (C[i]D0) is 1, channel [i] assumes that the end of descriptor ring was detected and processes the descriptor allocated to the address indicated by the channel [i] processing descriptor start address register (C[i]DSA). To end descriptor processing, allocate the invalid descriptor where the C[i]F0 flag of channel [i] processing descriptor 0 (C[i]D0) is set to 0. If processing for single continuous data is divided into several descriptors, the data size of each processing must be saved between several descriptor processing. Conversely, to handle different data, the data size of each processing must be initialized. For this reason, whether the descriptor currently being executed handles the end of continuous data must be indicated in the descriptor. Set this in the C[i]F2 flag. The A-DMAC does not allow you to set data size 0 in C[i]D315 to C[i]D30. #### 14.4.3 Checksum Figure 14.3 shows an example of descriptors that execute only checksum. In figure 14.3, (a) is an example of continuously allocating checksum descriptors each of which completes one processing and (b) is an example of splitting processing into several checksum descriptors and allocating the last checksum descriptor that completes processing. In the descriptor that performs checksum operation, set the data size in multiples of two bytes. However, if split descriptors are used, a value other than a multiple of two bytes can be set as the data size in each descriptor but the total number of data sizes specified in the split descriptors must be set so that it becomes a multiple of 2. (If processing is split into several descriptors and an odd size is specified in the non-last descriptor, the A-DMAC waits for the next descriptor without processing data of the last one byte.) Figure 14.3 Examples of Allocating Checksum Descriptors #### 14.5 FEC Channel Operation #### 14.5.1 Descriptor Format for FEC Channel Figure 14.4 shows the descriptor format for the FEC channel. The FEC channel can automatically perform DMA transfer with memory without the CPU according to descriptor information. Two source addresses can be specified in a descriptor but linking descriptors in the ring form provides FEC processing of any number of rows (columns). Only I-BUS can access FEC channel data due to its application, so information indicating the source and destination directions (I-BUS or STIF) is not included in the descriptor. The size of data subject to FEC operation must match the data size set in the FECD0\_SZ15 to FECD0\_SZ0 flag of FEC DMAC processing descriptor 0 (FECD00) in the first longword of the FEC descriptor. For this reason, when processing data less than the data size set in the FECD0\_SZ15 to FECD0\_SZ0 flag, you must pad the data with 0 and perform FEC processing. | Bit<br>Address | 31-16 | 15-12 | 11-8 | 7-4 | 3 | 2-0 | |----------------|----------|-----------|-------------|---------|-----|--------| | 0 | SZ[15:0] | DO[3:0] | SO[3:0] | SN[3:0] | DRE | F[2:0] | | +4 | | D01[ | 00A [31:0] | | | | | +8 | | D028 | SOA [31:0] | | | | | +12 | | D03S1A [3 | 31:0] or pa | dding | | | Figure 14.4 FEC DMAC Descriptor Format #### 14.5.2 **Basic FEC Channel Operation** When "1" is written to the FECC E bit of the FEC DMAC processing control register (FECC), the FEC channel starts descriptor read. If the FECD00 F0 flag in the first longword is "1", descriptors are fetched in turn to the appropriate register, starting from FECD00 in the first longword. After descriptor read is completed, the FEC channel reads data from memory space indicated by a source address and performs FEC operation (XOR calculation). After XOR calculation with all source addresses is completed, the FEC channel writes back the result to destination address space. After 1-descriptor processing ends, the FEC channel sets the FECD00\_F0 flag to "0" and writes back to the original area. To support the FEC matrix operation of any number of rows and columns, the FEC channel installed on the A-DMAC temporarily writes back the FEC operation result of source rows/columns that can be processed by one descriptor to the destination address. If the FEC matrix consists of two rows, the FEC matrix operation ends in one descriptor. If the FEC matrix consists of 3 rows/columns or more, the FEC channel splits the matrix into several descriptors and performs FEC matrix processing. If this processing must be split into several descriptors, use the FECD00\_DRE bit to control the FEC operation. Figure 14.5 shows an example of descriptor configuration where the FEC matrix operation is split into several descriptors for execution. In the first descriptor that starts the FEC operation, FECD00\_DRE is set to 0 because the operation result is not yet written. In the second and subsequent descriptors, the FEC operation is continued. In other words, to XOR the calculation result of the previous descriptor with the current descriptor source, FECD00\_DRE is set to 1. Piling up such descriptors till the number of rows or columns for the FEC matrix operation is met makes it possible to obtain the last XOR operation result of the target row (column). Any number of descriptors can be allocated onto memory in the ring form. Processing is started from the descriptor allocated to the address indicated by the FEC DMAC processing descriptor current address register (FECDCA). If descriptors where the FECD00 F0 flag of FEC DMAC processing descriptor 0 (FECD00) is set to 1 continue, the FEC channel processes them one after another. If the FECD00 F1 flag of FECD00 is 1, the FEC channel assumes that the end of descriptor ring was detected and processes the descriptor allocated to the address indicated by the FEC DMAC processing descriptor start address register (FECDSA). To end descriptor processing, allocate the invalid descriptor where the FECD00 F0 flag of FECD00 is set to "0" or allocate the last descriptor where the FECD00\_F2 flag of FECD00 is set to "1". Figure 14.5 Example of FEC Descriptor Configuration #### 14.6 **Usage Notes** #### 14.6.1 Data Transfer Size Set in Descriptor for A-DMAC Channel Operation The data transfer size to be set in a descriptor for A-DMAC channel operation is as explained in the description of the C[i]D3[15:0] bits in section 14.2.9, Channel [i] Processing Descriptor 3 Register (C[i]D3) [Data Length] (i = 0, 1). Note however that the following restrictions are applied when the relevant A-DMAC channel is operating together with an STIF in PS mode. When operating together with an STIF in PS mode, a descriptor for dummy data transfer must be prepared to satisfy the expression of (data transfer size specified by A-DMAC descriptor) = (setting of the SIZE[31:0] bits in STSIZER) + dummy data = multiple of 192 bytes. This means that the sum of the C[i]D3[15:0] bits for each descriptor should be a multiple of 192 bytes when data transfer is divided to be performed by multiple descriptors. Accordingly, in PS output mode, data including dummy data is transferred from the A-DMAC to the STIF, but the dummy data is deleted inside the STIF and only the data that should really be transferred will be output from the STIF to an external device. Similarly, in PS input mode, the STIF retrieves only the amount of data that should really be transferred from an external device. However, the A-DMAC transfers the data that should really be transferred followed by dummy data. Software should ignore the dummy data stored in memory. # Section 15 Stream Interface (STIF) This LSI has a 2-channel stream interface (STIF). #### 15.1 **Features** - Two-channel bidirectional interface - Supports TS packets (packet size: 188 bytes). - Supports TTS packets (packet size: 192 bytes). - Supports PS packets (packet size: specified by the size register). - 8-bit parallel transfer or 1-bit serial transfer is selectable. - Transfer direction is settable for each channel. - Polarity of each clock signal, request signal, synchronizing signal, and data enable signal is selectable. - A PCR clock recovery module (PCRRCV) incorporated Page 546 of 1278 Figure 15.1 shows a block diagram of the STIF. Figure 15.1 Block Diagram of STIF # 15.2 Input/Output Pins Table 15.1 shows the pin configuration of the STIF. **Table 15.1 Pin Configuration** | Name | I/O | Function | |---------------|--------|--------------------------------------------------------------------------------------------| | ST_CLKOUT | Output | Data clock output (common to channels) | | ST0_CLKIN | Input | Data clock input | | ST0_REQ | I/O | Request signal | | ST0_SYC | I/O | Synchronizing signal | | ST0_VLD | I/O | Data enable | | ST0_D[7:0] | I/O | Data (ST0_D[0] is used in serial mode) | | ST0_VCO_CLKIN | Input | The MPEG base clock is input from the external 27-MHz voltage controlled oscillator (VCO). | | ST0_PWM | Output | The 27-MHz VCO is controlled through the low-pass filter (LPF). | | ST1_CLKIN | Input | Data clock input | | ST1_REQ | I/O | Request signal | | ST1_SYC | I/O | Synchronizing signal | | ST1_VLD | I/O | Data enable | | ST1_D[7:0] | I/O | Data (ST1_D[0] is used in serial mode) | | ST1_VCO_CLKIN | Input | The MPEG base clock is input from the external 27-MHz VCO. | | ST1_PWM | Output | The 27-MHz VCO is controlled through the LPF. | ### 15.3 Register Descriptions The STIF has the following registers. For the address and status at each processing state of these registers, see section 28, List of Registers. - STIF mode select register (STMDR\_0) - STIF control register (STCTLR\_0) - STIF internal counter control register (STCNTCR\_0) - STIF internal counter set register (STCNTVR\_0) - STIF status register (STSTR\_0) - STIF interrupt enable register (STIER\_0) - STIF transfer size register (STSIZER\_0) - STIFPWM mode register (STPWMMR\_0) - STIFPWM control register\_0 (STPWMCR\_0) - STIFPWM register (STPWMR\_0) - STIFPCR0 register (STPCR0R\_0) - STIFPCR1 register (STPCR1R\_0) - STIFSTC0 register (STSTC0R\_0) - STIFSTC1 register (STSTC1R\_0) - STIF lock control register (STLKCR\_0) - STIF debugging status register (STDBGR\_0) - STIF mode select register (STMDR\_1) - STIF control register (STCTLR\_1) - STIF internal counter control register (STCNTCR\_1 - STIF internal counter set register (STCNTVR\_1) - STIF status register (STSTR\_1) - STIF interrupt enable register (STIER\_1) - STIF transfer size register (STSIZER\_1) - STIFPWM mode register (STPWMMR\_1) - STIFPWM control register\_1 (STPWMCR\_1) - STIFPWM register (STPWMR\_1) - STIFPCR0 register (STPCR0R\_1) - STIFPCR1 register (STPCR1R\_1) - STIFSTC0 register (STSTC0R\_1) - STIFSTC1 register (STSTC1R\_1) - STIF lock control register (STLKCR\_1) - STIF debugging status register (STDBGR\_1) #### 15.3.1 STIF Mode Select Register (STMDR) STMDR is a 32-bit register that selects operating mode, clock source, etc. of the on-chip STIF module. STMDR is initialized to H'00000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------| | 31 to 15 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 14 | LSBSEL | 0 | R/W | Selects MSB first or LSB first in serial mode. | | | | | | 0: MSB-first data input/output | | | | | | 1: LSB-first data input/output | | 13 | EDGSEL | 0 | R/W | Selects input/output timing of STn_REQ, STn_SYC, STn_VLD, and STn_D[7:0]. | | | | | | Output and sampled at the rising edge of the<br>synchronizing clock | | | | | | Output and sampled at the falling edge of the<br>synchronizing clock | | | | | | The synchronizing clock is defined by the CLKSEL and CKFRSEL[3:0] bits in this register. | | 12 | CLKSEL | 0 | R/W | Selects synchronizing clock for stream transmit mode | | | | | | <ol><li>STn_SYC, STn_VLD, and STn_D[7:0] are output in<br/>synchronization with ST_CLKOUT.</li></ol> | | | | | | STn_REQ is sampled in synchronization with ST_CLKOUT | | | | | | <ol> <li>STn_SYC, STn_VLD, and STn_D[7:0] are output in<br/>synchronization with STn_CLKIN.</li> </ol> | | | | | | STn_REQ is sampled in synchronization with STn_CLKIN. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|-----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | CKFRSEL3 | 0 | R/W | These bits select the clock source of ST_CLKOUT | | 10 | CKFRSEL2 | 0 | R/W | (available for STMDR_0 only). | | 9 | CKFRSEL1 | 0 | R/W | 0000: Вф | | 8 | CKFRSEL0 | 0 | R/W | 0001: Iφ/2 | | | | | | 0010: Iφ/3 | | | | | | 0011: Ιφ/4 | | | | | | 0100: Ιφ/6 | | | | | | 0101: Ιφ/8 | | | | | | 0110: Ιφ/12 | | | | | | 0111: Reserved (setting prohibited) | | | | | | 1000: Reserved (setting prohibited) | | | | | | 1001: Reserved (setting prohibited) | | | | | | 1010: Reserved (setting prohibited) | | | | | | 1011: Reserved (setting prohibited) | | | | | | 1100: Reserved (setting prohibited) | | | | | | 1101: Reserved (setting prohibited) | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Output is fixed to low. | | | | | | Notes: 1. For serial mode, select a clock source of B $\phi$ or less. For parallel mode, select a clock source of B $\phi$ /2 or less. | | | | | | For example, when $I\phi$ : $B\phi = 3:1$ or $6:2$ is set in the CPG, $I\phi/2$ is not selectable for serial mode. For parallel mode, $I\phi/2$ and $I\phi/4$ are not selectable. | | | | | | 2. Select a clock source that satisfies the following:<br>$STn\_CLKIN \le B\phi \times 80\%$ (serial mode) | | | | | | $STn\_CLKIN \le (B\phi/2) \times 80\%$ (parallel mode) | | 7 | REQACTSEL | . 0 | R/W | Selects the active polarity of STn_REQ. | | | | | | 0: Active-high | | | | | | 1: Active-low | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|-----------|------------------|-----|-------------------------------------------------| | 6 | VLDACTSEL | | R/W | Selects the active polarity of STn_VLD. | | | | | | 0: Active-high | | | | | | 1: Active-low | | 5 | SYCACTSEL | 0 | R/W | Selects the active polarity of STn_SYC. | | | | | | 0: Active-high | | | | | | 1: Active-low | | 4 | IOSEL | 0 | R/W | Selects stream input or output direction. | | | | | | 0: Input (from an external device to this LSI) | | | | | | 1: Output (from this LSI to an external device) | | 3 | IFMDSEL3 | 0 | R/W | These bits select operating mode. | | 2 | IFMDSEL2 | 0 | R/W | 0000: TS serial mode 1 | | 1 | IFMDSEL1 | 0 | R/W | 0001: TS parallel mode 1 | | 0 | IFMDSEL0 | 0 | R/W | 0010: TS serial mode 2 | | | | | | 0011: TS parallel mode 2 | | | | | | 0100: TS serial mode 3 | | | | | | 0101: TS parallel mode 3 | | | | | | 0110: Reserved (setting prohibited) | | | | | | 0111: Reserved (setting prohibited) | | | | | | 1000: TTS serial mode | | | | | | 1001: TTS parallel mode | | | | | | 1010: Reserved (setting prohibited) | | | | | | 1011: Reserved (setting prohibited) | | | | | | 1100: PS serial mode | | | | | | 1101: PS parallel mode | | | | | | 1110: Reserved (setting prohibited) | | | | | | 1111: Reserved (setting prohibited) | [Legend] n = 0, 1 # 15.3.2 STIF Control Register (STCTLR) STCTLR is a 32-bit register that sets the recovery processing switching threshold value and enables/disables DMA transfer requests. STCTLR is initialized to H'00000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------------|----------------------------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 12 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11<br>10<br>9 | RCVTM2<br>RCVTM1<br>RCVTM0 | 0 0 0 | R/W<br>R/W<br>R/W | • | | | | | | Recovery function (3) | | | | | | When the internal counter value is under the timestamp value but the difference is larger than the set threshold value, the packet is discarded and the recovery processing restarts with the next packet. (The next packet is output immediately, and the packet's timestamp is reloaded to the internal counter for timestamp at the same time.) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | RCV | 0 | R/W | Enables the recovery functions when outputting packets in TS mode 1 or TS mode 2. | | | | | | 0: Recovery functions disabled | | | | | | 1: Recovery functions enabled | | 7 | TRICK | 0 | R/W | Enables the function that transfers stream independently of timestamp when outputting packets in TS mode 1 or TS mode 2. | | | | | | 0: Transfer function disabled | | | | | | 1: Transfer function enabled | | 6 to 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 | REQEN | 0 | R/W | Enables or disables DMA transfer requests to the A-DMAC. | | | | | | 0: Disabled | | | | | | 1: Enabled | | 1 | EN | 0 | R/W | Enables or disables stream input/output. | | | | | | 0: Disabled | | | | | | 1: Enabled | | 0 | SRST | 0 | R/W | Setting this bit to 1 causes the internal state of this LSI to be initialized with register settings retained. | | | | | | When a TS packet is received for the first time after the initialization, the timestamp value of the TS packet is reloaded to the internal counter for timestamp. | | | | | | While 1 is read from this bit, the initialization is in progress. | | | | | | This bit is automatically cleared to 0. | | | | | | Whenever the STMDR setting is modified, be sure to set SRST to 1 to initialize this LSI and then set EN and REQEN to 1 to enable stream transfer. | # 15.3.3 STIF Internal Counter Control Register (STCNTCR) STCNTCR is a 32-bit register to control the internal counter for timestamp. STCNTCR is initialized to H'00000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------| | 31 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 3 | CRD | 0 | R/W | Setting this bit to 1 causes the internal counter value for timestamp to be read to STCNTVR. | | | | | | This bit is automatically cleared to 0. | | 2 | CSTP | 0 | R/W | Stops the internal counter for timestamp. | | | | | | 0: Count operation is continued. | | | | | | 1: Counter is stopped with its value retained. | | 1 | CSET | 0 | R/W | Setting this bit to 1 causes the STCNTVR value to be reloaded to the internal counter for timestamp. | | | | | | This bit is automatically cleared to 0. | | 0 | CRST | 0 | R/W | Setting this bit to 1 causes the internal counter for timestamp to be initialized to H'00000000. | | | | | | This bit is automatically cleared to 0. | ### 15.3.4 STIF Internal Counter Set Register (STCNTVR) STCNTVR is a 32-bit register that reads or reloads the value of the internal counter for timestamp in combination with the settings of the CRD and CSET bits in STCNTCR. STCNTVR is initialized to H'000000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------------|------------------|-----|--------------------------------------| | 31 to 0 | VLU31 to<br>VLU0 | All 0 | R/W | Internal counter value for timestamp | ### 15.3.5 STIF Status Register (STSTR) STSTR is a 32-bit register that indicates the status of the recovery functions, packet transmission/reception, and PCR clock recovery. STSTR is initialized to H'00000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | LKZF | 0 | R/W | Indicates whether the PLL error amount (internal STC - internal PCR) falls within threshold value range LKCYC when a PCR packet is received. | | | | | | 0: Within threshold value range (PLL error amount (internal STC - internal PCR) =< LKCYC) | | | | | | 1: Outside threshold value range (PLL error amount (internal STC - internal PCR) > LKCYC) | | | | | | This bit is cleared to 0 by writing 1. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | LKF | 0 | R/W | Indicates PLL lock status. | | | | | | 0: PLL unlocked | | | | | | In the case of ULCNT >= ULREF due to continued LKZF = 1 state (outside threshold value range) when a PCR packet is received with PLL locked (LKF = 1) | | | | | | 1: PLL locked | | | | | | In the case of LKCNT >= LKREF due to continued LKZF = 0 state (within threshold value range) when a PCR packet is received with PLL unlocked (LKF = 0) | | | | | | This bit is cleared to 0 by writing 1. | | 10 | DISF | 0 | R/W | Status flag bit that indicates the discontinuity_indicator (table 15.5) of received PCR_PID. This bit is set to 1 upon completion of transfer (internal PCR $\rightarrow$ STC $\rightarrow$ internal STC) | | | | | | This bit is cleared to 0 by writing 1. | | 9 | UNZF | 0 | R/W | This bit is set to 1 when data transfer from internal PCR to STC counter and data transfer from STC counter to internal STC are completed and the comparison of the upper data of received PCR_PID does not match (internal STC - internal PCR exceeded the acceptable comparison result range specified by PWMCYC; see figure 15.9). | | | | | | This bit is also set to 1 when PCR_PID (table 15.5) is received after "discont." | | | | | | Furthermore, if the PWM control variable with a bit width of the effective comparison bit count "n" specified by PWMCYC is -(2^n), this bit is set to 1 as invalid PWM control variable (ILGL = 1 hereinafter) in the same manner as above. | | | | | | This bit is cleared to 0 by writing 1. | | 8 | PCRF | 0 | R/W | This bit is set to 1 when data transfer from internal PCR to STC counter and data transfer from STC counter to internal STC are completed. | | | | | | These transfers take place when a packet whose PCR_PID was detected satisfies the conditions in table 15.4. | | | | | | This bit is cleared to 0 by writing 1. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TENDF | 0 | R/W | Indicates completion of output packet transfer for the transfer data size specified by STSIZER in PS mode. | | | | | | This bit is cleared to 0 by writing 1. | | 6 | RENDF | 0 | R/W | Indicates completion of input packet transfer for the transfer data size specified by STSIZER in PS mode. | | | | | | This bit is cleared to 0 by writing 1. | | 5 | RCVF3 | 0 | R/W | This bit is set to 1 when recovery function (3) is activated when outputting a packet in TS mode 1 or TS mode 2. | | | | | | This bit is cleared to 0 by writing 1. | | 4 | RCVF2 | 0 | R/W | This bit is set to 1 when recovery function (2) is activated when outputting a packet in TS mode 1 or TS mode 2. | | | | | | This bit is cleared to 0 by writing 1. | | 3 | RCVF1 | 0 | R/W | This bit is set to 1 when recovery function (1) is activated when outputting a packet in TS mode 1 or TS mode 2. | | | | | | This bit is cleared to 0 by writing 1. | | 2 | UPF | 0 | R/W | This bit is set to 1 when a packet shorter than 188 bytes is received in TS mode 1 or TS mode 2. Such packets are discarded. | | | | | | This bit is cleared to 0 by writing 1. | | 1 | OPF | 0 | R/W | When a packet of 189 bytes or longer is received in TS mode 1 or TS mode 2, this bit is set to 1 when reception of the 189th byte is completed. Packets exceeding 188 bytes are discarded. | | | | | | This bit is cleared to 0 by writing 1. | | 0 | ŌVF | 0 | R/W | This bit is set to 1 when data read by the A-DMAC is delayed and therefore the receive data which came later is discarded in TS mode 1 or TS mode 2. | | | | | | This bit is cleared to 0 by writing 1. | | | | | | | # 15.3.6 STIF Interrupt Enable Register (STIER) STIER is a 32-bit register to control various interrupt requests. STIER is initialized to H'00000000 by a power-on reset. | Bit Name | Initial<br>Value | R/W | Description | |----------|--------------------------|---------------|---------------------------------------------------------------------------| | _ | | R | Reserved | | | <i>.</i> <b>c</b> | | These bits are always read as 0. The write value should always be 0. | | LKZE | 0 | R/W | Enables or disables LKZF interrupt requests. | | | | | 0: LKZF interrupt requests are disabled. | | | | | 1: LKZF interrupt requests are enabled. | | LKE | 0 | R/W | Enables or disables LKF interrupt requests. | | | | | 0: LKF interrupt requests are disabled. | | | | | 1: LKF interrupt requests are enabled. | | DISE | 0 | R/W | Enables or disables DISF interrupt requests. | | | | | 0: DISF interrupt requests are disabled. | | | | | 1: DISF interrupt requests are enabled. | | UNZE | 0 | R/W | Enables or disables UNZF interrupt requests. | | | | | 0: UNZF interrupt requests are disabled. | | | | | 1: UNZF interrupt requests are enabled. | | PCRE | 0 | R/W | Enables or disables PCRF interrupt requests. | | | | | 0: PCRF interrupt requests are disabled. | | | | | 1: PCRF interrupt requests are enabled. | | TENDE | 0 | R/W | Enables or disables TENDF interrupt requests. | | | | | 0: TENDF interrupt requests are disabled. | | | | | 1: TENDF interrupt requests are enabled. | | RENDE | 0 | R/W | Enables or disables RENDF interrupt requests. | | | | | 0: RENDF interrupt requests are disabled. | | | | | 1: RENDF interrupt requests are enabled. | | RCVE3 | 0 | R/W | Enables or disables RCVF3 interrupt requests. | | | | | 0: RCVF3 interrupt requests are disabled. | | | | | 1: RCVF3 interrupt requests are enabled. | | | LKE DISE UNZE PCRE TENDE | Bit NameValue | Bit NameValueR/WLKZE0R/WLKE0R/WDISE0R/WUNZE0R/WFCRE0R/WTENDE0R/WRENDE0R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|----------|-----------------------------------------------| | 4 | RCVE2 | 0 | R/W | Enables or disables RCVF2 interrupt requests. | | 7 | TIOVEZ | O | 1 I/ V V | O: RCVF2 interrupt requests are disabled. | | | | | | | | | | | | 1: RCVF2 interrupt requests are enabled. | | 3 | RCVE1 | 0 | R/W | Enables or disables RCVF1 interrupt requests. | | | | | | 0: RCVF1 interrupt requests are disabled. | | | | | | 1: RCVF1 interrupt requests are enabled. | | 2 | UPE | 0 | R/W | Enables or disables UPF interrupt requests. | | | | | | 0: UPF interrupt requests are disabled. | | | | | | 1: UPF interrupt requests are enabled. | | 1 | OPE | 0 | R/W | Enables or disables OPF interrupt requests. | | | | | | 0: OPF interrupt requests are disabled. | | | | | | 1: OPF interrupt requests are enabled. | | 0 | ŌVE | 0 | R/W | Enables or disables OVF interrupt requests. | | | | | | 0: OVF interrupt requests are disabled. | | | | | | 1: OVF interrupt requests are enabled. | # 15.3.7 STIF Transfer Size Register (STSIZER) (n = 0,1) STSIZER is a 32-bit register that specifies a transfer byte count for PS mode. STSIZER is initialized to H'FFFFFFF by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------------|------------------|-----|---------------------------------| | 31 to 0 | SIZE31 to<br>SIZE0 | All 1 | R/W | Transfer byte count for PS mode | ## 15.3.8 STIFPWM Mode Register (STPWMMR) STPWMMR is a 32-bit register that selects PWM mode, sets PWM control cycle, reference bit shift amount, and reference clock, enables/disables PID filtering, and sets the PID of a PCR packet to be filtered. STPWMMR is initialized to H'000000000 by a power-on reset. | | | Initial | | | |----------|------------------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 29 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 28 to 16 | PID12 to<br>PID0 | All 0 | R/W | These bits set the PID (PCR_PID) of filtering target PCR packet. | | 15 | PIDEN | 0 | R/W | Enables or disables PCR packet filtering. | | | | | | 0: Filtering is disabled. | | | | | | 1: Filtering is enabled. | | 14 | PWMUEN | 0 | R/W | Selects whether to reflect the PWM control difference (internal STC - internal PCR) in the PWM control output according to the comparison of the residual upper bits (comparison target bits) in the comparison of bits 0 to 11. The comparison result of target bits is reflected in UNZF. This bit is valid only when PWMSEL is 0. | | | | | | <ol> <li>When the comparison results in a mismatch, PWM<br/>control variable is reflected in PWM control.</li> </ol> | | | | | | [Match: UNZF = 0] PWM control variable is reflected in PWM output control. | | | | | | [Mismatch: UNZF = 1] PWM control variable is reflected in PWM output control. | | | | | | <ol> <li>When the comparison results in a mismatch, PWM<br/>control variable is not reflected in PWM control.</li> </ol> | | | | | | [Match: UNZF = 0] PWM control variable is reflected in PWM output control. | | | | | | [Mismatch: UNZF = 1] PWM control variable is not reflected in PWM output control. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--| | 13 | PWMSEL | 0 | R/W | Selects difference (internal STC - PWMR value for use as the input | | | | | | | | | Also selects PCR arrival pulse or reflecting the selector 2 output in | • | | | | | | | | <ol> <li>PWM control mode is set for the<br/>- internal PCR) result control. F<br/>PWMWP are available.</li> </ol> | ` | | | | | | | | 1: PWM control mode is set for th | e PWMR control. | | | | | | | | Only PWMWP is available. | | | | | 12 | PWMSEL2 | 0 | R/W | /W Selects selector 1 (figure 15.9) or addition (selector 1 out<br>+ internal PWM) result for use as input to the internal PW | | | | | | | | | 0: Selector 1 output is set for input | it to the internal PWM. | | | | | | | | 1: Addition (selector 1 output + in for input to the internal PWM. | ternal PWM) result is set | | | | 11 | PWMCYC3 | 0 | R/W | These bits set a PWM control cyc | | | | | 10 | PWMCYC2 | 0 | R/W | PWM reference clock that is set by the PWMDIV bits. | | | | | 9 | PWMCYC1 | 0 | R/W | See table 15.2. | | | | | 8 | PWMCYC0 | 0 | R/W | This setting should be modified of 0. | nly when the PIDEN bit is | | | | 7 | PWMSFT3 | 0 | R/W | These bits set a reference bit pos | | | | | 6 | PWMSFT2 | 0 | R/W | the PWM control variable (internal STC - internal PCR). As shown in figure 15.9, the reference bit position of the PWM | | | | | 5 | PWMSFT1 | 0 | R/W | control variable varies with the PV | | | | | 4 | PWMSFT0 | 0 | R/W | This setting should be modified of 0. | nly when the PIDEN bit is | | | | | | | | Reference bit position | Reference bit position | | | | | | | | 0000: 0 | 1000: 8 | | | | | | | | 0001: 1 | 1001: 9 | | | | | | | | 0010: 2 | 1010: 10 | | | | | | | | 0011: 3 | 1011: 11 | | | | | | | | 0100: 4 | 1100: 12 | | | | | | | | 0101: 5 | 1101: 13 | | | | | | | | 0110: 6 | 1110: 14 | | | | | _ | | | 0111: 7 | 1111: 15 | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--| | 3 | PWMDIV3 | 0 | R/W | These bits set | the reference clock of the PWM control | | | 2 | PWMDIV2 | 0 | R/W | Set a division count between 1 and 1024. If a value outside the range is set, the operation of this LSI is not guaranteed. | | | | 1 | PWMDIV1 | 0 | R/W | | | | | 0 | PWMDIV0 | 0 | R/W | | | | | | | | | 0000: 1 | 1000: 256 | | | | | | | 0001: 2 | 1001: 512 | | | | | | | 0010: 4 | 1010: 1024 | | | | | | | 0011: 8 | 1011: 2048 (invalid) | | | | | | | 0100: 16 | 1100: 4096 (invalid) | | | | | | | 0101: 32 | 1101: 8192 (invalid) | | | | | | | 0110: 64 | 1110: 16384 (invalid) | | | | | | | 0111: 128 | 1111: 32768 (invalid) | | **Table 15.2 PWM Control Cycle** Bits 11 to 8 ### **Description** | PWMCYC3 to PWMCYC0 | PWM Cycle<br>(× PWM reference<br>clock) | Acceptable<br>Comparison Bit<br>Count n | Acceptable<br>Comparison (Internal<br>STC - Internal PCR)<br>Result Range *1 | PWM Control<br>Variable* <sup>2</sup><br>(ILGL = 1) | |--------------------|-----------------------------------------|-----------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------| | 0000 | 2 | 0 | _ | _ | | 0001 | 4 | 1 | -1 to +1 | -2 | | 0010 | 8 | 2 | −3 to +3 | -4 | | 0011 | 16 | 3 | -7 to +7 | -8 | | 0100 | 32 | 4 | -15 to +15 | -16 | | 0101 | 64 | 5 | -31 to +31 | -32 | | 0110 | 128 | 6 | -63 to +63 | -64 | | 0111 | 256 | 7 | -127 to +127 | -128 | | 1000 | 512 | 8 | -255 to +255 | -256 | | 1001 | 1024 | 9 | -511 to +511 | <b>-</b> 512 | | 1010 | 2048 | 10 | -1023 to +1023 | -1024 | | 1011 | 4096 | 11 | -2047 to +2047 | -2048 | | 1100 | 8192 | 12 | -4095 to +4095 | -4096 | | 1101 | 16384 | 13 | -8191 to +8191 | -8192 | | 1110 | 32768 | 14 | -16383 to +16383 | -16384 | | 1111 | 65536 | 15 | -32767 to +32767 | -32768 | Notes: 1. When PWMSEL = 0, if the comparison (internal STC - internal PCR) result exceeds the acceptable comparison result range, the UNZF bit is set to 1. 2. If the PWM control variable is -(2^n), it is treated as an invalid PWM control variable (ILGL = 1) and the UNZF bit is set to 1. The PWM control variable is selected by the PWMSEL bit. # 15.3.9 STIFPWM Control Register (STPWMCR) STPWMCR is a 32-bit register that specifies the generation of write pulses of the internal PCR and STC registers. STPWMCR is initialized to H'00000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 | STCXP | 0 | R/W | Setting this bit to 1 causes the STC value to be transferred to STSTC0R and STSTC1R. | | | | | | This bit is automatically cleared to 0. | | 7 | PWMBRS | 0 | R/W | Setting this bit to 1 causes the internal PWM register value to be transferred to STPWM (PWMB). | | | | | | This bit is automatically cleared to 0. | | 6 | PWMBWP | 0 | R/W | Setting this bit to 1 causes the STPWM (PWMB) value to be reflected in PWM. | | | | | | PWM control is immediately performed with the value that is set in PWM. Loading with this bit can preferentially be performed independently of the PWMSEL and PWMUEN settings, except when the PWM control variable is an invalid value as described in the UNZF bit field of STSTR. If this bit is set to 1 together with the PWMWP bit, PWMBWP takes precedence. | | | | | | This bit is automatically cleared to 0. | | 5 | PWMRS | 0 | R/W | Setting this bit to 1 causes the difference (internal STC - internal PCR) result to be transferred to STPWM (PWM). | | | | | | The difference result is masked by the PWMCYC bits (validity comparison bits) of STPWMMR as shown in figure 15.9. | | | | | | This bit is automatically cleared to 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | PWMWP | 0 | R/W | Setting this bit to 1 causes the selector 2 output to be reflected in PWM. | | | | | | Loading with this bit can be performed preferentially without depending on the PWMSEL and PWMUEN settings, except when the PWM control variable is an invalid value as described in the UNZF bit field of STSTR. If this bit is set to 1 together with the PWMWP bit, PWMBWP takes precedence. | | | | | | This bit is automatically cleared to 0. | | 3 | STCRS | 0 | R/W | Setting this bit to 1 causes the STC value to be transferred to STSTC0R and STSTC1R. | | | | | | This bit is automatically cleared to 0. | | 2 | STCWP | 0 | R/W | Setting this bit to 1 causes the STSTC0R and STSTC1R values to be transferred to STC. | | | | | | If the transfer conflicts with the data write after PCR is received, the transfer using the write pulse of this register takes precedence. | | | | | | This bit is automatically cleared to 0. | | 1 | PCRRS | 0 | R/W | Setting this bit to 1 causes the PCR value to be transferred to STPCR0R and STPCR1R. | | | | | | This bit is automatically cleared to 0. | | 0 | PCRWP | 0 | R/W | Setting this bit to 1 causes the STPCR0R and STPCR1R values to be transferred to PCR. | | | | | | If the transfer conflicts with the data write after PCR is received, the transfer using the write pulse of this register takes precedence. | | | | | | This bit is automatically cleared to 0. | # 15.3.10 STIFPWM Register (STPWMR) STPWMR is a 32-bit register that directly sets PWM control variable. STPWMR is initialized to H'00000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|--------------------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 16 | PWMB15 to<br>PWMB0 | All 0 | R/W | These bits set a PWM control value equivalent to the comparison (internal STC - internal PCR) result. | | | | | | To reflect the PWMB value in the PWMOUT output pin as a PWM control variable, set the PWMBWP bit in STPWMCR to 1. Set a PWMB value of two's complement (bit n = sign bit) out of the acceptable comparison bit count n specified by the PWMCYC bits. The acceptable setting range is -(2^n - 1) to +(2^n - 1) where n = acceptable comparison bit count specified by the PWMCYC bits. Do not set the value -(2^n). If -(2^n) is set and is attempted to reflect in the PWM control by setting PWMBWP to 1, it is treated as an invalid PWM control variable setting and the UNZF bit is set to 1. The setting is not reflected in the PWM control output. Note that reflection in the PWM control output is not performed until PWMB is set to a value other than -(2^n). | | 15 to 0 | PWM15 to<br>PWM0 | All 0 | R/W | These bits set a PWM control value equivalent to the comparison (internal STC - internal PCR) result. | | | | | | To reflect the PWM value in the PWMOUT output pin as a PWM control variable, set the PWMWP bit in STPWMCR to 1 with PWMSEL = 1. Set a PWM value of two's complement (bit $n = \text{sign bit}$ ) out of the acceptable comparison bit count n specified by the PWMCYC bits. The acceptable setting range is -(2^n - 1) to +(2^n - 1) where $n = acceptable comparison bit count specified by the PWMCYC bits. Set a value so that the selector 2 output is not the value -(2^n). When the selector 2 output is -(2^n) and the PWM value is reflected in the PWM control by setting PWMWP to 1, the PWM value is treated as an invalid PWM control variable setting and the UNZF bit is set to 1, The setting is not reflected in the PWM control output.$ | ## 15.3.11 STIFPCR0, STIFPCR01 Registers (STPCR0R, STPCR1R) STPCR0R and STPCR1R are 32-bit registers that interface with the internal PCR register. STPCR0R and STPCR1R are initialized to H'00000000 by a power-on reset. These registers compose a 42-bit register including PCR base (33 bits) and PCR extension (9 bits). The PCR base and PCR extension are stored in PCRB32 to PCRB0 and PCRX8 to PCRX0 respectively. Reading or writing this 42-bit register does not cause the read/write result to be reflected directly in clock recovery. #### STPCR0R | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|---------------------|------------------|-----|----------------------------------------------------------------------| | 31 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 to 0 | PCRB32 to<br>PCRB23 | All 0 | R/W | PCR Base | #### STPCR1R | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------------|------------------|-----|---------------| | 31 to 9 | PCRB22 to<br>PCRB0 | All 0 | R/W | PCR Base | | 8 to 0 | PCRX8 to<br>PCRX0 | All 0 | R/W | PCR Extension | Note: If PCR\_PID arrives during data read, the read value is overwritten and becomes undefined. Therefore, confirm that there is no PCR\_PID during data read with the PCRF bit in STSTR. Specifically, set the PCRF bit to 0 and then start reading the receive data. Whenever PCRF is 1, take this procedure. ### 15.3.12 STIFSTC0, STIFSTC1 Registers (STSTC0R, STSTC1R) STSTC0R and STSTC1R are 32-bit registers that interface with the internal STC register. STPCR0R and STPCR1R are initialized to H'00000000 by a power-on reset. These registers compose a 42-bit register including STC base (33 bits) and STC extension (9 bits). The PCR base and PCR extension are stored in STCB32 to STCB0 and STCX8 to STCX0 respectively. Reading or writing this 42-bit register does not cause the read/write result to be reflected directly in clock recovery. #### STSTC0R | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|---------------------|------------------|-----|----------------------------------------------------------------------| | 31 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 to 0 | STCB32 to<br>STCB23 | All 0 | R/W | STC Base | #### STSTC1R | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------------|------------------|-----|---------------| | 31 to 9 | STCB22 to<br>STCB0 | All 0 | R/W | STC Base | | 8 to 0 | STCX8 to<br>STCX0 | All 0 | R/W | STC Extension | Note: If PCR\_PID arrives during data read, the read value is overwritten and becomes undefined. Therefore, confirm that there is no PCR\_PID during data read with the PCRF bit in STSTR. Specifically, set the PCRF bit to 0 and then start reading the receive data. Whenever PCRF is 1, take this procedure. # 15.3.13 STIF Lock Control Register (STLKCR) STLKCR is a 32-bit register to control PLL frequency lock. STLKCR is initialized to H'000000000 by a power-on reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | | |----------|----------|-----------------------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31 to 26 | _ | All 0 | R | Reserved | | | | | | | These bits are always read as 0. The write value should always be 0. | | | 25 | LKWP | 0 | R/W | Setting this bit to 1 causes the LKCNT value to be reflected in the internal LKCNT. | | | | | | | If this operation conflicts with the count up or clear operation of the internal LKCNT, writing by LKWP takes precedence. | | | | | | | This bit is automatically cleared to 0. | | | 24 | ULWP | R/W Setting this bit to 1 causes the ULCNT value reflected in the internal ULCNT. | | Setting this bit to 1 causes the ULCNT value to be reflected in the internal ULCNT. | | | | | | | If this operation conflicts with the count up or clear operation of the internal ULCNT, writing by ULWP takes precedence. | | | | | | | This bit is automatically cleared to 0. | | | 23 | ULCNT3 | 0 | R/W | Setting ULWP to 1 causes the ULCNT value to be written | | | 22 | ULCNT2 | 0 | R/W | to the internal ULCNT. When read, these bits indicate to state below. | | | 21 | ULCNT1 | 0 | R/W | - The count of continuous LKZF = 1 states (outside the | | | 20 | ULCNT0 | 0 | R/W | threshold value range) in the PLL lock state (LKF = 1) | | | | | | | These bits are cleared to 0 when (1) ULCNT >= ULREF (when LKF = 1, it is cleared to 0), (2) the ULCNT value falls within the threshold value range (LKZF = 0), or (3) "discont" occurs. | | | 19 | LKCNT3 | 0 | R/W | Setting LKLP to 1 causes the LKCNT value to be written | | | 18 | LKCNT2 | 0 | R/W | to the internal LKCNT. When read, these bits indicate the state below. | | | 17 | LKCNT1 | 0 | R/W | - The count of continuous LKZF = 0 states (within the | | | 16 | LKCNT0 | 0 | R/W | threshold value range) in the PLL unlock state (LKF = 0) | | | | | | | These bits are cleared to 0 when (1) LKCNT >= LKREF (when LKF = 0, it is set to 1), (2) the LKCNT value exceeds the threshold value range (LKZF = 1), or (3) "discont" occurs. | | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--| | 15 | GAIN3 | 0 | R/W | These bits are used to cor | ntrol the right-shift amount that | | | | 14 | GAIN2 | 0 | R/W | gains the error amount to be input to the adder from<br>selector 1. Since the error amount is expressed as a tw<br>complement, an arithmetic shift is used for right shift. The | | | | | 13 | GAIN1 | 0 | R/W | | | | | | 12 | GAIN0 | 0 | R/W | is, the most significant sign bit is copied to the bits that become short by the right shift for refill. Select a value between 0 and 10 for the right-shift amount of error amount. If a value outside the range is set, the setting is invalid and the operation is not guaranteed. | | | | | | | | | Right-shift amount | Right-shift amount | | | | | | | | 0000: 0 | 1000: 8 | | | | | | | | 0001: 1 | 1001: 9 | | | | | | | | 0010: 2 | 1010: 10 | | | | | | | | 0011: 3 | 1011: 11 (invalid) | | | | | | | | 0100: 4 | 1100: 12 (invalid) | | | | | | | | 0101: 5 | 1101: 13 (invalid) | | | | | | | | 0110: 6 | 1110: 14 (invalid) | | | | | | | | 0111: 7 | 1111: 15 (invalid) | | | | 11 | LKCYC3 | 0 | R/W | | threshold value. For PLL lock | | | | 10 | LKCYC2 | 0 | R/W | | e 15.3. Set an LKCYC value that<br>C (LKCYC =< PWMCYC). If a | | | | 9 | LKCYC1 | 0 | R/W | | C is set, the operation is not | | | | 8 | LKCYC0 | 0 | R/W | guaranteed. | | | | | 7 | ULREF3 | 0 | R/W | | ence value for the number of | | | | 6 | ULREF2 | 0 | R/W | continuous LKZF = 1 state range) when PLL is locked | es (outside the threshold value | | | | 5 | ULREF1 | 0 | R/W | compared with the ULCN | | | | | 4 | ULREF0 | 0 | R/W | ULREF, the LKF bit in ST | | | | | 3 | LKREF3 | 0 | R/W | | ence value for the number of | | | | 2 | LKREF2 | 0 | R/W | | es (within the threshold value | | | | 1 | LKREF1 | 0 | R/W | | ked (LKF = 0). This value is | | | | 0 | LKREF0 | 0 | R/W | compared with the LKCNT value. When LKCNT >= LKREF, the LKF bit in STSTR is set to 1. | | | | Table 15.3 PLL Lock Threshold Value Bits 11 to 8 ### Description | LKCYC3 to | PLL Lock Threshold<br>Value<br>(x PWM Reference<br>Clock) | Comparison | Acceptable<br>Comparison (Internal<br>STC - Internal PCR)<br>Result Range *1 | PWM Control<br>Variable* <sup>2</sup><br>(ILGL = 1) | |-----------|-----------------------------------------------------------|------------|------------------------------------------------------------------------------|-----------------------------------------------------| | 0000 | 2 | 0 | _ | _ | | 0001 | 4 | 1 | -1 to +1 | -2 | | 0010 | 8 | 2 | -3 to +3 | -4 | | 0011 | 16 | 3 | -7 to +7 | -8 | | 0100 | 32 | 4 | -15 to +15 | -16 | | 0101 | 64 | 5 | -31 to +31 | -32 | | 0110 | 128 | 6 | -63 to +63 | -64 | | 0111 | 256 | 7 | -127 to +127 | -128 | | 1000 | 512 | 8 | -255 to +255 | <b>–</b> 256 | | 1001 | 1024 | 9 | -511 to +511 | <b>-</b> 512 | | 1010 | 2048 | 10 | -1023 to +1023 | -1024 | | 1011 | 4096 | 11 | -2047 to +2047 | -2048 | | 1100 | 8192 | 12 | -4095 to +4095 | -4096 | | 1101 | 16384 | 13 | -8191 to +8191 | -8192 | | 1110 | 32768 | 14 | -16383 to +16383 | -16384 | | 1111 | 65536 | 15 | -32767 to +32767 | -32768 | Notes: 1. When the comparison (internal STC - internal PCR) result falls within the acceptable comparison result range, the LKZF bit is set to 0. 2. If the PWM control variable is -(2^n), it is treated as an invalid PWM control variable (ILGL = 1) and the LKZF bit is set to 1. The PWM control variable is selected by the PWMSEL and PWMSEL2 bits. ### 15.3.14 STIF Debugging Status Register (STDBGR) STDBGR is a 32-bit register that indicates the first four bytes of an input or output packet. STDBGR is provided for debugging. The write value should always be 0. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------------------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 0 | STMON31<br>to STMON0 | All 0 | R | The 4-byte timestamp of a packet that is input or output in TS mode is stored. | | | | | | This means that when the STIF receives a TS packet (188 bytes) from an external device, the 4-byte timestamp that will be added to the beginning of the TS packet by the STIF is stored. When the STIF outputs a TS packet to an external device, the 4-byte timestamp that was added to the beginning of the TTS packet (192 bytes) is stored. | | | | | | This register cannot be used in TTS mode or PS mode. | # 15.4 Examples of Clock Connection to Another Device Examples of clock connection to another device are illustrated below. ## 15.4.1 A Basic Example - When this LSI receives a stream, it is received in synchronization with STn\_CLKIN. - When this LSI sends a stream, it is sent in synchronization with ST\_CLKOUT. ### 15.4.2 An Example of Clock Connection When Another Device Has No Clock Input - When this LSI receives a stream, it is received in synchronization with STn\_CLKIN. - When this LSI sends a stream, it is sent in synchronization with STn\_CLKIN. ### 15.4.3 An Example of Clock Connection When Another Device Has No Clock Output - When this LSI receives a stream, it is received in synchronization with STn\_CLKIN. - When this LSI sends a stream, it is sent in synchronization with ST\_CLKOUT. # 15.5 Input/Output Timing Figures 15.2 to 15.7 show the operation overview and input/output timing of each mode. Figure 15.2 Operation Overview Figure 15.3 TS Mode 1 Figure 15.4 TS Mode 2 Figure 15.5 TS Mode 3 Figure 15.6 TTS Mode Figure 15.7 PS Mode ## 15.6 PCR Clock Recovery Module (PCRRCV) The PCR clock recovery module (PCRRCV) is a circuit to provide a PWM (pulse wave modulation) output for controlling the external VCXO circuit according to the difference between 42-bit program\_clock\_reference (PCR) and system reference clock (STC). The PCR consists of program\_colck\_reference\_base (PCR base) and program\_clock\_reference\_extension (PCR extension) of adaptation field in an input transport (TS) packet. The PCRRCV has the following features. - A 42-bit internal STC counter triggered by the clock input from the external VCXO circuit - PWM output for controlling the external VCXO circuit can be output on the STn\_PWMOUT pin. - VCXO control is selectable from PWM control mode according to the difference between PCR and STC in a TS packet or PWM control mode by directly setting STPWMR. - PWM control accuracy and PWM cycle can be set in STPWMMR. Figure 15.8 STn\_VCO\_CLKIN and STn\_PWMOUT Connections ## 15.6.1 Operation of PCR Clock Recovery Figure 15.9 Illustration of Register Settings - Register Settings - A. Specify the acceptable comparison bit count n of the PWM control variable using the PWMCYC3 to PWMCYC0 bits in STPWMMR. - B. Set a PLL lock threshold value using the LKCYC3 to LKCYC0 bits in STLKCR. - C. Specify the shift amount of the PWM control variable reference bit (LSB of PWM control variable) using the PWMSFT3 to PWMSFT0 bits in STPWMMR. The shifted bits (PWMSFT width bits in figure 15.9) do not fall within the PWM control variable comparison range. - D. In the PWM control variable calculation, the PCR base and PCR extension of the internal STC and PCR registers are converted to binary values, and the converted values are masked with the PWMSFT width bits, and then the difference between the values is calculated. The binary conversion is performed using the following expression (1). Internal STC/PCR binary conversion: (PCR\_base × 300 + PCR\_ext) & (PWMSFT width mask) ...(1) The upper comparison result except (PWMCYC + 1) of the difference result is reflected in the UNZF bit in STSTR. The upper comparison result except (LKCYC + 1) of the difference result is reflected in the LKZF bit in STSTR. - E. Specify the right-shift amount of selector 1 output using the GAIN3 to GAIN0 bits in STLKCR. Since an arithmetic shift is used for the right shift, the overflowing bits are discarded on the lower side and the sign bit (bit n when the acceptable comparison bit count = n) is refilled on the upper side. - F. Switch selector 1 and selector 2 using the PWMSEL and PWMSEL2 bits in STPWMMR to select the path to the internal PWM register. - G. Specify the PWM reference clock of the PWMOUT pin using the PWMDIV3 to PWMDIV0 bits in STPWMMR. The PWM reference clock has a cycle of system clock × PWMDIV. The PWM cycle of the PWMOUT pin has a clock cycle of PWMCYC × PWMDIV. - H. The PWMOUT output waveform that depends on the PWM control variable is as follows: PWMOUT high = (Inverse value of PWM control variable (except MSB) + 1) $\times$ PWMDIV ...(2a) $PWMOUT low = (PWMCYC - PWMOUT low) \times PWMDIV \qquad ...(2b)$ When the acceptable comparison bit count is n, the MSB becomes bit n of the PWM control variable. The PWM control variable is expressed as a two's complement. Whether to include the upper comparison target in the PWM control range is specified by the PWMUEN bit in STPWMMR. I. The PWM control variable can directly be set by STPWMR when the PWMSEL bit in STPWMMR is set to 1. In this case, PWMCYC acts as a number of acceptable comparison bits as in the case of internal STC value - PCR value (figure 15.9). ### 15.6.2 PCR Clock Recovery Operation Figure 15.10 Overview of TS Packet - Example 1: Clock recovery using the PCRRCV hardware - A. Set PWMSEL to 0 to enable the clock recovery using the PCRRCV hardware. - B. Set the PWMCYC, PWMSFT, PWMDIV, and PWMUEN bits in STPWMMR for the PWM control output. - C. Set the PID bits in STPWMMR to PCR\_PID of a packet including PCR for recovering clock to the PCRRCV. The clock recovery starts upon the PID setting. For this reason, if the PCR continuity is impaired by a reset or channel change, set PIDEN to 0 and then set a PID. - D. When a packet including PCR\_PID arrives, the PCRRCV extracts the 42-bit program\_clock\_reference (PCR) from the adaptation\_field of the packet. For packet conditions for extracting PCR, see table 15.4. When a TS packet that satisfies the conditions in table 15.4 arrives, a PCR arrival pulse is generated in the PCRRCV. - E. When a PCR arrival pulse is generated, the PCR extracted from the packet is transferred to the internal PCR register and STC counter. The STC counter (STC) value is also transferred to the internal STC register at the same time. After that, the STC counter starts counting by the VCXO clock input. The STC counter value incremented from the previous PCR until the present time by the VCXO clock is set in the internal STC register, and the currently arrived PCR is set in the internal PCR register and STC counter. - F. The PWM control variable, which is the comparison result between the internal STC and PCR registers (STC value PCR value), is calculated by the PWMCYC, PWMSFT, and PWMDIV bits in STPWMMR. When the comparison result reflection conditions in table 15.5 are satisfied, the comparison result is reflected in the PWM output control. Setting PWMUEN to 1 disables the PWM control variable outside the acceptable comparison result range specified by the PWMCYC bits to be reflected in the PWM control output. This function can prevent an abnormal PCR (caused by PCR error due to transmission error or protocol violation at the transmitter side) from being reflected in clock recovery. For measures against abnormal PCRs, see the procedure examples 1 and 2 described later. - G. The PWMOUT waveform with a reflected PWM control variable is output from the PWMOUT pin as shown in figure 15.9. - H. The internal STC and PCR register values are compared each time a PCR\_PID packet arrives. By configuring a feedback circuit including an external low-pass filter (LPF) and an external VCXO, which makes the comparison (STC value PCR value) result to be 0, the VCXO clock frequency is adjusted. - Example 2: Clock recovery using the PCRRCV and software - A. Set PWMSEL to 1 to disable the clock recovery using the PCRRCV hardware. Also set PCRE to 1 to enable interrupt requests made by each PCR arrival pulse. - B. The PCRRCV settings and transfers of the PCRRCV internal registers are the same as those described in steps 2 to 5 of Example 1. Notes 1 to 4 for table 15.5 apply to the case of the first arrival of PCR after the PCR continuity is lost. Since the STC counter that has no continuity with the arrived internal PCR register is transferred to the internal STC register, it is not appropriate to calculate the difference (STC value PCR value) by the CPU. - C. Confirm that transfer between the PCRRCV internal registers has been completed (PCRF = 1), and then set PCRF to 0. After that, set the STCRS and PCRRS bits to 1 to enable transfer from the STC register to STSTC0R and STSTC1R, as well as transfer from the PCR register to STSTC0R and STSTC1R. Then read STSTC0R/STSTC1R and STPCR0R/STPCR1R. Furthermore, to obtain the STC counter value for setting to the MPEG2 decoder, set the STCXP bit to 1 to enable transfer from the STC counter to STSTC0R and STSTC1R. Then read STSTC0R and STSTC1R. - D. A PCRF read value of 0 means that no PCR\_PID packet arrived during the register read stage in step 3. This shows that the reading of STSTC0R/STSTC1R and STPCR0R/STPCR1R in step 3 was successful. On the other hand, a PCRF read value of 1 shows an arrival of PCR\_PID packet during the register read stage in step 3. It is not certain that the read STSTC0R/STSTC1R and STPCR0R/STPCR1R are the values of the internal STC and PCR registers that arrived previously or those that arrived during the register read stage. Therefore, go back to step 3 and repeat the procedure. - E. The CPU converts the read STSTC0R/STSTC1R and STPCR0R/STPCR1R values to binary ones with STCbin and PCRbin respectively using the expression (1) in section 15.6.1, Operation of PCR Clock Recovery, step 4, and then calculates the difference (STCbin PCRbin). To be set in STPWMR as a PWM control variable, specify the difference (STCbin PCRbin) as a two's complement of the acceptable comparison bit count n (n: sign bit) specified by the PWMCYC bits. Set a value within the range of -(2^n 1) to +(2^n 1) for the difference. Do not set the value -2^n. The CPU also determines the handling of PCR data errors shown in step 6 of Example 1. - F. The PWM control variable that is set in STPWMR can be reflected in the PWM control output by writing 1 to PWMWP. - G. For the principle of VCXO clock frequency adjustment using the PWM control output, the descriptions in steps 7 and 8 of Example 1 apply. Table 15.4 PCR Extraction Conditions | transport_error_<br>indicator | adaptation_field_<br>control | adaptation_field_length | PCR_flag | PCR Extraction* | |-------------------------------|------------------------------|-------------------------|------------|-----------------| | 0 | 00 | don't care | don't care | Impossible | | | 01 | don't care | don't care | Impossible | | | 10 | 0 ≤ len < 7 | don't care | Impossible | | | | 7 ≤ len < H'FF | 0 | Impossible | | | | | 1 | Possible | | | 11 | 0 ≤ len < 7 | don't care | Impossible | | | | 7 ≤ len < H'FF | 0 | Impossible | | | | | 1 | Possible | | 1 | don't care | don't care | don't care | Impossible | Note: \* When PCR extraction is possible, PCR is extracted and a PCR arrival pulse is generated. Table 15.5 Internal PCR and STC Registers Comparison Result Reflection Conditions \*1 | Reflection | Comparison Result Reflection Conditions | | |-----------------|---------------------------------------------------------------------------------|--| | Not reflected*2 | Arrival of PCR_PID after "discont" *3 | | | | Arrival of PCR_PID whose upper comparison result does not match when PWMUEN = 1 | | | Reflected | Arrival of PCR_PID in other cases | | - Notes: 1. When PWMSEL = 0, the reflection conditions in this table are effective. When PWMSEL = 1, the PWM control variable can be reflected in the PWM control output by writing 1 to the PWMWP bit. - 2. Since the PWM control variable is not reflected, the PWMOUT waveform is maintained. - 3. There are four patterns of PCR\_PID arrival after "discont." - (1) The first PCR PID arrival after reset cancellation - (2) The first PCR PID arrival after PCR flush cancellation - (3) When discontinuity\_indicator of the arrived PCR\_PID packet = 1 - (4) Arrival of PCR\_PID after the PID bits in STPWMMR was modified \*4 - Set PIDEN to 0 before modifying the PID bits in STPWMMR. With this setting, arrival of PCR\_PID is treated as arrival after "discont." - Hardware measures against arrival of abnormal PCRs - Initial setting (1) Set an LKCYC value not larger than the PWMCYC value. The LKCYC value must be larger than the steady-state deviation (error amount) of the PLL that is configured with an external circuit. Determine the LKCYC value with a margin from the PLL's steady-state deviation. Otherwise, the operation of this LSI is not guaranteed. - Initial setting (2) Set an LKREF value until the LKF bit is set to 1 when the PLL error amount falls within the threshold value range. The LKREF bits, which are usually set to 1, are provided for setting to enhance the stability against arrival of abnormal PCRs in the PLL pullin state. Note that the larger the LKREF value becomes, the higher stability is obtained, but the PLL pull-in time becomes longer. Initial setting (3) Set a ULREF value until the LKF bit is set to 0 when the PLL error amount exceeds the threshold value limit. The ULREF bits, which are usually set to 1, are provided for setting to enhance the stability against arrival of abnormal PCRs in the PLL lock state. It is recommended that the LKREF value be larger than the maximum of the number of continuous arrivals of system-dependent abnormal PCRs. ## 15.7 Usage Notes - 1. When at least one channel is set to transmit mode (stream output from the SHA to an external device) with the input clock to the ST\_CLKIN pin of the relevant channel selected as the transmit clock (CLKSEL bit in STMDR of relevant channel is 1), the ST\_CLKOUT pin should be fixed to low-level output (CKFRSEL[3:0] bits in STMDR\_0 are 1111). - 2. The ST\_CLKOUT pin is a common resource for STIF channels. Since it is incorporated in channel 0, the ST\_CLKOUT operation is not affected by channel 1 being in module standby mode. When the STIF is in module standby mode, the main clock supplies (Pφ and Bφ) to the relevant channel are stopped. Therefore, if channel 0 enters module standby mode, the ST\_CLKOUT operation conforms to the setting of bits CKFRSEL[3:0] in STMDR\_0 as shown below. 0000: Output is fixed to low 0001: Ιφ/2 (not affected by module standby mode) 0010: I\psi/3 (not affected by module standby mode) 0011: I\psi/4 (not affected by module standby mode) 0100: I\psi/6 (not affected by module standby mode) 0101: I\u00f3/8 (not affected by module standby mode) 0110: Iφ/12 (not affected by module standby mode) 0111: Reserved (setting prohibited) 1000: Reserved (setting prohibited) 1001: Reserved (setting prohibited) 1010: Reserved (setting prohibited) 1011: Reserved (setting prohibited) 1100: Reserved (setting prohibited) 1101: Reserved (setting prohibited) 1110: Reserved (setting prohibited) 1111: Output is fixed to low For details on module standby mode, refer to section 11, Power-Down Modes. When a stream from an external device to the STIF is being transferred to memory via the A-DMAC, perform the following processing in the order shown below to pause and resume transfer. To pause transfer: - (1) Clear the C[i]C\_E bit in the channel [i] processing control register (C[i]C) to 0. - (2) Poll the interrupt request flag or wait for an interrupt until the C[i]I\_DI bit in the channel [i] processing interrupt request register (C[i]I) becomes 1. To resume transfer: - (3) Set the C[i]C\_E bit in the channel [i] processing control register (C[i]C) to 1. - 4. When a stream from memory to the A-DMAC is being transferred to an external device via the STIF, perform the following processing in the order shown below to pause and resume transfer. To pause transfer: - (1) Clear the C[i]C E bit in the channel [i] processing control register (C[i]C) to 0. - (2) Poll the interrupt request flag or wait for an interrupt until the C[i]I\_DI bit in the channel [i] processing interrupt request register (C[i]I) becomes 1. To resume transfer: - (3) Set the C[i]C\_E bit in the channel [i] processing control register (C[i]C) to 1. - 5. When a stream from an external device to the STIF is being transferred to memory via the A-DMAC, perform the following processing in the order shown below to forcibly terminate and resume transfer. To forcibly terminate transfer: - (1) Clear both the REQEN and EN bits in the STIF control register (STCTLR) to 0. - (2) Clear the C[i]C\_E bit to 0 and set the C[i]C\_R bit to 1 in the channel [i] processing control register (C[i]C). - (3) Prepare a dummy descriptor. (Specify data transfer from the relevant STIF channel to memory and set a transfer size of 192 bytes. Other settings and the transfer data contents can be set as desired.) - (4) Set the pointer address of the above dummy descriptor in the channel [i] processing descriptor start address register (C[i]DSA) and channel [i] processing descriptor current address register (C[i]DCA). - (5) Set the C[i]C\_E bit to 1 and clear the C[i]C\_R bit to 0 in the channel [i] processing control register (C[i]C). - (6) According to the STIF channel to be stopped, poll the interrupt request flag until bits 14 to 8 or 6 to 0 in address H'FFFC\_25E0 become 0000000. (If STIF0 is to be stopped, bits 14 to 8 are polled. If STIF1 is to be stopped, bits 6 to 0 are polled.) - (7) Clear the C[i]C E bit to 0 and set the C[i]C R bit to 1 in the channel [i] processing control register (C[i]C). - (8) Set the SRST bit in the STIF control register (STCTLR) to 1. To resume transfer: - (9) Set the C[i]C E bit to 1 and clear the C[i]C R bit to 0 in the channel [i] processing control register (C[i]C). - (10) Set both the REQEN and EN bits in the STIF control register (STCTLR) to 1. - 6. When a stream from memory to the A-DMAC is being transferred to an external device via the STIF, perform the following processing in the order shown below to forcibly terminate and resume transfer. To forcibly terminate transfer: - (1) Clear both the REQEN and EN bits in the STIF control register (STCTLR) to 0. - (2) Clear the C[i]C\_E bit to 0 and set the C[i]C\_R bit to 1 in the channel [i] processing control register (C[i]C). - (3) Prepare a dummy descriptor. (Specify data transfer from the relevant STIF channel to memory and set a transfer size of 192 bytes. Other settings and the transfer data contents can be set as desired.) - (4) Set the pointer address of the above dummy descriptor in the channel [i] processing descriptor start address register (C[i]DSA) and channel [i] processing descriptor current address register (C[i]DCA). - (5) Set the C[i]C E bit to 1 and clear the C[i]C R bit to 0 in the channel [i] processing control register (C[i]C). - (6) According to the STIF channel to be stopped, poll the interrupt request flag until bits 14 to 8 or 6 to 0 in address H'FFFC 25E0 become 0000000. (If STIF0 is to be stopped, bits 14 to 8 are polled. If STIF1 is to be stopped, bits 6 to 0 are polled.) - (7) Clear the C[i]C E bit to 0 and set the C[i]C R bit to 1 in the channel [i] processing control register (C[i]C). - (8) Set the SRST bit in the STIF control register (STCTLR) to 1. To resume transfer: - (9) Set both the REQEN and EN bits in the STIF control register (STCTLR) to 1. - (10) Set the C[i]C\_E bit to 1 and clear the C[i]C\_R bit to 0 in the channel [i] processing control register (C[i]C). # Section 16 Serial Sound Interface (SSI) The serial sound interface (SSI) is a module designed to send or receive audio data interface with various devices offering Philips format compatibility. It also provides additional modes for other common formats, as well as support for multi-channel mode. ### 16.1 Features - Number of channels: Two channels - Operating mode: Non-compressed mode The non-compressed mode supports serial audio streams divided by channels. - Serves as both a transmitter and a receiver - Capable of using serial bus format - Asynchronous transfer takes place between the data buffer and the shift register. - It is possible to select a value as the dividing ratio for the clock used by the serial bus interface. - It is possible to control data transmission or reception with DMAC and interrupt requests. - Selects the oversampling clock input from among the following pins: EXTAL, XTAL (Clock operation mode 0) CKIO (Clock operation modes 1 and 2) AUDIO CLK Figure 16.1 shows a schematic diagram of the four channels in the SSI module. Figure 16.1 Schematic Diagram of SSI Module Figure 16.2 shows a block diagram of the SSI module. Figure 16.2 Block Diagram of SSI #### **Input/Output Pins** 16.2 Table 16.1 shows the pin assignments relating to the SSI module. **Table 16.1 Pin Assignments** | Pin Name | Number of Pins | I/O | Description | |-----------|----------------|-------|----------------------------------------------------------------------| | SSISCK0 | 1 | I/O | Serial bit clock | | SSIWS0 | 1 | I/O | Word selection | | SSIDATA0 | 1 | I/O | Serial data input/output | | SSISCK1 | 1 | I/O | Serial bit clock | | SSIWS1 | 1 | I/O | Word selection | | SSIDATA1 | 1 | I/O | Serial data input/output | | AUDIO_CLK | 1 | Input | External clock for audio (entering oversampling clock 256/384/512fs) | ## 16.3 Register Description The SSI has the following registers. Note that explanation in the text does not refer to the channels. **Table 16.2 Register Description** | Channel | Register Name | Abbrevia-<br>tion | R/W | Initial Value | Address | Access<br>Size | |---------|--------------------------------|-------------------|------|---------------|------------|----------------| | 0 | Control register 0 | SSICR_0 | R/W | H'00000000 | H'FFFEC000 | 32 | | | Status register 0 | SSISR_0 | R/W* | H'02000003 | H'FFFEC004 | 32 | | | Transmit data register 0 | SSITDR_0 | R/W | H'00000000 | H'FFFEC008 | 32 | | | Receive data register 0 | SSIRDR_0 | R | H'00000000 | H'FFFEC00C | 32 | | 1 | Control register 1 | SSICR_1 | R/W | H'00000000 | H'FFFEC800 | 32 | | | Status register 1 | SSISR_1 | R/W* | H'02000003 | H'FFFEC804 | 32 | | | Transmit data register 1 | SSITDR_1 | R/W | H'00000000 | H'FFFEC808 | 32 | | | Receive data register 1 | SSIRDR_1 | R | H'00000000 | H'FFFEC80C | 32 | | 0 | SSI clock selection register 0 | SCSR_0 | R/W | H'0000 | H'FFFF0000 | 16 | | 1 | SSI clock selection register 1 | SCSR_1 | R/W | H'0000 | H'FFFF0800 | 16 | Note: \* Although bits 26 and 27 in this register can be read from or written to, bits other than these are read-only. For details, refer to section 16.3.2, Status Register (SSISR). #### 16.3.1 **Control Register (SSICR)** SSICR is a readable/writable 32-bit register that controls the IRQ, selects the polarity status, and sets operating mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|------|------|------|------|------|------|------|------|-----|--------|----------|---------|------|-----|----------|-----| | | - | - | - | DMEM | UIEN | OIEN | IIEN | DIEN | CHN | L[1:0] | | DWL[2:0 | ] | | SWL[2:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SCKD | SWSD | SCKP | SWSP | SPDP | SDTA | PDTA | DEL | 1 | ( | CKDV[2:0 | )] | MUEN | - | TRMD | EN | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W R | R/W | R/W | R/W | R/W | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------| | 31 to 29 | _ | All 0 | R | Reserved | | | | | | The read value is not guaranteed. The write value should always be 0. | | 28 | DMEN | 0 | R/W | DMA Enable | | | | | | Enables/disables the DMA request. | | | | | | 0: DMA request is disabled. | | | | | | 1: DMA request is enabled. | | 27 | UIEN | 0 | R/W | Underflow Interrupt Enable | | | | | | 0: Underflow interrupt is disabled. | | | | | | 1: Underflow Interrupt is enabled. | | 26 | OIEN | 0 | R/W | Overflow Interrupt Enable | | | | | | 0: Overflow interrupt is disabled. | | | | | | 1: Overflow interrupt is enabled. | | 25 | IIEN | 0 | R/W | Idle Mode Interrupt Enable | | | | | | 0: Idle mode interrupt is disabled. | | | | | | 1: Idle mode interrupt is enabled. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|-----|-------------------------------------------------------------| | 24 | DIEN | 0 | R/W | Data Interrupt Enable | | | | | | 0: Data interrupt is disabled. | | | | | | 1: Data interrupt is enabled. | | 23, 22 | CHNL[1:0] | 00 | R/W | Channels | | | | | | These bits show the number of channels in each system word. | | | | | | 00: Having one channel per system word | | | | | | 01: Having two channels per system word | | | | | | 10 Having three channels per system word | | | | | | 11: Having four channels per system word | | 21 to 19 | DWL[2:0] | 000 | R/W | Data Word Length | | | | | | Indicates the number of bits in a data word. | | | | | | 000: 8 bits | | | | | | 001: 16 bits | | | | | | 010: 18 bits | | | | | | 011: 20 bits | | | | | | 100: 22 bits | | | | | | 101: 24 bits | | | | | | 110: 32 bits | | | | | | 111: Reserved | | 18 to 16 | SWL[2:0] | 000 | R/W | System Word Length | | | | | | Indicates the number of bits in a system word. | | | | | | 000: 8 bits | | | | | | 001: 16 bits | | | | | | 010: 24 bits | | | | | | 011: 32 bits | | | | | | 100: 48 bits | | | | | | 101: 64 bits | | | | | | 110: 128 bits | | | | | | 111: 256 bits | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | SCKD | 0 | R/W | Serial Bit Clock Direction | | | | | | 0: Serial bit clock is input, slave mode. | | | | | | 1: Serial bit clock is output, master mode. | | | | | | Note: Non-compression mode (CPEN = 0) permits only the following settings: (SCKD, SWSD) = $(0,0)$ and $(1,1)$ . Other settings are prohibited. | | 14 | SWSD | 0 | R/W | Serial WS Direction | | | | | | 0: Serial word select is input, slave mode. | | | | | | 1: Serial word select is output, master mode. | | | | | | Note: Non-compression mode (CPEN = 0) permits only the following settings: (SCKD, SWSD) = (0,0) and (1,1). Other settings are prohibited. | | 13 | SCKP | 0 | R/W | Serial Bit Clock Polarity | | | | | | 0: SSIWS and SSIDATA change at the SSISCK falling edge (sampled at the SCK rising edge). | | | | | | 1: SSIWS and SSIDATA change at the SSISCK rising edge (sampled at the SCK falling edge). | | | | | | SCKP = 0 SCKP = 1 | | | | | | SSIDATA input sampling timing at the time of reception (TRMD = 0) | | | | | | SSIDATA output change timing at the time of transmission (TRMD = 1) | | | | | | SSIWS input sampling timing at the time of slave mode (SWSD = 0) SSISCK rising edge SSISCK falling edge | | | | | | SSIWS output change SSISCK falling edge SSISCK rising edge timing at the time of master mode (SWSD = 1) | | 12 | SWSP | 0 | R/W | Serial WS Polarity | | | | | | 0: SSIWS is low for 1st channel, high for 2nd channel. | | | | | | 1: SSIWS is high for 1st channel, low for 2nd channel. | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | SPDP | 0 | R/W | Serial Padding Polarity | | | | | | 0: Padding bits are low. | | | | | | 1: Padding bits are high. | | | | | | Note: When MUEN = 1, the padding bit becomes low (the MUTE function takes precedence). | | 10 | SDTA | 0 | R/W | Serial Data Alignment | | | | | | 0: Transmitting and receiving in the order of serial data and padding bits | | | | | | Transmitting and receiving in the order of padding bits and serial data | | 9 | PDTA | 0 | R/W | Parallel Data Alignment | | | | | | This bit is ignored if CPEN = 1. When the data word length is 32, 16 or 8 bit, this configuration field has no meaning. | | | | | | This bit applies to SSIRDR in receive mode and SSITDR in transmit mode. | | | | | | 0: Parallel data (SSITDR, SSIRDR) is left-aligned | | | | | | 1: Parallel data (SSITDR, SSIRDR) is right-aligned. | | | | | | <ul> <li>DWL = 000 (with a data word length of 8 bits), the<br/>PDTA setting is ignored.</li> </ul> | | | | | | All data bits in SSIRDR or SSITDR are used on the audio serial bus. Four data words are transmitted or received at each 32-bit access. The first data word is derived from bits 7 to 0, the second from bits 15 to 8, the third from bits 23 to 16 and the last data word is derived from bits 31 to 24. | | | | | | <ul> <li>DWL = 001 (with a data word length of 16 bits), the<br/>PDTA setting is ignored.</li> </ul> | | | | | | All data bits in SSIRDR or SSITDR are used on the audio serial bus. Two data words are transmitted or received at each 32-bit access. The first data word is derived from bits 15 to 0 and the second data word is derived from bits 31 to 16. | | | | Initial | | | |-----|----------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 9 | PDTA | 0 | R/W | <ul> <li>DWL = 010, 011, 100, 101 (with a data word length<br/>of 18, 20, 22 or 24 bits), PDTA = 0 (left-aligned)</li> </ul> | | | | | | The data bits used in SSIRDR or SSITDR are the following: | | | | | | Bits 31 down to (32 minus the number of bits in the data word length specified by DWL). | | | | | | That is, If DWL = 011, the data word length is 20 bits; therefore, bits 31 to 12 in either SSIRDR or SSITDR are used. All other bits are ignored or reserved. | | | | | | <ul> <li>DWL = 010, 011, 100, 101 (with a data word length<br/>of 18, 20, 22 or 24 bits), PDTA = 1 (right-aligned)</li> </ul> | | | | | | The data bits used in SSIRDR or SSITDR are the following: | | | | | | Bits (the number of bits in the data word length specified by DWL minus 1) to 0 | | | | | | i.e. if DWL = 011, then DWL = 20 and bits 19 to 0 are used in either SSIRDR or SSITDR. All other bits are ignored or reserved. | | | | | | <ul> <li>DWL = 110 (with a data word length of 32 bits), the<br/>PDTA setting is ignored.</li> </ul> | | | | | | All data bits in SSIRDR or SSITDR are used on the audio serial bus. | | 8 | DEL | 0 | R/W | Serial Data Delay | | | | | | 0: 1 clock cycle delay between SSIWS and SSIDATA | | | | | | 1: No delay between SSIWS and SSIDATA | | | | | | Note: When CPEN = 1, this bit should be set to 1. | | 7 | _ | 0 | R | Reserved | | | | | | The read value is undefined. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 to 4 | CKDV[2:0] | 000 | R/W | Serial Oversampling Clock Division Ratio | | | | | | Sets the ratio between oversampling clock* and the serial bit clock. When the SCKD bit is 0, the setting of these bits is ignored. The serial bit clock is used in the shift register and is supplied from the SSISCK pin. | | | | | | 000: Serial bit clock frequency = Oversampling clock Frequency/1 | | | | | | 001: Serial bit clock frequency = Oversampling clock frequency/2 | | | | | | 010: Serial bit clock frequency = Oversampling clock frequency/4 | | | | | | 011: Serial bit clock frequency = Oversampling clock frequency/8 | | | | | | 100: Serial bit clock frequency = Oversampling clock frequency/16 | | | | | | 101: Serial bit clock frequency = Oversampling clock frequency/6 | | | | | | 110: Serial bit clock frequency = Oversampling clock frequency/12 | | | | | | 111: Setting prohibited | | | | | | Note: * An oversampling clock is selected by the SCSR_0/SCSR_1 setting. | | 3 | MUEN | 0 | R/W | Mute Enable | | | | | | 0: Module is not muted. | | | | | | 1: Module is muted. | | 2 | _ | 0 | R | Reserved | | | | | | The read value is undefined. The write value should always be 0. | | 1 | TRMD | 0 | R/W | Transmit/Receive Mode Select | | | | | | 0: Module is in receive mode. | | | | | | 1: Module is in transmit mode. | | 0 | EN | 0 | R/W | SSI Module Enable | | | | | | 0: Module is disabled. | | | | | | 1: Module is enabled. | ## 16.3.2 Status Register (SSISR) SSISR consists of status flags indicating the operational status of the SSI module and bits indicating the current channel numbers and word numbers. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | | - | - | - | DMRQ | UIRQ | OIRQ | IIRQ | DIRQ | - | - | - | - | - | - | - | - | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Un-<br>defined | R/W: | R | R | R | R | R/W* | R/W* | R | R | R | R | R | R | R | R | R | R | | Dia. | | | | | | | | | _ | | _ | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | - | 1 | - | - | 1 | 1 | 1 | - | - | - | 1 | CHN | O[1:0] | SWNO | IDST | | Initial value: | Un-<br>defined 0 | 0 | 1 | 1 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | Note: \* Can be read from or written to. Writing 0 initializes the bit, but writing 1 is ignored. | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------| | 31 to 29 | _ | All 0 | R | Reserved | | | | | | The read value is not guaranteed. The write value should always be 0. | | 28 | DMRQ | 0 | R | DMA Request Status Flag | | | | | | This status flag allows the CPU to recognize the value of the DMA request pin on the SSI module. | | | | | | • TRMD = 0 (Receive mode) | | | | | | If DMRQ = 1, the SSIRDR has unread data. | | | | | | If SSIRDR is read, DMRQ = 0 until there is new unread data. | | | | | | • TRMD = 1 (Transmit mode) | | | | | | If DMRQ = 1, SSITDR requires data to be written to continue the transmission to the audio serial bus. | | | | | | Once data is written to SSITDR, DMRQ = $0$ until it requires further transmit data. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | |-----|----------|------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 27 | UIRQ | 0 | R/W* | Underflow Error Interrupt Status Flag This status flag indicates that data was supplied at a lower rate than was required. In either case, this bit is set to 1 regardless of the value of the UIEN bit and can be cleared by writing 0 to this | | | | | | | | bit. If UIRQ = 1 and UIEN = 1, an interrupt occurs. | | | | | | | | • TRMD = 0 (Receive mode) | | | | | | | | If UIRQ = 1, SSIRDR was read before there was new unread data indicated by the DMRQ or DIRQ bit. This can lead to the same received sample being stored twice by the host leading to potential corruption of multi-channel data. | | | | | | | | • TRMD = 1 (Transmit mode) | | | | | | | | If UIRQ = 1, SSITDR did not have data written to it before it was required for transmission. This will lead to the same sample being transmitted once more and a potential corruption of multi-channel data. This is more serious error than a receive mode underflow as the output SSI data results in error. | | | | | | | | Note: When underflow error occurs, the current data in the data buffer of this module is transmitted until the next data is filled. | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26 | OIRQ | 0 | R/W* | Overflow Error Interrupt Status Flag | | | | | | This status flag indicates that data was supplied at a higher rate than was required. | | | | | | In either case this bit is set to 1 regardless of the value of the OIEN bit and can be cleared by writing 0 to this bit. | | | | | | If OIRQ = 1 and OIEN = 1, an interrupt occurs. | | | | | | • TRMD = 0 (Receive mode) | | | | | | If OIRQ = 1, SSIRDR was not read before there was new unread data written to it. This will lead to the loss of a sample and a potential corruption of multi-channel data. | | | | | | Note: When overflow error occurs, the current data in the data buffer of this module is overwritten by the next incoming data from the SSI interface. | | | | | | • TRMD = 1 (Transmit mode) | | | | | | If OIRQ = 1, SSITDR had data written to it before it was transferred to the shift register. This will lead to the loss of a sample and a potential corruption of multi-channel data. | | 25 | IIRQ | 1 | R | Idle Mode Interrupt Status Flag | | | | | | This interrupt status flag indicates whether the SSI module is in idle state. | | | | | | This bit is set regardless of the value of the IIEN bit to allow polling. | | | | | | The interrupt can be masked by clearing IIEN, but cannot be cleared by writing to this bit. | | | | | | If IIRQ = 1 and IIEN = 1, an interrupt occurs. | | | | | | 0: The SSI module is not in idle state. | | | | | | 1: The SSI module is in idle state. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | |---------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 24 | DIRQ | 0 | R | Data Interrupt Status Flag | | | | | | | | | | This status flag indicates that the module has data to be read or requires data to be written. | | | | | | | | | | In either case this bit is set to 1 regardless of the value of the DIEN bit to allow polling. | | | | | | | | | | The interrupt can be masked by clearing DIEN, but cannot be cleared by writing to this bit. | | | | | | | | | | If DIRQ= 1 and DIEN = 1, an interrupt occurs. | | | | | | | | | | • TRMD = 0 (Receive mode) | | | | | | | | | | 0: No unread data in SSIRDR | | | | | | | | | | 1: Unread data in SSIRDR | | | | | | | | | | • TRMD = 1 (Transmit mode) | | | | | | | | | | 0: Transmit buffer is full. | | | | | | | | | | <ol> <li>Transmit buffer is empty and requires data to be<br/>written to SSITDR.</li> </ol> | | | | | | 23 to 4 | _ | Undefined | R | Reserved | | | | | | | | | | The read value is undefined. The write value should always be 0. | | | | | | 3, 2 | CHNO | 00 | R | Channel Number | | | | | | | [1:0] | | | These bits show the current channel number. | | | | | | | | | | • TRMD = 0 (Receive mode) | | | | | | | | | | CHNO indicates which channel the data in SSIRDR currently represents. This value will change as the data in SSIRDR is updated from the shift register. | | | | | | | | | | • TRMD = 1 (Transmit mode) | | | | | | | | | | CHNO indicates which channel is required to be written to SSITDR. This value will change as the data is copied to the shift register, regardless of whether the data is written to SSITDR. | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | SWNO | 1 | R | System Word Number | | | | | | This status bit indicates the current word number. | | | | | | • TRMD = 0 (Receive mode) | | | | | | SWNO indicates which system word the data in SSIRDR currently represents. This value will change as the data in SSIRDR is updated from the shift register, regardless of whether SSIRDR has been read. | | | | | | • TRMD = 1 (Transmit mode) | | | | | | SWNO indicates which system word is required to<br>be written to SSITDR. This value will change as the<br>data is copied to the shift register, regardless of<br>whether the data is written to SSITDR. | | 0 | IDST | 1 | R | Idle Mode Status Flag | | | | | | This status flag indicates that the serial bus activity has stopped. | | | | | | This bit is cleared if $EN = 1$ and the serial bus are currently active. | | | | | | This bit is automatically set to 1 under the following conditions. | | | | | | <ul> <li>SSI = Master transmitter (SWSD = 1 and<br/>TRMD = 1)</li> </ul> | | | | | | This bit is set to 1 if all the data in the system word to be transmitted has been written to SSITDR and if the EN bit is cleared to end the system word currently being output. | | | | | | • SSI = Master receiver (SWSD = 1 and TRMD = 0) | | | | | | This bit is set to 1 if the EN bit is cleared and the current system word is completed. | | | | | | • SSI = Slave transmitter/receiver (SWSD = 0) | | | | | | This bit is set to 1 if the EN bit is cleared and the current system word is completed. | | | | | | Note: If the external master stops the serial bus clock before the current system word is completed, this bit is not set. | Note: \* The bit can be read or written to. Writing 0 initializes the bit, but writing 1 is ignored. ### 16.3.3 Transmit Data Register (SSITDR) SSITDR is a 32-bit register that stores data to be transmitted. Data written to this register is transferred to the shift register upon transmission request. If the data word length is less than 32 bits, the alignment is determined by the setting of the PDTA control bit in SSICR. The data in the buffer can be accessed by reading this register. ### 16.3.4 Receive Data Register (SSIRDR) SSIRDR is a 32-bit register that stores receive messages. Data in this register is transferred from the shift register each time data word is received. If the data word length is less than 32 bits, the alignment is determined by the setting of the PDTA control bit in SSICR. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | | | | | | | | | | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | ## 16.3.5 SSI Clock Selection Register (SCSR) SCSR is a 16-bit readable/writable register that selects the source of oversampling clocks used by the SSI, as well as division ratio. Note: n=0, 1 | | | Initial | | | |---------|--------------|---------|-----|------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 3 | _ | All 0 | R | Reserved | | | | | | The read value is undefined. The write value should always be 0. | | 2 to 0 | SSInCKS[2:0] | 000 | R/W | SSIchn Clock Select | | | | | | Selects the source of the oversampling clock used by SSIchn. See table 16.3. | Note: n = 0, 1 Table 16.3 Selection of the Source for the Oversampling Clock Used by SSInCKS | SSInCKS[2:0]*1 | Clock Operating Mode | | | | | | | | | |----------------|--------------------------------------------------------------------------------------------------------------------|---------------|--------------------|--|--|--|--|--|--| | Setting | 0 or 1 | 2 | 3 | | | | | | | | 000 | Reserved. This is given as an initial value and it should be changed to an appropriate value before SSI operation. | | | | | | | | | | 001 | Reserved | | | | | | | | | | 010 | AUDIO_CLK input *2 | | | | | | | | | | 011 | AUDIO_CLK input *2/4 | | | | | | | | | | 100 | EXTAL input | CKIO input | Setting prohibited | | | | | | | | 101 | EXTAL input /4 | CKIO input /4 | Setting prohibited | | | | | | | | 110 | EXTAL input /2 | CKIO input /2 | Setting prohibited | | | | | | | | 111 | EXTAL input /8 | CKIO input /8 | Setting prohibited | | | | | | | Note: \*1. n = 0, 1 <sup>\*2.</sup> Using AUDIO\_CLK requires the setting of the control register of the corresponding port. ## **16.4** Operation Description ### 16.4.1 Bus Format The SSI module can operate as a transmitter or a receiver and can be configured into many serial bus formats in either mode. The bus format can be selected from one of the modes shown in table 16.4. **Table 16.4 Bus Format for SSI Module** | TRMD 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Non-Compressed<br>Slave Receiver | Non-Compressed<br>Slave Transmitter | Non-Compressed<br>Master Receiver | Non-Compressed<br>Master<br>Transmitter | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------|-------------------------------------|-----------------------------------|-----------------------------------------| | SCKD 0 0 1 1 SWSD 0 0 1 1 EN Control Bits MUEN DIEN UIEN OIEN UIEN DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] DWL[2:0] | TRMD | 0 | 1 | 0 | 1 | | SWSD 0 0 1 1 EN Control Bits MUEN DIEN UIEN DIEN UIEN DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] DWL[2:0] | CPEN | 0 | 0 | 0 | 0 | | EN Control Bits MUEN DIEN IIEN OIEN UIEN DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | SCKD | 0 | 0 | 1 | 1 | | MUEN DIEN IIEN OIEN UIEN DEL PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | SWSD | 0 | 0 | 1 | 1 | | DIEN IIEN OIEN UIEN DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | EN | Control Bits | | | | | IIEN | MUEN | - | | | | | OIEN UIEN DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | DIEN | - | | | | | UIEN DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | IIEN | - | | | | | DEL Configuration Bits PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | OIEN | _ | | | | | PDTA SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | UIEN | | | | | | SDTA SPDP SWSP SCKP SWL[2:0] DWL[2:0] | DEL | Configuration Bits | | | | | SPDP SWSP SCKP SWL[2:0] DWL[2:0] | PDTA | - | | | | | SWSP SCKP SWL[2:0] DWL[2:0] | SDTA | - | | | | | SCKP SWL[2:0] DWL[2:0] | SPDP | - | | | | | SWL[2:0] DWL[2:0] | SWSP | <del>-</del> | | | | | DWL[2:0] | SCKP | <del>-</del> | | | | | | SWL[2:0] | <del>-</del> | | | | | CHNL[1:0] | DWL[2:0] | _ | | | | | | CHNL[1:0] | - | | | | #### 16.4.2 **Non-Compressed Modes** The non-compressed modes support all serial audio streams split into channels. It supports Philips, Sony and Matsushita modes as well as many more variants on these modes. #### Slave Receiver **(1)** This mode allows the module to receive serial data from another device. The clock and word select signal used for the serial data stream is also supplied from an external device. If these signals do not conform to the format specified in the configuration fields of the SSI module, operation is not guaranteed. #### **(2)** Slave Transmitter This mode allows the module to transmit serial data to another device. The clock and word select signal used for the serial data stream is also supplied from an external device. If these signals do not conform to the format specified in the configuration fields of the SSI module, operation is not guaranteed. #### Master Receiver **(3)** This mode allows the module to receive serial data from another device. The clock and word select signals are internally derived from the oversampling clock. The format of these signals is defined in the configuration fields of the SSI module. If the incoming data does not follow the configured format, operation is not guaranteed. #### **Master Transmitter (4)** This mode allows the module to transmit serial data to another device. The clock and word select signals are internally derived from the oversampling clock. The format of these signals is defined in the configuration fields of the SSI module. #### **(5) Operating Setting Related to Word Length** All bits related to the SSICR's word length are valid in non-compressed modes. There are many configurations the SSI module supports, but some of the combinations are shown below for the popular formats by Philips, Sony, and Matsushita. ### · Philips Format Figures 16.3 and 16.4 demonstrate the supported Philips format both with and without padding. Padding occurs when the data word length is smaller than the system word length. Figure 16.3 Philips Format (without Padding) Figure 16.4 Philips Format (with Padding) Figure 16.5 shows Sony format and figure 16.6 shows Matsushita format. Padding is assumed in both cases, but may not be present in a final implementation if the system word length equals the data word length. ### Sony Format Figure 16.5 Sony Format (Transmitted and received in the order of padding bits and serial data) ### Matsushita Format Figure 16.6 Matsushita Format (Transmitted and received in the order of serial data and padding bits) ### (6) Multi-channel Formats Padding Bits Some devices extend the definition of the specification by Philips and allow more than 2 channels to be transferred within two system words. The SSI module supports the transfer of 4, 6 and 8 channels by using the CHNL, SWL and DWL bits only when the system word length (SWL) is greater than or equal to the data word length (DWL) multiplied by channels (CHNL). Table 16.5 shows the number of padding bits for each of the valid setting. If setting is not valid, "—" is indicated instead of a number. Table 16.5 The Number of Padding Bits for Each Valid Setting | Padding Bits Per System Word | | | DWL[2:0] | 000 | 001 | 010 | 011 | 100 | 101 | 110 | |------------------------------|----------------------------------------------|--------------|---------------------------|-----|-----|-----|-----|-----|-----|-----| | CHNL<br>[1:0] | Decoded<br>Channels<br>per<br>System<br>Word | SWL<br>[2:0] | Decoded<br>Word<br>Length | 8 | 16 | 18 | 20 | 22 | 24 | 32 | | 00 | 1 | 000 | 8 | 0 | _ | _ | _ | _ | _ | _ | | | | 001 | 16 | 8 | 0 | _ | _ | _ | _ | _ | | | | 010 | 24 | 16 | 8 | 6 | 4 | 2 | 0 | _ | | | | 011 | 32 | 24 | 16 | 14 | 12 | 10 | 8 | 0 | | | | 100 | 48 | 40 | 32 | 30 | 28 | 26 | 24 | 16 | | | | 101 | 64 | 56 | 48 | 46 | 44 | 42 | 40 | 32 | | | | 110 | 128 | 120 | 112 | 110 | 108 | 106 | 104 | 96 | | | | 111 | 256 | 248 | 240 | 238 | 236 | 234 | 232 | 224 | | 01 | 2 | 000 | 8 | _ | _ | _ | _ | _ | _ | _ | | | | 001 | 16 | 0 | _ | _ | _ | _ | _ | _ | | | | 010 | 24 | 8 | _ | _ | _ | _ | _ | _ | | | | 011 | 32 | 16 | 0 | _ | _ | _ | _ | _ | | | | 100 | 48 | 32 | 16 | 12 | 8 | 4 | 0 | | | | | 101 | 64 | 48 | 32 | 28 | 24 | 20 | 16 | 0 | | | | 110 | 128 | 112 | 96 | 92 | 88 | 84 | 80 | 64 | | | | 111 | 256 | 240 | 224 | 220 | 216 | 212 | 208 | 192 | | | g Bits Per S | ystem | | | | | | | | | |------|----------------------------------------------|--------------|---------------------------|-----|-----|-----|-----|-----|-----|--------------| | Word | | | DWL[2:0] | 000 | 001 | 010 | 011 | 100 | 101 | 110 | | CHNL | Decoded<br>Channels<br>per<br>System<br>Word | SWL<br>[2:0] | Decoded<br>Word<br>Length | 8 | 16 | 18 | 20 | 22 | 24 | 32 | | 10 | 3 | 000 | 8 | | | | | | | <del>_</del> | | 10 | O | 001 | 16 | | | | | | | | | | | | | | _ | _ | _ | _ | _ | | | | | 010 | 24 | 0 | _ | _ | _ | _ | _ | | | | | 011 | 32 | 8 | _ | _ | _ | _ | _ | | | | | 100 | 48 | 24 | 0 | — | — | _ | _ | | | | | 101 | 64 | 40 | 16 | 10 | 4 | _ | _ | _ | | | | 110 | 128 | 104 | 80 | 74 | 68 | 62 | 56 | 32 | | | | 111 | 256 | 232 | 208 | 202 | 196 | 190 | 184 | 160 | | 11 | 4 | 000 | 8 | _ | _ | _ | _ | _ | _ | _ | | | | 001 | 16 | _ | _ | _ | _ | _ | _ | _ | | | | 010 | 24 | _ | _ | _ | _ | _ | _ | _ | | | | 011 | 32 | 0 | _ | _ | _ | _ | _ | _ | | | | 100 | 48 | 16 | _ | _ | _ | _ | | _ | | | | 101 | 64 | 32 | 0 | | | _ | | _ | | | | 110 | 128 | 96 | 64 | 56 | 48 | 40 | 32 | 0 | | | | 111 | 256 | 224 | 192 | 184 | 176 | 168 | 160 | 128 | | | - | | | | | | | | | | When the SSI module acts as a transmitter, each word written to SSITDR is transmitted to the serial audio bus in the order they are written. When the SSI module acts as a receiver, each word received by the serial audio bus is read in the order received from the SSIRDR register. Figures 16.7 to 16.9 show how 4, 6 and 8 channels are transferred to the serial audio bus. Note that there are no padding bits in the first example, the second example is left-aligned and the third is right-aligned. This selection is arbitrary and is just for demonstration purposes only. Figure 16.7 Multi-Channel Format (4 Channels Without Padding) Figure 16.8 Multi-Channel Format (6 Channels with High Padding) Figure 16.9 Multi-Channel Format (8 Channels; Transmitting and Receiving in the Order of Serial Data and Padding Bits; with Padding) ### (7) Bit Setting Configuration Format Several more configuration bits in non-compressed mode are shown below. These bits are not mutually exclusive, but some combinations may not be useful for any other device. These configuration bits are described below with reference to figure 16.10. Figure 16.10 Basic Sample Format (Transmit Mode with Example System/Data Word Length) Figure 16.10 uses a system word length of 6 bits and a data word length of 4 bits. These settings are not possible with the SSI module but are used only for clarification of the other configuration bits. ### Inverted Clock Figure 16.11 Inverted Clock ### Inverted Word Select Figure 16.12 Inverted Word Select ## • Inverted Padding Polarity Figure 16.13 Inverted Padding Polarity • Transmitting and Receiving in the Order of Serial Data and Padding Bits; with Delay Figure 16.14 Transmitting and Receiving in the Order of Serial Data and Padding Bits; with Delay Transmitting and Receiving in the Order of Serial Data and Padding Bits; without Delay Figure 16.15 Transmitting and Receiving in the Order of Serial Data and Padding Bits; without Delay Transmitting and Receiving in the Order of Padding Bits and Serial Data; without Delay Figure 16.16 Transmitting and Receiving in the Order of Padding Bits and Serial Data; without Delay ## • Parallel Right-Aligned with Delay Figure 16.17 Parallel Right-Aligned with Delay ### Mute Enabled Figure 16.18 Mute Enabled #### 16.4.3 **Operation Modes** There are three modes of operation: configuration, enabled and disabled. Figure 16.19 shows how the module enters each of these modes. Figure 16.19 Operation Modes #### **Configuration Mode (1)** This mode is entered after the module is released from reset. All required configuration fields in the control register should be defined in this mode, before the SSI module is enabled by setting the EN bit. Setting the EN bit causes the module to enter the module enabled mode. #### **(2) Module Enabled Mode** Operation of the module in this mode is dependent on the operation mode selected. For details, refer to section 16.4.4, Transmit Operation and section 16.4.5, Receive Operation, below. ### 16.4.4 Transmit Operation Page 620 of 1278 Transmission can be controlled either by DMA or interrupt. DMA control is preferred to reduce the processor load. In DMA control mode the processor will only receive interrupts if there is an underflow or overflow of data or the DMAC has finished its transfer. The alternative method is using the interrupts that the SSI module generates to supply data as required. This mode has a higher interrupt load as the module is only double buffered and will require data to be written at least every system word period. When disabling the module, the SSI clock\* must remain present until the SSI module is in idle state, indicated by the IIRQ bit. Figure 16.20 shows the transmit operation in DMA control mode, and figure 16.21 shows the transmit operation in interrupt control mode. Note: \* Input clock from the SSISCK pin when SCKD = 0. Input clock from the AUDIO\_CLK pin when SCKD = 1. ## (1) Transmission Using DMA Controller Figure 16.20 Transmission Using DMA Controller ## (2) Transmission Using Interrupt Data Flow Control Figure 16.21 Transmission Using Interrupt Data Flow Control #### 16.4.5 **Receive Operation** Like transmission, reception can be controlled either by DMA or interrupt. Figures 16.22 and 16.23 show the flow of operation. When disabling the SSI module, the SSI clock\* must be kept supplied until the IIRQ bit is in idle state. Input clock from the SSISCK pin when SCKD = 0. Note: \* Input clock from the AUDIO\_CLK pin when SCKD = 1. ### (1) Reception Using DMA Controller Figure 16.22 Reception Using DMA Controller ### (2) Reception Using Interrupt Data Flow Control Figure 16.23 Reception Using Interrupt Data Flow Control When an underflow or overflow error condition has matched, the CHNO[1:0] bits and the SWNO bit can be used to recover the SSI module to a known status. When an underflow or overflow occurs, the host can read the channel number and system word number to determine what point the serial audio stream has reached. In the transmitter case, the host can skip forward through the data it wants to transmit until it finds the sample data that matches what the SSI module is expecting to transmit next, and so resynchronize with the audio data stream. In the receiver case the host CPU can store null data to make the number of receive data items consistent until it is ready to store the sample data that the SSI module is indicating will be received next, and so resynchronize with the audio data stream. #### 16.4.6 Temporary Stop and Restart Procedures in Transmit Mode The following procedures can be used for implementation. # (1) Procedure for the transfer and stop without having to reconfigure the bus bridge (BBG)/DMAC - 1. Set SSICR.DMEN = 0 (disabling a DMA request) to stop the DMA transfer. - 2. Wait for SSISR.DIRQ = 1 (transmit mode: the transmit buffer is empty) using a polling, interrupt, or the like. - 3. With SSICR.EN = 0 (disabling an SSI module operation), stop the transfer. - 4. Before attempting another transfer, make sure that SSISR.IDST = 1 is reached. - 5. Set SSICR.EN = 1 (enabling an SSI module operation). - 6. Wait for SSISR.DIRQ = 1, using a polling, interrupt, or the like. - 7. Setting SSICR.DMEN = 1 (enabling a DMA request) will restart the DMA transfer. # (2) Procedure for Reconfiguring the BBG/DMAC after an SSI stop - 1. Set SSICR.DMEN = 0 (disabling a DMA request) to stop the DMA transfer. - 2. Wait for SSISR.DIRQ = 1 (transmit mode: the transmit buffer is empty), using a polling, interrupt, or the like. - 3. With SSICR.EN = 0 (disabling an SSI module operation), stop the transfer. - 4. Bring the DMAC to a forced stop with the DSTPR of BBG/DMAC. - 5. Before attempting another transfer, make sure that SSISR.IDST = 1 is reached. - 6. Set SSICR.EN = 1 (enabling an SSI module operation). - 7. Set the BBG/DMAC registers and start the transfer. - 8. Setting SSICR.DMEN = 1 (enabling a DMA request) will restart the DMA transfer. #### 16.4.7 Serial Bit Clock Control This function is used to control and select which clock is used for the serial bus interface. If the serial clock direction is set to input (SCKD = 0), the SSI module is in clock slave mode and the shift register uses the bit clock that was input to the SSISCK pin. If the serial clock direction is set to output (SCKD = 1), the SSI module is in clock master mode, and the shift register uses the bit clock that was input from the AUDIO\_CLK pin, or the bit clock that is generated by dividing them. This input clock is then divided by the ratio in the serial oversampling clock divide ratio (CKDV) in SSICR and used as the bit clock in the shift register. In either case the module pin, SSISCK, is the same as the bit clock. ## 16.5 Usage Notes ### 16.5.1 Limitations from Overflow during Receive DMA Operation If an overflow occurs while the receive DMA is in operation, the module should be restarted. The receive buffer in the SSI consists of 32-bit registers that share the L and R channels. Therefore, data to be received at the L channel may sometimes be received at the R channel if an overflow occurs, for example, under the following condition: the control register (SSICR) has a 32-bit setting for both data word length (DWL2 to DWL0) and system word length (SWL2 to SWL). If an overflow is confirmed with the overflow error interrupt or overflow error status flag (the OIRQ bit in SSISR), write 0 to the EN bit in SSICR and DMEN bit to disable DMA in the SSI module, thus stopping the operation. (In this case, the controller setting should also be stopped.) After this, write 0 to the OIRQ bit to clear the overflow status, set DMA again and restart the transfer. # Section 17 USB 2.0 Host/Function Module (USB) The USB 2.0 host/function module (USB) is a USB controller which provides capabilities as a USB host controller and USB function controller function. This module supports high-speed transfer defined by USB (universal serial bus) Specification 2.0, full-speed transfer, and low-speed transfer when used as the host controller, and supports high-speed transfer and full-speed transfer when used as the function controller. This module has a USB transceiver and supports all of the transfer types defined by the USB specification. This module has an 8-Kbyte buffer memory for data transfer, providing a maximum of ten pipes. Any endpoint numbers can be assigned to PIPE1 to PIPE9, based on the peripheral devices or user system for communication. #### 17.1 **Features** #### Host Controller and Function Controller Supporting USB High-Speed Operation (1) - The USB host controller and USB function controller are incorporated. - The USB host controller and USB function controller can be switched by register settings. - USB transceiver is incorporated. #### Reduced Number of External Pins and Space-Saving Installation **(2)** - The VBUS signal can be directly connected to the input pin of this module. - On-chip D+ pull-up resistor (during USB function operation) - On-chip D+ and D- pull-down resistor (during USB host operation) - On-chip D+ and D- terminal resistor (during high-speed operation) - On-chip D+ and D- output impedance (during full-speed operation) #### **(3)** All Types of USB Transfers Supported - Control transfer - Bulk transfer - Interrupt transfer (high bandwidth transfers not supported) - Isochronous transfer (high bandwidth transfers not supported) #### (4) Internal Bus Interfaces • Two DMA interface channels are incorporated. ### (5) Pipe Configuration - Up to 8 Kbytes of buffer memory for USB communications are supported - Up to ten pipes can be selected (including the default control pipe) - Programmable pipe configuration - Endpoint numbers can be assigned flexibly to PIPE1 to PIPE9. - Transfer conditions that can be set for each pipe: PIPE0: Control transfer (default control pipe: DCP), 64-byte fixed single buffer PIPE1 and PIPE2: Bulk transfers/isochronous transfer, continuous transfer mode, programmable buffer size (up to 2 Kbytes: double buffer can be specified) PIPE3 to PIPE5: Bulk transfer, continuous transfer mode, programmable buffer size (up to 2 Kbytes: double buffer can be specified) PIPE6 to PIPE9: Interrupt transfer, 64-byte fixed single buffer #### (6) Features of the USB Host Controller - High-speed transfer (480 Mbps), full-speed transfer (12 Mbps), and low-speed transfer (1.5 Mbps) are supported. - Communications with multiple peripheral devices connected via a single HUB - · Automatic response to the reset handshake - Automatic scheduling for SOF and packet transmissions - Programmable intervals for isochronous and interrupt transfers #### **Features of the USB Function Controller (7)** - Both high-speed transfer (480 Mbps) and full-speed transfer (12 Mbps) are supported. - Automatic recognition of high-speed operation or full-speed operation based on automatic response to the reset handshake - Control transfer stage control function - Device state control function - Auto response function for SET\_ADDRESS request - NAK response interrupt function (NRDY) - SOF interpolation function #### (8) **Other Features** - Transfer ending function using transaction count - BRDY interrupt event notification timing change function (BFRE) - Function that automatically clears the buffer memory after the data for the pipe specified at the DnFIFO (n = 0 or 1) port has been read (DCLRM) - NAK setting function for response PID generated by end of transfer (SHTNAK) # 17.2 Input / Output Pins Table 17.1 shows the pin configuration of the USB. **Table 17.1 USB Pin Configuration** | Pin Name | Name | I/O | Function | |----------|--------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DP | USB D+ data | I/O | D+ I/O of the USB on-chip transceiver | | DM | USB D- data | I/O | D- I/O of the USB on-chip transceiver | | | | | This pin should be connected to the D- pin of the USB bus. | | VBUS | VBUS input | Input | USB cable connection monitor pin | | | | | This pin should be connected directly to the VBUS of the USB bus. Whether the VBUS is connected or disconnected can be detected. | | | | | If this pin is not connected with the VBUS of the USB bus, it should be supplied with 5 V. It should be supplied with 5 V also when the host controller function is selected. | | REFRIN | Reference input | Input | Reference resistor connection pin | | | | | This pin should be connected to AG33 through a 5.6 k $\Omega$ ±1% resistor. | | USB_X1 | Crystal input output pin | Input | These pins should be connected to crystal oscillators for the USB. The EXTAL_USB pin can be used for external clock input. | | USB_X2 | _ (Clock input pin) | Output | These pins should be connected to crystal oscillators for the USB. | | AV33 | USB analog 3.3 V power supply | _ | Power supply for transceiver block core | | AG33 | USB analog<br>ground | _ | Ground for transceiver block core | | DV33 | USB digital 3.3 V power supply | _ | Power supply for transceiver block pins | | DG33 | USB digital<br>ground | _ | Ground for transceiver block pins | | AV12 | USB analog 1.2 V power supply | _ | Power supply for transceiver block core | | AG12 | USB analog<br>ground | _ | Ground for transceiver block core | | Pin Name | Name | I/O | Function | |----------|-----------------------------------|-----|-----------------------------------------------| | DV12 | USB digital 1.2 V power supply | _ | Power supply for transceiver block pins | | DG12 | USB digital ground | _ | Ground for transceiver block pins | | UV12 | USB 480 MHz 1.2 V<br>power supply | _ | Power supply for 480-MHz operation block core | | UG12 | USB 480 MHz 1.2 V<br>ground | | Ground for 480-MHz operation block core | # 17.3 Register Description Table 17.2 shows the register configuration of the USB. Table 17.3 shows the register state in each processing mode. **Table 17.2 Register Configuration** | System configuration control register BUSWAIT R/W H'FFFF F802 16 System configuration status register SYSSTS R H'FFFF F804 16 Device state control register DVSTCTR R/W H'FFFF F808 16 Test mode register TESTMODE R/W H'FFFF F810 16 F80C DMA0-FIFO bus configuration D0FBCFG R/W H'FFFF F810 16 register DMA1-FIFO bus configuration P1FBCFG R/W H'FFFF F812 16 register CFIFO port register CFIFO R/W H'FFFF F812 16 CFIFO port select register CFIFOSEL R/W H'FFFF F822 16 D0FIFO port select register D0FIFOSEL R/W H'FFFF F828 16 D0FIFO port control register D0FIFOSEL R/W H'FFFF F824 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F825 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F826 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F826 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F826 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F832 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F832 16 D1FIFO port control register D1FIFOSEL R/W H'FFFF F836 16 RRDY interrupt enable register BRDYENB R/W H'FFFF F838 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F838 16 SOF output configuration register BEMPENB R/W H'FFFF F830 16 SOF output configuration register BEMPENB R/W H'FFFF F830 16 SOF output configuration register SOFCFG R/W H'FFFF F830 16 Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 Interrupt status register 1 INTSTS1 R/W H'FFFF F842 16 | Register Name | Abbreviation | R/W | Address | Access<br>Size | Connection bus | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------|-----|-------------|----------------|----------------| | System configuration status register SYSSTS R H'FFFF F804 16 Device state control register DVSTCTR R/W H'FFFF F808 16 Test mode register TESTMODE R/W H'FFFF F806 16 DMA0-FIFO bus configuration D0FBCFG R/W H'FFFF F810 16 register DMA1-FIFO bus configuration register CFIFO DMA1-FIFO | | SYSCFG | R/W | H'FFFF F800 | 16 | • | | Device state control register Test mode register TESTMODE R/W H'FFFF 16 F80C DMA0-FIFO bus configuration register DMA1-FIFO bus configuration register CFIFO port register CFIFO port select register CFIFO port control register CFIFO port select register D0FIFO port select register D0FIFO port select register D0FIFO port select register D0FIFO port select register D0FIFO port select register D0FIFO port control register D0FIFO Port control register D1FIFO Port select register D1FIFO Port select register D1FIFO Port select register D1FIFO Port select register D1FIFO Port select register D1FIFO Port select register D1FIFOSEL R/W H'FFFF F82A 16 D1FIFO PORT SELECT REGISTER D1FIFOSEL R/W H'FFFF F82A 16 D1FIFO PORT SELECT REGISTER D1FIFO PORT SELECT REGISTER D1FIFOSEL R/W H'FFFF F82B 16 RESCC D1FIFO PORT SELECT REGISTER D1FIFOSEL R/W H'FFFF F83A 16 RESCC D1FIFO PORT SELECT REGISTER D1FIFOSEL R/W H'FFFF F83A 16 REDY interrupt enable register RRDYENB R/W H'FFFF F83A 16 RRDY interrupt enable register RRDYENB R/W H'FFFF F83A 16 RRDY interrupt enable register RRDYENB R/W H'FFFF F83A 16 | CPU bus wait setting register | BUSWAIT | R/W | H'FFFF F802 | 16 | <u>-</u> | | Test mode register TESTMODE R/W H'FFFF 16 F80C DMA0-FIFO bus configuration register DMA1-FIFO bus configuration register CFIFO port register CFIFO port register CFIFO port select register CFIFO port select register CFIFOCTR B/W H'FFFF F820 DOFIFO port control register DOFIFO port select register DOFIFO port select register DOFIFO port select register DOFIFO port select register DOFIFO port control register DIFIFOSEL R/W H'FFFF F820 16 DOFIFO port select register DOFIFOCTR R/W H'FFFF F820 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF F820 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF F820 16 Interrupt enable register D1FIFOCTR R/W H'FFFF F830 16 Interrupt enable register 1 INTENB0 R/W H'FFFF F830 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F830 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F830 16 SOF output configuration register SOFCG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | System configuration status register | SYSSTS | R | H'FFFF F804 | 16 | | | DMA0-FIFO bus configuration register DMA1-FIFO bus configuration pregister DMA1-FIFO bus configuration register CFIFO port register CFIFO port select register CFIFO port control register CFIFO port select register CFIFO port select register CFIFO port select register CFIFO port select register D0FIFO port select register D0FIFO port select register D0FIFO port select register D0FIFO port control register D0FIFO port control register D1FIFOSEL R/W H'FFFF F822 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF 16 F82C D1FIFO port control register D1FIFOCTR R/W H'FFFF 16 F82C D1FIFO port control register D1FIFOCTR R/W H'FFFF F830 16 Interrupt enable register 1 INTENB0 R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF F840 16 | Device state control register | DVSTCTR | R/W | H'FFFF F808 | 16 | | | DMA1-FIFO bus configuration register CFIFO port register CFIFO port select register CFIFO port select register CFIFO port select register CFIFO port select register CFIFOCTR D0FIFO port select register D0FIFOSEL D0FIFO port control register D0FIFO port control register D0FIFOSEL D0FIFO port select register D0FIFOSEL R/W H'FFFF F828 16 D0FIFO port select register D1FIFOSEL R/W H'FFFF F82A D1FIFO port select register D1FIFOSEL R/W H'FFFF F82B 16 D1FIFO port control register D1FIFOCTR R/W H'FFFF F82E 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F83A 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF F840 16 | Test mode register | TESTMODE | R/W | | 16 | | | CFIFO port register CFIFO port select register CFIFO port select register CFIFOSEL R/W CFIFO port select register CFIFOCTR R/W CFIFF F820 CFIFOCTR | | D0FBCFG | R/W | H'FFFF F810 | 16 | | | CFIFO port select register CFIFOSEL R/W H'FFFF F820 16 CFIFO port control register CFIFOCTR R/W H'FFFF F822 16 DOFIFO port select register DOFIFOSEL R/W H'FFFF F828 16 DOFIFO port control register DOFIFOCTR R/W H'FFFF F82A 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF F82A 16 D1FIFO port control register D1FIFOCTR R/W H'FFFF 16 F82C D1FIFO port control register D1FIFOCTR R/W H'FFFF F830 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register BRDYENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF F840 16 Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | | D1FBCFG | R/W | H'FFFF F812 | 16 | | | CFIFO port control register CFIFOCTR R/W H'FFFF F822 16 D0FIFO port select register D0FIFOSEL R/W H'FFFF F828 16 D0FIFO port control register D0FIFOCTR R/W H'FFFF F82A 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF 16 F82C D1FIFO port control register D1FIFOCTR R/W H'FFFF F82E 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F83A 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | CFIFO port register | CFIFO | R/W | H'FFFF F814 | 8/16/32 | <u>-</u> | | D0FIFO port select register D0FIFOSEL R/W H'FFFF F828 16 D0FIFO port control register D1FIFO port select register D1FIFOSEL R/W H'FFFF F82A 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF 16 F82C D1FIFO port control register D1FIFOCTR R/W H'FFFF F82E 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F83A 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTS0 R/W H'FFFF F840 16 | CFIFO port select register | CFIFOSEL | R/W | H'FFFF F820 | 16 | <u>-</u> | | D0FIFO port control register D1FIFOSEL R/W H'FFFF F82A 16 D1FIFO port select register D1FIFOSEL R/W H'FFFF F82E 16 D1FIFO port control register D1FIFOCTR R/W H'FFFF F82E 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F83A 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | CFIFO port control register | CFIFOCTR | R/W | H'FFFF F822 | 16 | _ | | D1FIFO port select register D1FIFOSEL R/W H'FFFF 16 F82C D1FIFO port control register D1FIFOCTR R/W H'FFFF F82E 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F838 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | D0FIFO port select register | D0FIFOSEL | R/W | H'FFFF F828 | 16 | - | | D1FIFO port control register D1FIFOCTR R/W H'FFFF F82E 16 Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F838 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | D0FIFO port control register | D0FIFOCTR | R/W | H'FFFF F82A | 16 | | | Interrupt enable register 0 INTENB0 R/W H'FFFF F830 16 Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F838 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | D1FIFO port select register | D1FIFOSEL | R/W | | 16 | | | Interrupt enable register 1 INTENB1 R/W H'FFFF F832 16 BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F838 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | D1FIFO port control register | D1FIFOCTR | R/W | H'FFFF F82E | 16 | | | BRDY interrupt enable register BRDYENB R/W H'FFFF F836 16 NRDY interrupt enable register NRDYENB R/W H'FFFF F838 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTSO R/W H'FFFF F840 16 | Interrupt enable register 0 | INTENB0 | R/W | H'FFFF F830 | 16 | _ | | NRDY interrupt enable register NRDYENB R/W H'FFFF F838 16 BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF F840 16 | Interrupt enable register 1 | INTENB1 | R/W | H'FFFF F832 | 16 | | | BEMP interrupt enable register BEMPENB R/W H'FFFF F83A 16 SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTS0 R/W H'FFFF F840 16 | BRDY interrupt enable register | BRDYENB | R/W | H'FFFF F836 | 16 | - | | SOF output configuration register SOFCFG R/W H'FFFF 16 F83C Interrupt status register 0 INTSTS0 R/W H'FFFF F840 16 | NRDY interrupt enable register | NRDYENB | R/W | H'FFFF F838 | 16 | _ | | F83C Interrupt status register 0 INTSTS0 R/W H'FFFF F840 16 | BEMP interrupt enable register | BEMPENB | R/W | H'FFFF F83A | 16 | | | | SOF output configuration register | SOFCFG | R/W | | 16 | | | Interrupt status register 1 INTSTS1 R/W H'FFFF F842 16 | Interrupt status register 0 | INTSTS0 | R/W | H'FFFF F840 | 16 | _ | | | Interrupt status register 1 | INTSTS1 | R/W | H'FFFF F842 | 16 | -,- | | Register Name | Abbreviation | R/W | Address | Access<br>Size | Connection bus | |--------------------------------------------|--------------|-----|----------------|----------------|----------------| | BRDY interrupt status register | BRDYSTS | R/W | H'FFFF F846 | 16 | Peripheral | | NRDY interrupt status register | NRDYSTS | R/W | H'FFFF F848 | 16 | bus | | BEMP interrupt status register | BEMPSTS | R/W | H'FFFF F84A | 16 | - | | Frame number register | FRMNUM | R/W | H'FFFF<br>F84C | 16 | <del>-</del> | | μFrame number register | UFRMNUM | R/W | H'FFFF F84E | 16 | _ | | USB address register | USBADDR | R | H'FFFF F850 | 16 | _ | | USB request type register | USBREQ | R | H'FFFF F854 | 16 | _ | | USB request value register | USBVAL | R | H'FFFF F856 | 16 | _ | | USB request index register | USBINDX | R | H'FFFF F858 | 16 | _ | | USB request length register | USBLENG | R | H'FFFF F85A | 16 | _ | | DCP configuration register | DCPCFG | R/W | H'FFFF<br>F85C | 16 | _ | | DCP maximum packet size register | DCPMAXP | R/W | H'FFFF F85E | 16 | _ | | DCP control register | DCPCTR | R/W | H'FFFF F860 | 16 | _ | | Pipe window select register | PIPESEL | R/W | H'FFFF F864 | 16 | - | | Pipe configuration register | PIPECFG | R/W | H'FFFF F868 | 16 | _ | | Pipe buffer setting register | PIPEBUF | R/W | H'FFFF F86A | 16 | - | | Pipe maximum packet size register | PIPEMAXP | R/W | H'FFFF<br>F86C | 16 | _ | | Pipe cycle control register | PIPEPERI | R/W | H'FFFF F86E | 16 | _ | | Pipe 1 control register | PIPE1CTR | R/W | H'FFFF F870 | 16 | _ | | Pipe 2 control register | PIPE2CTR | R/W | H'FFFF F872 | 16 | _ | | Pipe 3 control register | PIPE3CTR | R/W | H'FFFF F874 | 16 | _ | | Pipe 4 control register | PIPE4CTR | R/W | H'FFFF F876 | 16 | _ | | Pipe 5 control register | PIPE5CTR | R/W | H'FFFF F878 | 16 | _ | | Pipe 6 control register | PIPE6CTR | R/W | H'FFFF F87A | 16 | _ | | Pipe 7 control register | PIPE7CTR | R/W | H'FFFF<br>F87C | 16 | <del>-</del> | | Pipe 8 control register | PIPE8CTR | R/W | H'FFFF F87E | 16 | - | | Pipe 9 control register | PIPE9CTR | R/W | H'FFFF F880 | 16 | - | | Pipe 1 transaction counter enable register | PIPE1TRE | R/W | H'FFFF F890 | 16 | = | | Register Name | Abbreviation | R/W | Address | Access<br>Size | Connection bus | |--------------------------------------------|--------------|-----|-------------|----------------|----------------| | Pipe 1 transaction counter register | PIPE1TRN | R/W | H'FFFF F892 | 16 | Peripheral | | Pipe 2 transaction counter enable register | PIPE2TRE | R/W | H'FFFF F894 | 16 | bus | | Pipe 2 transaction counter register | PIPE2TRN | R/W | H'FFFF F896 | 16 | _ | | Pipe 3 transaction counter enable register | PIPE3TRE | R/W | H'FFFF F898 | 16 | - | | Pipe 3 transaction counter register | PIPE3TRN | R/W | H'FFFF F89A | 16 | _ | | Pipe 4 transaction counter enable register | PIPE4TRE | R/W | H'FFFF F89C | 16 | _ | | Pipe 4 transaction counter register | PIPE4TRN | R/W | H'FFFF F89E | 16 | _ | | Pipe 5 transaction counter enable register | PIPE5TRE | R/W | H'FFFF F8A0 | 16 | _ | | Pipe 5 transaction counter register | PIPE5TRN | R/W | H'FFFF F8A2 | 16 | _ | | Device address 0 configuration register | DEVADD0 | R/W | H'FFFF F8D0 | 16 | - | | Device address 1 configuration register | DEVADD1 | R/W | H'FFFF F8D2 | 16 | _ | | Device address 2 configuration register | DEVADD2 | R/W | H'FFFF F8D4 | 16 | _ | | Device address 3 configuration register | DEVADD3 | R/W | H'FFFF F8D6 | 16 | - | | Device address 4 configuration register | DEVADD4 | R/W | H'FFFF F8D8 | 16 | _ | | Device address 5 configuration register | DEVADD5 | R/W | H'FFFF F8DA | 16 | - | | Device address 6 configuration register | DEVADD6 | R/W | H'FFFF F8DC | 16 | _ | | Device address 7 configuration register | DEVADD7 | R/W | H'FFFF F8DE | 16 | _ | | Device address 8 configuration register | DEVADD8 | R/W | H'FFFF F8E0 | 16 | _ | | Device address 9 configuration register | DEVADD9 | R/W | H'FFFF F8E2 | 16 | _ | | Device address A configuration register | DEVADDA | R/W | H'FFFF F8E4 | 16 | | | | | | | • | | | Register Name | Abbreviation | R/W | Address | Access<br>Size | Connection bus | |----------------------------------|--------------|-----|-------------|----------------|----------------| | D0FIFO bus wait setting register | D0FWAIT | R/W | H'FFFC 1C0C | 16 | Internal bus | | D1FIFO bus wait setting register | D1FWAIT | R/W | H'FFFC 1C0E | 16 | <del>-</del> | | D0FIFO port register | D0FIFO | R/W | H'FFFC 1C14 | 32 | <del>-</del> | | D1FIFO port register | D1FIFO | R/W | H'FFFC 1C18 | 32 | | **Table 17.3** Register State in Each Processing Mode | Register<br>Abbreviation | Power-On Reset | Software<br>Standby | Module Standby | Sleep | |--------------------------|----------------|---------------------|----------------|----------| | SYSCFG | Initialized | Retained | Retained | Retained | | BUSWAIT | Initialized | Retained | Retained | Retained | | SYSSTS | Initialized | Retained | Retained | Retained | | DVSTCTR | Initialized | Retained | Retained | Retained | | TESTMODE | Initialized | Retained | Retained | Retained | | D0FBCFG | Initialized | Retained | Retained | Retained | | D1FBCFG | Initialized | Retained | Retained | Retained | | CFIFO | Initialized | Retained | Retained | Retained | | D0FIFO | Initialized | Retained | Retained | Retained | | D1FIFO | Initialized | Retained | Retained | Retained | | CFIFOSEL | Initialized | Retained | Retained | Retained | | CFIFOCTR | Initialized | Retained | Retained | Retained | | D0FIFOSEL | Initialized | Retained | Retained | Retained | | D0FIFOCTR | Initialized | Retained | Retained | Retained | | D1FIFOSEL | Initialized | Retained | Retained | Retained | | D1FIFOCTR | Initialized | Retained | Retained | Retained | | INTENB0 | Initialized | Retained | Retained | Retained | | INTENB1 | Initialized | Retained | Retained | Retained | | BRDYENB | Initialized | Retained | Retained | Retained | | NRDYENB | Initialized | Retained | Retained | Retained | | BEMPENB | Initialized | Retained | Retained | Retained | | SOFCFG | Initialized | Retained | Retained | Retained | | INTSTS0 | Initialized | Retained | Retained | Retained | | INTSTS1 | Initialized | Retained | Retained | Retained | | BRDYSTS | Initialized | Retained | Retained | Retained | | NRDYSTS | Initialized | Retained | Retained | Retained | | BEMPSTS | Initialized | Retained | Retained | Retained | | FRMNUM | Initialized | Retained | Retained | Retained | | UFRMNUM | Initialized | Retained | Retained | Retained | | Register<br>Abbreviation | Power-On Reset | Software<br>Standby | Module Standby | Sleep | |--------------------------|----------------|---------------------|----------------|----------| | USBADDR | Initialized | Retained | Retained | Retained | | USBREQ | Initialized | Retained | Retained | Retained | | USBVAL | Initialized | Retained | Retained | Retained | | USBINDX | Initialized | Retained | Retained | Retained | | USBLENG | Initialized | Retained | Retained | Retained | | DCPCFG | Initialized | Retained | Retained | Retained | | DCPMAXP | Initialized | Retained | Retained | Retained | | DCPCTR | Initialized | Retained | Retained | Retained | | PIPESEL | Initialized | Retained | Retained | Retained | | PIPECFG | Initialized | Retained | Retained | Retained | | PIPEBUF | Initialized | Retained | Retained | Retained | | PIPEMAXP | Initialized | Retained | Retained | Retained | | PIPEPERI | Initialized | Retained | Retained | Retained | | PIPE1CTR | Initialized | Retained | Retained | Retained | | PIPE2CTR | Initialized | Retained | Retained | Retained | | PIPE3CTR | Initialized | Retained | Retained | Retained | | PIPE4CTR | Initialized | Retained | Retained | Retained | | PIPE5CTR | Initialized | Retained | Retained | Retained | | PIPE6CTR | Initialized | Retained | Retained | Retained | | PIPE7CTR | Initialized | Retained | Retained | Retained | | PIPE8CTR | Initialized | Retained | Retained | Retained | | PIPE9CTR | Initialized | Retained | Retained | Retained | | PIPE1TRE | Initialized | Retained | Retained | Retained | | PIPE1TRN | Initialized | Retained | Retained | Retained | | PIPE2TRE | Initialized | Retained | Retained | Retained | | PIPE2TRN | Initialized | Retained | Retained | Retained | | PIPE3TRE | Initialized | Retained | Retained | Retained | | PIPE3TRN | Initialized | Retained | Retained | Retained | | PIPE4TRE | Initialized | Retained | Retained | Retained | | PIPE4TRN | Initialized | Retained | Retained | Retained | | Register<br>Abbreviation | Power-On Reset | Software<br>Standby | Module Standby | Sleep | |--------------------------|----------------|---------------------|----------------|----------| | PIPE5TRE | Initialized | Retained | Retained | Retained | | PIPE5TRN | Initialized | Retained | Retained | Retained | | PHYTEST0 | Initialized | Retained | Retained | Retained | | PHYTEST1 | Initialized | Retained | Retained | Retained | | DEVADD0 | Initialized | Retained | Retained | Retained | | DEVADD1 | Initialized | Retained | Retained | Retained | | DEVADD2 | Initialized | Retained | Retained | Retained | | DEVADD3 | Initialized | Retained | Retained | Retained | | DEVADD4 | Initialized | Retained | Retained | Retained | | DEVADD5 | Initialized | Retained | Retained | Retained | | DEVADD6 | Initialized | Retained | Retained | Retained | | DEVADD7 | Initialized | Retained | Retained | Retained | | DEVADD8 | Initialized | Retained | Retained | Retained | | DEVADD9 | Initialized | Retained | Retained | Retained | | DEVADDA | Initialized | Retained | Retained | Retained | Jun 21, 2011 ### 17.3.1 System Configuration Control Register (SYSCFG) SYSCFG is a register that enables high-speed operation, selects the host controller function or function controller function, controls the DP and DM pins, and enables operation of this module. This register is initialized by a power-on reset. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|------|---|---|-----|------|------|-------|---|---|---|------| | [ | _ | _ | _ | _ | _ | SCKE | _ | _ | HSE | DCFM | DRPD | DPRPU | _ | _ | _ | USBE | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R | R | R | R | R | R/W | R | R | R/W | R/W | R/W | R/W | R | R | R | R/W | | Bit Name | Initial<br>Value | R/W | Description | |----------|------------------|---------------------------------|-------------------------------------------------------------------------------------------------| | _ | All 0 | R | Reserved | | | | | These bits are always read as 0. The write value should always be 0. | | SCKE | 0 | R/W | USB Module Clock Enable | | | | | Stops or enables supplying 48-MHz clock signal to this module. | | | | | <ol> <li>Stops supplying the clock signal to the USB module.</li> </ol> | | | | | <ol> <li>Enables supplying the clock signal to the USB module.</li> </ol> | | | | | When this bit is 0, only this register and the BUSWAIT register allow both writing and reading. | | _ | All 0 | R | Reserved | | | | | These bits are always read as 0. The write value should always be 0. | | | _ | Bit Name Value — All 0 SCKE 0 | Bit Name Value R/W — All 0 R SCKE 0 R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | HSE | 0 | R/W | High-Speed Operation Enable | | | | | | 0: High-speed operation is disabled | | | | | | When the function controller function is selected: Only full-speed operation is enabled. | | | | | | When the host controller function is selected: Full-speed or low-speed operation is enabled. | | | | | | <ol> <li>High-speed operation is enabled (detected by this module)</li> </ol> | | | | | | (1) When the host controller function is selected | | | | | | When HSE = 0, the USB port performs low-speed or full-speed operation. | | | | | | Set HSE to 0 when connection of a low-speed peripheral device to the USB port has been detected. | | | | | | When HSE = 1, this module executes the reset handshake protocol, and automatically allows the USB port to perform high-speed or full-speed operation according to the protocol execution result. | | | | | | This bit should be modified after detecting device connection (after detecting the ATTCH interrupt) and before executing a USB bus reset (before setting USBRESET to 1). | | | | | | (2) When the function controller function is selected | | | | | | When HSE = 0, this module performs full-speed operation. | | | | | | When HSE = 1, this module executes the reset handshake protocol, and automatically performs high-speed or full-speed operation according to the protocol execution result. | | | | | | This bit should be modified while DPRPU is 0. | | 6 | DCFM | 0 | R/W | Controller Function Select | | | | | | Selects the host controller function or function controller function. | | | | | | 0: Function controller function is selected. | | | | | | 1: Host controller function is selected. | | | | | | This bit should be modified while DPRPU and DPRD are 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | DRPD | 0 | R/W | D+/D- Line Resistor Control | | | | | | Enables or disables pulling down D+ and D- lines when the host controller function is selected. | | | | | | 0: Pulling down the lines is disabled. | | | | | | 1: Pulling down the lines is enabled. | | | | | | This bit should be set to 1 if the host controller function is selected, and should be set to 0 if the function controller function is selected. | | 4 | DPRPU | 0 | R/W | D+ Line Resistor Control | | | | | | Enables or disables pulling up D+ line when the function controller function is selected. | | | | | | 0: Pulling up the line is disabled. | | | | | | 1: Pulling up the line is enabled. | | | | | | Setting this bit to 1 when the function controller function is selected allows this module to pull up the D+ line to 3.3 V, thus notifying the USB host of connection. Modifying this bit from 1 to 0 allows this module to cancel pulling up the D+ line, thus notifying the USB host of disconnection. | | | | | | This bit should be set to 1 if the function controller function is selected, and should be set to 0 if the host controller function is selected. | | 3 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | USBE | 0 | R/W | USB Module Operation Enable | | | | | | Enables or disables operation of this module. | | | | | | 0: USB module operation is disabled. | | | | | | 1: USB module operation is enabled. | | | | | | Modifying this bit from 1 to 0 initializes some register bits as listed in tables 17.4 and 17.5. | | | | | | This bit should be modified while SCKE is 1. | | | | | | When the host controller function is selected, this bit should be set to 1 after setting DPRD to 1, eliminating LNST bit chattering, and checking that the USB bus has been settled. | Table 17.4 Register Bits Initialized by Writing USBE = 0 (when Function Controller Function is Selected) | Register Name | Bit Name | Remarks | |---------------|-------------------------|------------------------------------------------------------------------| | SYSSTS | LNST | The value is retained when the host controller function is selected. | | DVSTCTR | RHST | | | INTSTS0 | DVSQ | The value is retained when the host controller function is selected. | | USBADDR | USBADDR | The value is retained when the host controller function is selected. | | USEREQ | BRequest, bmRequestType | The values are retained when the host controller function is selected. | | USBVAL | wValue | The value is retained when the host controller function is selected. | | USBINDX | windex | The value is retained when the host controller function is selected. | | USBLENG | wLength | The value is retained when the host controller function is selected. | Table 17.5 Register Bits Initialized by Writing USBE = 0 (when Host Controller Function is Selected) | Register Name | Bit Name | Remarks | |---------------|----------|--------------------------------------------------------------------------| | DVSTCTR | RHST | | | FRMNUM | FRNM | The value is retained when the function controller function is selected. | | UFRMNUM | UFRNM | The value is retained when the function controller function is selected. | ### 17.3.2 CPU Bus Wait Setting Register (BUSWAIT) BUSWAIT specifies the number of access waits for those registers of this module that are connected to the peripheral bus (that is, the registers excluding D0FWAIT, D1FWAIT, D0FIFO, and D1FIFO). The basic clock for this module is a USB clock of 48 MHz, and access from the peripheral bus is performed through $P\phi$ synchronization. For this reason, the USB clock must be multiplied by a certain number of cycles when accessing registers of this module via the peripheral bus. The number of access waits should be adjusted to produce at least the approximate value shown below: 83.4 ns (USB clock $\times$ 4 cycles) when the size of access is 32 bits, 41.7 ns (USB clock $\times$ 2 cycles) when the size of access is 16 bits, or 20.8 ns (USB clock $\times$ 1 cycle) when the size of access is 8 bits. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|---|-----|------|--------|-----| | [ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | BWAI | T[3:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------| | 3 to 0 | BWAIT[3:0] | 1111 | R/W | CPU Bus Wait | | | | | | On a P $\phi$ basis, set the number of waits needed when accessing registers of this module via the peripheral bus. | | | | | | 0000: 0 wait (accessing two cycles on a Pφ basis) | | | | | | 0001: 1 wait (accessing three cycles on a $P\phi$ basis) | | | | | | 0010: 2 waits (accessing four cycles on a $P\phi$ basis) | | | | | | : | | | | | | 1111: 15 waits (accessing 17 cycles on a Pφ basis) | | | | | | Note: Be sure to set this bit in the initialization routine of this module by taking into account the $P\phi$ and access size. | # 17.3.3 System Configuration Status Register (SYSSTS) SYSSTS is a register that monitors the line status (D + and D - lines) of the USB data bus. This register is initialized by a power-on reset or a USB bus reset. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------|---| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | LNST[1:0] | | | Initial value | : 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | | | R/W | · R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial Value | R/W | Description | |----------|----------|---------------|-----|----------------------------------------------------------------------| | 15 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. The write value should always be 1. | | 9 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial Value R/W | Description | |------|-----------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | LNST[1:0] | Undefined* R | USB Data Line Status Monitor | | | | | Indicates the status of the USB data bus lines (D+ and D-) as shown in table 17.6. | | | | | These bits should be read after setting DPRPU to 1 to notify connection when the function controller function is selected; whereas after setting DRPD to 1 to enable pulling down the lines when the host controller function is selected. | Note: \* Depends on the DP and DM pin status. Table 17.6 USB Data Bus Line Status | LNST[1] | LNST[0] | During Low-<br>Speed<br>Operation<br>(only when<br>Host<br>Controller<br>Function is<br>Selected) | During Full-<br>Speed<br>Operation | During High-<br>Speed<br>Operation | During Chirp<br>Operation | |---------|---------|---------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------|---------------------------| | 0 | 0 | SE0 | SE0 | Squelch | Squelch | | 0 | 1 | K state | J state | Not squelch | Chirp J | | 1 | 0 | J state | K state | Invalid | Chirp K | | 1 | 1 | SE1 | SE1 | Invalid | Invalid | [Legend] Chirp: The reset handshake protocol is being executed in high-speed operation enabled state (the HSE bit in SYSCFG is set to 1). Squelch: SE0 or idle state Not squelch: High-speed J state or high-speed K state Chirp J: Chirp J state Chirp K: Chirp K state # 17.3.4 Device State Control Register (DVSTCTR) DVSTCTR is a register that controls and confirms the state of the USB data bus. This register is initialized by a power-on reset. After a USB bus reset, WKUP is initialized but RESUME is undefined. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|------|-------|--------|--------|------|---|---|---------|----| | [ | _ | _ | _ | - | _ | - | _ | WKUP | RWUPE | USBRST | RESUME | UACT | _ | R | HST[2:0 | 0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W* | R/W | R/W | R/W | R/W | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | WKUP | 0 | R/W | Wakeup Output | | | | s<br>f | | Enables or disables outputting the remote wakeup signal (resume signal) to the USB bus when the function controller function is selected. | | | | | | 0: Remote wakeup signal is not output. | | | | | | 1: Remote wakeup signal is output. | | | | | | The module controls the output time of a remote wakeup signal. When this bit is set to 1, this module clears this bit to 0 after outputting the 10-ms K state. | | | | | | According to the USB specification, the USB bus idle state must be kept for 5 ms or longer before a remote wakeup signal is output. If this module writes 1 to this bit right after detection of suspended state, the K state will be output after 2 ms. | | | | | | Note: Do not write 1 to this bit, unless the device state is in the suspended state (the DVSQ bit in the INTSTS0 register is set to 1xx) and the USB host enables the remote wakeup signal. When this bit is set to 1, the internal clock must not be stopped even in the suspended state (write 1 to this bit while SCKE is 1). | | | | | | This bit should be set to 0 if the host controller function is selected. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | RWUPE | 0 | R/W | Wakeup Detection Enable | | | | | | Enables or disables the downstream port peripheral device to use the remote wakeup function (resume signal output) when the host controller function is selected. | | | | | | 0: Downstream port wakeup is disabled. | | | | | | 1: Downstream port wakeup is enabled. | | | | | | With this bit set to 1, on detecting the remote wakeup signal, this module detects the resume signal (K-state for 2.5 $\mu$ s) from the downstream port device and performs the resume process (drives the port to the K-state). | | | | | | With this bit set to 0, this module ignores the detected remote wakeup signal (K-state) from the peripheral device connected to the downstream port. | | | | | | While this bit is 1, the internal clock should not be stopped even in the suspended state (SCKE should be set to 1). Also note that the USB bus should not be reset from the suspended state (USBRST should not be set to 1); it is prohibited by USB Specification 2.0. | | | | | | This bit should be set to 0 if the function controller function is selected. | | this bit to 1 allows this module to drive the USB port to SE0 to reset the USB bus. Here, this module performs the reset handshake protocol if the HSE bit is 1. This module continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for the time defined by USB Specification 2.0. Writing 1 to this bit during communication (UACT = 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus rese process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST). This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 R/W Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). | Bit | Bit Name | Initial<br>Value | R/W | Description | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------| | host controller function is selected. 0: USB bus reset signal is not output. 1: USB bus reset signal is output. When the host controller function is selected, setting this bit to 1 allows this module to drive the USB port to SE0 to reset the USB bus. Here, this module performs the reset handshake protocol if the HSE bit is 1. This module continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for the time defined by USB Specification 2.0. Writing 1 to this bit during communication (UACT = 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus rese process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST) This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). | 6 | USBRST | 0 | R/W | Bus Reset Output | | 1: USB bus reset signal is output. When the host controller function is selected, setting this bit to 1 allows this module to drive the USB port to SE0 to reset the USB bus. Here, this module performs the reset handshake protocol if the HSE bit is 1. This module continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for the time defined by USB Specification 2.0. Writing 1 to this bit during communication (UACT = 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus reset process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST). This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 R/W Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). | | | | | | | When the host controller function is selected, setting this bit to 1 allows this module to drive the USB port to SEO to reset the USB bus. Here, this module performs the reset handshake protocol if the HSE bit is 1. This module continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for the time defined by USB Specification 2.0. Writing 1 to this bit during communication (UACT = 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus rese process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST). This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 R/W Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). | | | | | 0: USB bus reset signal is not output. | | this bit to 1 allows this module to drive the USB port to SED to reset the USB bus. Here, this module performs the reset handshake protocol if the HSE bit is 1. This module continues outputting SE0 while USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for the time defined by USB Specification 2.0. Writing 1 to this bit during communication (UACT = 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus rese process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST). This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 R/W Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | 1: USB bus reset signal is output. | | USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for the time defined by USB Specification 2.0. Writing 1 to this bit during communication (UACT = 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus rese process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST) This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 RAW Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | to SE0 to reset the USB bus. Here, this module performs the reset handshake protocol if the HSE bit | | 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus rese process until both UACT and RESUME become 0. Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST) This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 R/W Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | USBRST is 1 (until software sets USBRST to 0). USBRST should be 1 (= USB bus reset period) for | | of the USB bus reset process (writing 0 to USBRST) This bit should be set to 0 if the function controller function is selected. 5 RESUME 0 Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | 1) or during the resume process (RESUME = 1) prevents this module from starting the USB bus reset | | function is selected. 5 RESUME 0 R/W Resume Output Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | Write 1 to the UACT bit simultaneously with the end of the USB bus reset process (writing 0 to USBRST). | | Controls the resume signal output when the host controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | | | controller function is selected. 0: Resume signal is not output. 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | 5 | RESUME | 0 | R/W | Resume Output | | 1: Resume signal is output. Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | | | Setting this bit to 1 allows this module to drive the port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | 0: Resume signal is not output. | | port to the K-state and output the resume signal. This module continues outputting K-state while RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | 1: Resume signal is output. | | RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time defined by USB Specification 2.0. This bit should be set to 1 in the suspended state. Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | | | Write 1 to the UACT bit simultaneously with the end of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | RESUME is 1 (until software sets RESUME to 0). RESUME should be 1 (= resume period) for the time | | of the resume process (writing 0 to RESUME). This bit should be set to 0 if the function controller | | | | | This bit should be set to 1 in the suspended state. | | | | | | | | | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | | | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 4 | UACT | 0 | R/W | USB Bus Enable | | | | | | | | | | | | Enables operation of the USB bus (controls the SOF or $\mu$ SOF packet transmission to the USB bus) when the host controller function is selected. | | | | | | | | | | | | 0: Downstream port is disabled (SOF/ $\mu$ SOF transmission is disabled). | | | | | | | | | | | | 1: Downstream port is enabled (SOF/ $\mu$ SOF transmission is enabled). | | | | | | | | | | | | With this bit set to 1, this module puts the USB port to the USB-bus enabled state and performs SOF output and data transmission and reception. | | | | | | | | | | | | This module starts outputting SOF/ $\mu$ SOF within 1 (frame after software has written 1 to UACT. | | | | | | | | | | | | With this bit set to 0, this module enters the idle state after outputting SOF/ $\mu$ SOF. | | | | | | | | | | | | This module sets this bit to 0 on any of the following conditions. | | | | | | | | | | | | A DTCH interrupt is detected during | | | | | | | | | | | | communication (while UACT = 1). | | | | | | | | | | | | An EOFERR interrupt is detected during | | | | | | | | | | | | communication (while UACT = 1). | | | | | | | | | | | | Writing 1 to this bit should be done at the end of the USB reset process (writing 0 to USBRST) or at the end of the resume process from the suspended state (writing 0 to RESUME). | | | | | | | | | | | | This bit should be set to 0 if the function controller function is selected. | | | | | | | | 3 | | 0 | R | Reserved | | | | | | | | | | | | This bit is always read as 0. The write value should always be 0. | | | | | | | | | | | | always be 0. | | | | | | | | | | Initial | | | | | | | | |--------|-----------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Bit Name | Value | R/W | Description | | | | | | | 2 to 0 | RHST[2:0] | 000 | R | Reset Handshake | | | | | | | | | | | Indicates the status of the reset handshake. | | | | | | | | | | | (1) When the host controller function is selected | | | | | | | | | | | 000: Communication speed not determined (powered state or no connection) | | | | | | | | | | | 1xx: Reset handshake in progress | | | | | | | | | | | 001: Low-speed connection | | | | | | | | | | | 010: Full-speed connection | | | | | | | | | | | 011: High-speed connection | | | | | | | | | | | These bits indicate 100 after software has written 1 to USBRST. | | | | | | | | | | | If HSE has been set to 1, these bits indicate 111 as soon as this module detects Chirp-K from the peripheral device. | | | | | | | | | | | This module fixes the value of the RHST bits when software writes 0 to USBRST and this module completes SE0 driving. | | | | | | | | | | | (2) When the function controller function is selected | | | | | | | | | | | 000: Communication speed not determined | | | | | | | | | | | 100: Reset handshake in progress | | | | | | | | | | | 010: Full-speed connection | | | | | | | | | | | 011: High-speed connection | | | | | | | | | | | If HSE has been set to 1, these bits indicate 100 as soon as this module detects the USB bus reset. Then, these bits indicate 011 as soon as this module outputs Chirp-K and detects Chirp-JK from the USB host three times. If the connection speed is not fixed to high speed within 2.5 ms after Chirp-K output, these bits indicate 010. | | | | | | | | | | | If HSE has been set to 0, these bits indicate 010 as soon as this module detects the USB bus reset. | | | | | | | | | | | A DVST interrupt is generated as soon as this module detects the USB bus reset and then the value of the RHST bits is fixed to 010 or 011. | | | | | | Note: \* Only 1 can be written. # 17.3.5 Test Mode Register (TESTMODE) TESTMODE is a register that controls the USB test signal output during high-speed operation. This register is initialized by a power-on reset. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|----|---|---|---|---|---|---|-----|------|-------|-----| | | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | _ | _ | _ | | UTST | [3:0] | | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | · R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------| | 15 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 3 to 0 | UTST[3:0] | 0000 | R/W | Test Mode | | | | | | This module outputs the USB test signals during the high-speed operation, when these bits are written appropriate value. | | | | | | Table 17.7 shows test mode operation of this module. | | | | Initial | | | | | | | | |--------|-----------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Bit Name | Value | R/W | Description | | | | | | | 3 to 0 | UTST[3:0] | 0000 | R/W | (1) When the host controller function is selected | | | | | | | | | | | These bits can be set after writing 1 to DRPD. This module outputs waveforms to the USB port for which both DPRD and UACT have been set to 1. This module also performs high-speed termination for the USB port. | | | | | | | | | | | <ul> <li>Procedure for setting the UTST bits</li> </ul> | | | | | | | | | | | 1. Power-on reset. | | | | | | | | | | | <ol><li>Start the clock supply (Set SCKE to 1 after the<br/>crystal oscillation and the PLL for USB are<br/>settled).</li></ol> | | | | | | | | | | | <ol><li>Set DCFM and DPRD to 1 (setting HSE to 1 is<br/>not required).</li></ol> | | | | | | | | | | | 4. Set USBE to 1. | | | | | | | | | | | <ol><li>Set the UTST bits to the appropriate value<br/>according to the test specifications.</li></ol> | | | | | | | | | | | 6. Set the UACT bit to 1. | | | | | | | | | | | <ul> <li>Procedure for modifying the UTST bits</li> </ul> | | | | | | | | | | | <ol> <li>(In the state after executing step 6 above) Set<br/>UACT and USBE to 0.</li> </ol> | | | | | | | | | | | 2. Set USBE to 1. | | | | | | | | | | | <ol><li>Set the UTST bits to the appropriate value<br/>according to the test specifications.</li></ol> | | | | | | | | | | | 4. Set the UACT bit to 1. | | | | | | | | | | | When these bits are set to Test_SE0_NAK (1011), this module does not output the SOF packet to the port even when 1 has been set to UACT for the port. | | | | | | | | | | | When these bits are set to Test_Force_Enable (1101), this module outputs the SOF packet to the port for which 1 has been set to UACT. In this test mode, this module does not perform hardware control consequent to detection of high-speed disconnection (detection of the DTCH interrupt). | | | | | | | | | | | When setting the UTST bits, the PID bits for all the pipes should be set to NAK. | | | | | | | | | | | To return to normal USB communication after a test mode has been set and executed, a power-on resesshould be applied. | | | | | | | | | Initial | | | | | | |--------|-----------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Bit Name | Value | R/W | Description | | | | | 3 to 0 | UTST[3:0] | 0000 | ( ) | | | | | | | | | | The appropriate value should be set to these bits according to the SetFeature request from the USB host during high-speed communication. | | | | | | | | | This module does not make a transition to the suspended state while these bits are 0001 to 0100. | | | | **Table 17.7 Test Mode Operation** ### **UTST Bit Setting** | Test Mode | When Function Controller<br>Function is Selected | When Host Controller<br>Function is Selected | |-------------------|--------------------------------------------------|----------------------------------------------| | Normal operation | 0000 | 0000 | | Test_J | 0001 | 1001 | | Test_K | 0010 | 1010 | | Test_SE0_NAK | 0011 | 1011 | | Test_Packet | 0100 | 1100 | | Test_Force_Enable | _ | 1101 | | Reserved | 0101 to 0111 | 1110 to 1111 | ### 17.3.6 DMA-FIFO Bus Configuration Registers (D0FBCFG, D1FBCFG) D0FBCFG is a register that controls DMA0-FIFO bus accesses. D1FBCFG is a register that controls DMA1-FIFO bus accesses. These registers are initialized by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|----|----|-----|----|----|---|---|---|---|---|-------|---|---|---|---| | [ | _ | _ | DF | ACC | _ | _ | _ | _ | _ | 1 | _ | TENDE | _ | _ | _ | _ | | Initial value: | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | | | | |---------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 15, 14 | _ | All 0 | R | Reserved | | | | | | | | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | | | | 13, 12 | DFACC | 00 | R | DMAn-FIFO Buffer Access Mode (n = 0, 1) | | | | | | | | | | | | | Specifies DMA0-FIFO or DMA1-FIFO port access mode. | | | | | | | | | | | | | 00: Cycle steal mode (initial value) | | | | | | | | | | | | | 01: 16-byte continuous access mode | | | | | | | | | | | | | 10: 32-byte continuous access mode | | | | | | | | | | | | | 11: Invalid | | | | | | | | | 11 to 5 | _ | All 0 | R | Reserved | | | | | | | | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | | | | 4 | TENDE | 0 | R/W | DMA Transfer End Sampling Enable | | | | | | | | | | | | | Controls acceptance of the DMA transfer end signal that is transmitted from the DMAC when DMA transfer ends. | | | | | | | | | | | | | 0: DMA transfer end signal is not sampled. | | | | | | | | | | | | | 1: DMA transfer end signal is sampled. | | | | | | | | | 3 to 0 | _ | All 0 | R | Reserved | | | | | | | | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | | | #### 17.3.7 FIFO Port Registers (CFIFO, D0FIFO, D1FIFO) CFIFO, D0FIFO and D1FIFO are port registers that are used to read data from the FIFO buffer memory and writing data to the FIFO buffer memory. There are three FIFO ports: the CFIFO, D0FIFO and D1FIFO ports. Each FIFO port is configured of a port register (CFIFO, D0FIFO, D1FIFO) that handles reading of data from the FIFO buffer memory and writing of data to the FIFO buffer memory, a select register (CFIFOSEL, D0FIFOSEL) that is used to select the pipe assigned to the FIFO port, and a control register (CFIFOCTR, D0FIFOCTR, D1FIFOCTR). Each FIFO port has the following features. - The DCP FIFO buffer should be accessed through the CFIFO port. - Accessing the FIFO buffer using DMA transfer should be performed through the D0FIFO or D1FIFO port. - The D1FIFO and D0FIFO ports can be accessed also by the CPU. - When using functions specific to the FIFO port, the pipe number (selected pipe) specified by the CURPIPE bits cannot be changed (when the DMA transfer function is used, etc.). - Registers configuring a FIFO port do not affect other FIFO ports. - The same pipe should not be assigned to two or more FIFO ports. - There are two FIFO buffer states: the access right is on the CPU side and it is on the SIE side. When the FIFO buffer access right is on the SIE side, the FIFO buffer cannot be accessed from the CPU. These registers are initialized by a power-on reset. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------|-----------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | FIFOPORT[31:16] | | | | | | | | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: R/W | | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FIFOPORT[15:0] | | | | | | | | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------------------------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 0 FIFOPORT All 0 | R/W | FIFO Port | | | | | [31:0] | 31:0] | | Accessing these bits allow reading the received data from the FIFO buffer or writing the transmit data to the FIFO buffer. | | | | | | These bits can be accessed only while the FRDY bit in each control register (CFIFOCTR, D0FIFOCTR, or D1FIFOCTR) is 1. | | | | | | The valid bits in this register depend on the settings of the MBW bits (access bit width setting) and BIGEND bit (endian setting) as shown in tables 17.8 to 17.10. | ### **Table 17.8** Endian Operation in 32-Bit Access (when MBW = 10) | BIGEND Bit | Bits 31 to 24 | Bits 23 to 16 | Bits 15 to 8 | Bits 7 to 0 | |------------|---------------|---------------|---------------|---------------| | 0 | N + 3 address | N + 2 address | N + 1 address | N + 0 address | | 1 | N + 0 address | N + 1 address | N + 2 address | N + 3 address | ### **Table 17.9 Endian Operation in 16-Bit Access (when MBW = 01)** | BIGEND Bit | Bits 31 to 24 | Bits 23 to 16 | Bits 15 to 8 | Bits 7 to 0 | |------------|-------------------|----------------------|-------------------|----------------------| | 0 | Writing: invalid, | reading: prohibited* | N + 1 address | N + 0 address | | 1 | N + 0 address | N + 1 address | Writing: invalid, | reading: prohibited* | Note: \* Reading data from the invalid bits in a word or byte unit is prohibited. # Table 17.10 Endian Operation in 8-Bit Access (when MBW = 00) | BIGEND Bit | Bits 31 to 24 | Bits 23 to 16 | Bits 15 to 8 | Bits 7 to 0 | | | | | |------------|---------------|------------------------------------------------------|----------------------|---------------|--|--|--|--| | 0 | Writir | Writing: invalid, reading: prohibited* N + 0 address | | | | | | | | 1 | N + 0 address | Writin | ng: invalid, reading | : prohibited* | | | | | Note: \* Reading data from the invalid bits in a word or byte unit is prohibited. ### 17.3.8 FIFO Port Select Registers (CFIFOSEL, D0FIFOSEL, D1FIFOSEL) CFIFOSEL, D0FIFOSEL and D1FIFOSEL are registers that assign the pipe to the FIFO port, and control access to the corresponding port. The same pipe should not be specified by the CURPIPE bits in CFIFOSEL, D0FIFOSEL and D1FIFOSEL. When the CURPIPE bits in D0FIFOSEL and D1FIFOSEL are cleared to B'000, no pipe is selected. The pipe number should not be changed while the DMA transfer is enabled. These registers are initialized by a power-on reset. ### (1) CFIFOSEL | Bit | t: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|------|----|----|-----|--------|---|--------|---|---|------|---|-----|-------|---------|-----| | | RCNT | REW | _ | _ | MBV | V[1:0] | _ | BIGEND | _ | - | ISEL | _ | | CURPI | PE[3:0] | | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | /: R/W | R/W* | R | R | R/W | R/W | R | R/W | R | R | R/W | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------| | 15 | RCNT | 0 | R/W | Read Count Mode | | | | | | Specifies the read mode for the value in the DTLN bits in CFIFOCTR. | | | | | | <ol><li>The DTLN bit is cleared when all of the receive<br/>data has been read from the CFIFO.</li></ol> | | | | | | (In double buffer mode, the DTLN bit value is cleared when all the data has been read from a single plane.) | | | | | | <ol> <li>The DTLN bit is decremented when the receive<br/>data is read from the CFIFO.</li> </ol> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 | REW | 0 | R/W* | Buffer Pointer Rewind | | | | | | Specifies whether or not to rewind the buffer pointer. | | | | | | 0: The buffer pointer is not rewound. | | | | | | 1: The buffer pointer is rewound. | | | | | | When the selected pipe is in the receiving direction, setting this bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer plane from the first data is allowed). | | | | | | Do not set REW to 1 simultaneously with modifying the CURPIPE bits. Before setting REW to 1, be sure to check that FRDY is 1. | | | | | | To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit. | | 13, 12 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11, 10 | MBW[1:0] | 00 | R/W | CFIFO Port Access Bit Width | | | | | | Specifies the bit width for accessing the CFIFO port. | | | | | | 00: 8-bit width | | | | | | 01: 16-bit width | | | | | | 10: 32-bit width | | | | | | 11: Setting prohibited | | | | | | When the selected pipe is in the receiving direction, once reading data is started after setting these bits, these bits should not be modified until all the data has been read. | | | | | | When the selected pipe is in the receiving direction, set the CURPIPE and MBW bits simultaneously. | | | | | | When the selected pipe is in the transmitting direction, the bit width cannot be changed from the 8-bit width to the 16-/32-bit width or from the 16-bit width to the 32-bit width while data is being written to the buffer memory. | | | | | | The odd number of bytes can also be written through byte-access control even when 8- or 16-bit width is selected. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 8 | BIGEND | 0 | R/W | CFIFO Port Endian Control | | | | | | Specifies the byte endian for the CFIFO port. | | | | | | 0: Little endian | | | | | | 1: Big endian | | 7, 6 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 5 | ISEL | 0 | R/W | CFIFO Port Access Direction When DCP is Selected | | | | | | 0: Reading from the buffer memory is selected | | | | | | 1: Writing to the buffer memory is selected | | | | | | After writing to this bit with the DCP being a selected pipe, read this bit to check that the written value agrees with the read value before proceeding to the next process. | | | | | | Even if an attempt is made to modify the setting of this bit during access to the FIFO buffer, the current access setting is retained until the access is completed. Then, the modification becomes effective thus enabling continuous access. | | | | | | Set this bit and the CURPIPE bits simultaneously. | | 4 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|--------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 to 0 | CURPIPE[3:0] | 0000 | R/W | CFIFO Port Access Pipe Specification | | | | | | Specifies the pipe number using which data is read or written through the CFIFO port. | | | | | | 0000: DCP | | | | | | 0001: Pipe 1 | | | | | | 0010: Pipe 2 | | | | | | 0011: Pipe 3 | | | | | | 0100: Pipe 4 | | | | | | 0101: Pipe 5 | | | | | | 0110: Pipe 6 | | | | | | 0111: Pipe 7 | | | | | | 1000: Pipe 8 | | | | | | 1001: Pipe 9 | | | | | | Other than above: Setting prohibited | | | | | | After writing to these bits, read these bits to check that the written value agrees with the read value before proceeding to the next process. | | | | | | Do not set the same pipe number to the CURPIPE bits in CFIFOSEL, D0FIFOSEL, and D1FIFOSEL. | | | | | | Even if an attempt is made to modify the setting of these bits during access to the FIFO buffer, the current access setting is retained until the access is completed. Then, the modification becomes effective thus enabling continuous access. | Note: \* Only 0 can be read. # (2) D0FIFOSEL, D1FIFOSEL | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|------|-------|-------|-----|--------|---|------------|---|---|---|---|-----|-------|---------|-----| | | RCNT | REW | DCLRM | DREQE | MBW | /[1:0] | _ | BIG<br>END | _ | _ | _ | _ | | CURPI | PE[3:0] | | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R/W | R/W* | R/W | R/W | R/W | R/W | R | R/W | R | R | R | R | R/W | R/W | R/W | R/W | | | | Initial | | | |-----|----------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 | RCNT | 0 | R/W | Read Count Mode | | | | | | Specifies the read mode for the value in the DTLN bits in DnFIFOCTR. | | | | | | <ol><li>The DTLN bit is cleared when all of the receive<br/>data has been read from the DnFIFO.</li></ol> | | | | | | (In double buffer mode, the DTLN bit value is cleared when all the data has been read from a single plane.) | | | | | | <ol> <li>The DTLN bit is decremented when the receive<br/>data is read from the DnFIFO.</li> </ol> | | | | | | When accessing DnFIFO with the BFRE bit set to 1, set this bit to 0. | | 14 | REW | 0 | R/W* | Buffer Pointer Rewind | | | | | | Specifies whether or not to rewind the buffer pointer. | | | | | | 0: The buffer pointer is not rewound. | | | | | | 1: The buffer pointer is rewound. | | | | | | When the selected pipe is in the receiving direction, setting this bit to 1 while the FIFO buffer is being read allows re-reading the FIFO buffer from the first data (in double buffer mode, re-reading the currently-read FIFO buffer plane from the first data is allowed). | | | | | | Do not set REW to 1 simultaneously with modifying the CURPIPE bits. Before setting REW to 1, be sure to check that FRDY is 1. | | | | | | When accessing DnFIFO with the BFRE bit set to 1, do not set this bit to 1 in the state in which the short packet data has been read out. | | | | | | To re-write to the FIFO buffer again from the first data for the pipe in the transmitting direction, use the BCLR bit. | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | DCLRM | 0 | R/W | Auto Buffer Memory Clear Mode Accessed after Specified Pipe Data is Read | | | | | | Enables or disables the buffer memory to be cleared automatically after data has been read out using the selected pipe. | | | | | | 0: Auto buffer clear mode is disabled. | | | | | | 1: Auto buffer clear mode is enabled. | | | | | | With this bit set to 1, this module sets BCLR to 1 for<br>the FIFO buffer of the selected pipe on receiving a<br>zero-length packet while the FIFO buffer assigned to<br>the selected pipe is empty, or on receiving a short<br>packet and reading the data while BFRE is 1. | | | | | | When using this module with the BRDYM bit set to 1, set this bit to 0. | | 12 | DREQE | 0 | R/W | DMA Transfer Request Enable | | | | | | Enables or disables the DMA transfer request to be issued. | | | | | | 0: Request disabled | | | | | | 1: Request enabled | | | | | | Before setting this bit to 1 to enable the DMA transfer request to be issued, set the CURPIPE bits. | | | | | | Before modifying the CURPIPE bit setting, set this bit to 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11, 10 | MBW[1:0] | All 0 | R/W | FIFO Port Access Bit Width | | | | | | Specifies the bit width for accessing the DnFIFO port. | | | | | | 00: 8-bit width | | | | | | 01: 16-bit width | | | | | | 10: 32-bit width | | | | | | 11: Setting prohibited | | | | | | When the selected pipe is in the receiving direction, once reading data is started after setting these bits, these bits should not be modified until all the data has been read. | | | | | | When the selected pipe is in the receiving direction, set the CURPIPE and MBW bits simultaneously. | | | | | | When the selected pipe is in the transmitting direction, the bit width cannot be changed from the 8-bit width to the 16-/32-bit width or from the 16-bit width to the 32-bit width while data is being written to the buffer memory. | | | | | | The odd number of bytes can be written through byte-access control even when 8- or 16-bit width is selected. | | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 8 | BIGEND | 0 | R/W | FIFO Port Endian Control | | | | | | Specifies the byte endian for the DnFIFO port. | | | | | | 0: Little endian | | | | | | 1: Big endian | | 7 to 4 | _ | All 0 | R/W | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | | | | <b></b> | Initial | | | |--------|--------------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 3 to 0 | CURPIPE[3:0] | 0000 | R/W | FIFO Port Access Pipe Specification | | | | | | Specifies the pipe number using which data is read or written through the D0FIFO/D1FIFO port. | | | | | | 0000: No pipe specified | | | | | | 0001: Pipe 1 | | | | | | 0010: Pipe 2 | | | | | | 0011: Pipe 3 | | | | | | 0100: Pipe 4 | | | | | | 0101: Pipe 5 | | | | | | 0110: Pipe 6 | | | | | | 0111: Pipe 7 | | | | | | 1000: Pipe 8 | | | | | | 1001: Pipe 9 | | | | | | Other than above: Setting prohibited | | | | | | After writing to these bits, read these bits to check that the written value agrees with the read value before proceeding to the next process. | | | | | | Do not set the same pipe number to the CURPIPE bits in CFIFOSEL, D0FIFOSEL, and D1FIFOSEL. | | | | | | Even if an attempt is made to modify the setting of these bits during access to the FIFO buffer, the current access setting is retained until the access is completed. Then, the modification becomes effective thus enabling continuous access. | Note: \* Only 0 can be read. # 17.3.9 FIFO Port Control Registers (CFIFOCTR, D0FIFOCTR, D1FIFOCTR) CFIFOCTR, D0FIFOCTR and D1FIFOCTR are registers that determine whether or not writing to the buffer memory has been finished, the buffer accessed from the CPU has been cleared, and the FIFO port is accessible. CFIFOCTR, D0FIFOCTR, and D1FIFOCTR are used for the corresponding FIFO ports. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---------|---------|------|----|----|----|---|---|---|------|--------|---|---|---|---|---| | | BVAL | BCLR | FRDY | _ | | | | | | DTLN | [11:0] | | | | | | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R/W*2 | 2 R/W*1 | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | R/W: R/W* <sup>2</sup> R/W* <sup>1</sup> R | R R | R | R | R | R | R | R | R | R | R | R | R | |-----|--------------------------------------------|------------------|-------|------------------|----------------------------------------------------|----------------------------|-------------------------------|--------------------|---------------------------|------------------|--------------------|-------------------------------------|----------| | Bit | Bit Name | Initial<br>Value | R/W | De | script | ion | | | | | | | | | 15 | BVAL | 0 | R/W*2 | Bu | ffer Me | emory | / Valid | l Flag | | | | | <u> </u> | | | | | | cor<br>sid | is bit s<br>nplete<br>e for th<br>lected | ly wri | tten to<br>e sel | the F | IFO I | ouffer | on th | e CPL | | | | | | | 0: I | Invalid | | | | | | | | | | | | | | 1: \ | Writing | g ende | ed | | | | | | | | | | | | dire<br>The | nen the<br>ection,<br>en, this<br>'U side | set th<br>s mod | nis bit<br>dule s | to 1 ii<br>witche | n the<br>s the | follow<br>FIFO | ing ca | ases.<br>er from | | | | | | | • | | | | ort pa<br>ritten. | • | set th | is bit t | to 1 af | ter | | | | | | • | | | | ro-len<br>ritten t | • | | | nis bit t<br>er. | to 1 | | | | | | • | has b<br>transf<br>intege | een v<br>er mo | vritten<br>ode, w<br>Itiple ( | for the | e pipe<br>the nu<br>maxir | e in co<br>umbei | ontinu<br>r is a ı | a byte<br>lous<br>natura<br>It size | I | | | | | | wri<br>mo<br>buf | nen the<br>tten fo<br>dule s<br>ffer fro<br>nsmiss | r the <br>ets th<br>m the | pipe i<br>iis bit | n cont<br>to 1 a | inuou<br>nd sw | s trar | nsfer r<br>s the l | node,<br>FIFO | this | | | | | | | iting 1<br>icates | | | | | | hile F | RDY | | do not set this bit to 1. When the selected pipe is in the receiving direction, | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 | BCLR | 0 | R/W*1 | CPU Buffer Clear | | | | | | This bit should be set to 1 to clear the FIFO buffer on the CPU side for the selected pipe. | | | | | | 0: Invalid | | | | | | 1: Clears the buffer memory on the CPU side. | | | | | | When double buffer mode is set for the FIFO buffer assigned to the selected pipe, this module clears only one plane of the FIFO buffer even when both planes are read-enabled. | | | | | | When the selected pipe is the DCP, setting BCLR to 1 allows this module to clear the FIFO buffer regardless of whether the FIFO buffer is on the CPU side or SIE side. To clear the buffer on the SIE side, set the PID bits for the DCP to NAK before setting BCLR to 1. | | | | | | When the selected pipe is in the transmitting direction, if 1 is written to BVAL and BCLR bits simultaneously, this module clears the data that has been written before it, enabling transmission of a zero-length packet. | | | | | | When the selected pipe is not the DCP, writing 1 to this bit should be done while FRDY indicates 1 (set by this module). | | 13 | FRDY | 0 | R | FIFO Port Ready | | | | | | Indicates whether the FIFO port can be accessed by the CPU (DMAC). | | | | | | 0: FIFO port access is disabled. | | | | | | 1: FIFO port access is enabled. | | | | | | In the following cases, this module sets FRDY to 1 but data cannot be read via the FIFO port because there is no data to be read. In these cases, set BCLR to 1 to clear the FIFO buffer, and enable transmission and reception of the next data. | | | | | | <ul> <li>A zero-length packet is received when the FIFO<br/>buffer assigned to the selected pipe is empty.</li> </ul> | | | | | | <ul> <li>A short packet is received and the data is<br/>completely read while BFRE is 1.</li> </ul> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 11 to 0 | DTLN[11:0] | H'000 | R | Receive Data Length | | | | | | Indicates the length of the receive data. | | | | | | While the FIFO buffer is being read, these bits indicate the different values depending on the RCNT bit value as described below. | | | | | | • RCNT = 0: | | | | | | This module sets these bits to indicate the length of the receive data until the CPU (DMAC) has read all the received data from a single FIFO buffer plane. | | | | | | While BFRE is 1, these bits retain the length of<br>the receive data until BCLR is set to 1 even after<br>all the data has been read. | | | | | | • RCNT = 1: | | | | | | This module decrements the value indicated by these bits each time data is read from the FIFO buffer. (The value is decremented by one when MBW is 0, and by two when MBW is 1.) | | | | | | This module sets these bits to 0 when all the data has been read from one FIFO buffer plane. However, in double buffer mode, if data has been received in one FIFO buffer plane before all the data has been read from the other plane, this module sets these bits to indicate the length of the receive data in the former plane when all the data has been read from the latter plane. | Notes: 1. Only 0 can be read and 1 can be written to. 2. Only 1 can be written to. When RCNT is 1, reading these bits while the FIFO buffer is being read returns the latest value within 150 ns after the FIFO port read cycle. #### **Interrupts Enable Register 0 (INTENB0)** INTENBO is a register that specifies the various interrupt masks. On detecting the interrupt corresponding to the bit in this register to which software has set 1, this module generates the USB interrupt. This module sets 1 to each status bit in INTSTS0 when a detection condition of the corresponding interrupt source has been satisfied regardless of the set value in INTENB0 (regardless of whether the interrupt output is enabled or disabled). While the status bit in INTSTS0 corresponding to the interrupt source indicates 1, this module generates the USB interrupt when software modifies the corresponding interrupt enable bit in INTENB0 from 0 to 1. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|------|------|------|------|-------|-------|-------|---|---|---|---|---|---|---|---| | | VBSE | RSME | SOFE | DVSE | CTRE | ВЕМРЕ | NRDYE | BRDYE | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | ': R/W | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------| | 15 | VBSE | 0 | R/W | VBUS Interrupts Enable | | | | | | Enables or disables the USB interrupt output when the VBINT interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 14 | RSME | 0 | R/W | Resume Interrupts Enable | | | | | | Enables or disables the USB interrupt output when the RESM interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------| | 13 | SOFE | 0 | R/W | Frame Number Update Interrupts Enable | | | | | | Enables or disables the USB interrupt output when the SOFR interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 12 | DVSE | 0 | R/W | Device State Transition Interrupts Enable* | | | | | | Enables or disables the USB interrupt output when the DVST interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 11 | CTRE | 0 | R/W | Control Transfer Stage Transition Interrupts Enable* | | | | | | Enables or disables the USB interrupt output when the CTRT interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 10 | BEMPE | 0 | R/W | Buffer Empty Interrupts Enable | | | | | | Enables or disables the USB interrupt output when the BEMP interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 9 | NRDYE | 0 | R/W | Buffer Not Ready Response Interrupts Enable | | | | | | Enables or disables the USB interrupt output when the NRDY interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-----------------------------------------------------------------------------------| | 8 | BRDYE | 0 | R/W | Buffer Ready Interrupts Enable | | | | | | Enables or disables the USB interrupt output when the BRDY interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 7 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Note: The RSME, DVSE, and CTRE bits can be set to 1 only when the function controller function is selected; do not set these bits to 1 to enable the corresponding interrupt output when the host controller function is selected. #### **Interrupt Enable Register 1 (INTENB1)** INTENB1 is a register that specifies the various interrupt masks when the host controller function is selected. On detecting the interrupt corresponding to the bit in this register to which software has set 1, this module generates the USB interrupt. This module sets 1 to each status bit in INTSTS1 when a detection condition of the corresponding interrupt source has been satisfied regardless of the set value in INTENB1 (regardless of whether the interrupt output is enabled or disabled). While the status bit in INTSTS1 corresponding to the interrupt source indicates 1, this module generates the USB interrupt when software modifies the corresponding interrupt enable bit in INTENB1 from 0 to 1. When the function controller function is selected, the interrupts should not be enabled. This register is initialized by a power-on reset. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|-------|----|-------|------------|----|---|---|---|-------------|-------|-------|---|---|---|---| | [ | _ | BCHGE | _ | DTCHE | ATT<br>CHE | _ | _ | _ | _ | EOF<br>ERRE | SIGNE | SACKE | _ | _ | _ | _ | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | R | R/W | R | R/W | R/W | R | R | R | R | R/W | R/W | R/W | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|-------------------------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 | BCHGE | 0 | R/W | USB Bus Change Interrupt Enable | | | | | | Enables or disables the USB interrupt output when the BCHG interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | DTCHE | 0 | R/W | Disconnection Detection Interrupt Enable | | | | | | Enables or disables the USB interrupt output when the DTCH interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 11 | ATTCHE | 0 | R/W | Connection Detection Interrupt Enable | | | | | | Enables or disables the USB interrupt output when the ATTCH interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 10 to 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 6 | EOFERRE | 0 | R/W | EOF Error Detection Interrupt Enable | | | | | | Enables or disables the USB interrupt output when the EOFERR interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 5 | SIGNE | 0 | R/W | Setup Transaction Error Interrupt Enable | | | | | | Enables or disables the USB interrupt output when the SIGN interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-----------------------------------------------------------------------------------| | 4 | SACKE | 0 | R/W | Setup Transaction Normal Response Interrupt Enable | | | | | | Enables or disables the USB interrupt output when the SACK interrupt is detected. | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 3 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Note: The INTENB1 register bits can be set to 1 only when the host controller function is selected; do not set these bits to 1 to enable the corresponding interrupt output when the function controller function is selected. #### 17.3.12 BRDY Interrupt Enable Register (BRDYENB) BRDYENB is a register that enables or disables the BRDY bit in INTSTS0 to be set to 1 when the BRDY interrupt is detected for each pipe. On detecting the BRDY interrupt for the pipe corresponding to the bit in this register to which software has set 1, this module sets 1 to the corresponding PIPEBRDY bit in BRDYSTS and the BRDY bit in INTSTSO, and generates the BRDY interrupt. While at least one PIPEBRDY bit in BRDYSTS indicates 1, this module generates the BRDY interrupt when software modifies the corresponding interrupt enable bit in BRDYENB from 0 to 1. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|----------------|-----|----------------|-----|----------------|-----|----------------|-----|-----|----------------| | [ | _ | _ | _ | _ | _ | _ | PIPE9<br>BRDYE | | PIPE7<br>BRDYE | | PIPE5<br>BRDYE | | PIPE3<br>BRDYE | | | PIPE0<br>BRDYE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|----------------------------------------------------------------------| | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PIPE9BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE9 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 8 | PIPE8BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE8 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 7 | PIPE7BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE7 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 6 | PIPE6BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE6 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 5 | PIPE5BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE5 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 4 | PIPE4BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE4 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 3 | PIPE3BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE3 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 2 | PIPE2BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE2 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|------------|------------------|-----|---------------------------------| | 1 | PIPE1BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE1 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 0 | PIPE0BRDYE | 0 | R/W | BRDY interrupt Enable for PIPE0 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | #### NRDY Interrupt Enable Register (NRDYENB) NRDYENB is a register that enables or disables the NRDY bit in INTSTS0 to be set to 1 when the NRDY interrupt is detected for each pipe. On detecting the NRDY interrupt for the pipe corresponding to the bit in this register to which software has set 1, this module sets 1 to the corresponding PIPENRDY bit in NRDYSTS and the NRDY bit in INTSTS0, and generates the NRDY interrupt. While at least one PIPENRDY bit in NRDYSTS indicates 1, this module generates the NRDY interrupt when software modifies the corresponding interrupt enable bit in NRDYENB from 0 to 1. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | [ | _ | _ | _ | _ | - | _ | PIPE9<br>NRDYE | PIPE8<br>NRDYE | PIPE7<br>NRDYE | PIPE6<br>NRDYE | PIPE5<br>NRDYE | PIPE4<br>NRDYE | PIPE3<br>NRDYE | PIPE2<br>NRDYE | PIPE1<br>NRDYE | PIPE0<br>NRDYE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|----------------------------------------------------------------------| | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PIPE9NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE9 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 8 | PIPE8NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE8 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 7 | PIPE7NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE7 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 6 | PIPE6NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE6 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 5 | PIPE5NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE5 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 4 | PIPE4NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE4 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 3 | PIPE3NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE3 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 2 | PIPE2NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE2 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | - | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|------------|------------------|-----|---------------------------------| | 1 | PIPE1NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE1 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 0 | PIPE0NRDYE | 0 | R/W | NRDY Interrupt Enable for PIPE0 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | ### 17.3.14 BEMP Interrupt Enable Register (BEMPENB) BEMPENB is a register that enables or disables the BEMP bit in INTSTS0 to be set to 1 when the BEMP interrupt is detected for each pipe. On detecting the BEMP interrupt for the pipe corresponding to the bit in this register to which software has set 1, this module sets 1 to the corresponding PIPEBEMP bit in BEMPSTS and the BEMP bit in INTSTSO, and generates the BEMP interrupt. While at least one PIPEBEMP bit in BEMPSTS indicates 1, this module generates the BEMP interrupt when software modifies the corresponding interrupt enable bit in BEMPENB from 0 to 1. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | | _ | _ | _ | _ | _ | _ | PIPE9<br>BEMPE | PIPE8<br>BEMPE | PIPE7<br>BEMPE | PIPE6<br>BEMPE | PIPE5<br>BEMPE | PIPE4<br>BEMPE | PIPE3<br>BEMPE | PIPE2<br>BEMPE | PIPE1<br>BEMPE | PIPE0<br>BEMPE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|----------------------------------------------------------------------| | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PIPE9BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE9 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 8 | PIPE8BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE8 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 7 | PIPE7BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE7 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 6 | PIPE6BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE6 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 5 | PIPE5BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE5 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 4 | PIPE4BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE4 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 3 | PIPE3BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE3 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 2 | PIPE2BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE2 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 1 | PIPE1BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE1 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | 0 | PIPE0BEMPE | 0 | R/W | BEMP Interrupt Enable for PIPE0 | | | | | | 0: Interrupt output disabled | | | | | | 1: Interrupt output enabled | | | | | | | # 17.3.15 SOF Control Register (SOFCFG) SOFCFG is a register that specifies the transaction-enabled time and BRDY interrupt status clear timing. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|--------------|---|-------|----|---|---|---|---|---| | [ | _ | _ | _ | _ | _ | _ | _ | TRNEN<br>SEL | _ | BRDYM | _ | _ | _ | I | - | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0* | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W | R | R/W | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 | TRNENSEL | 0 | R/W | Transaction-Enabled Time Select | | | | | | Selects the transaction-enabled time either for full- or low-speed communication, where is the time in which this module issues tokens in a frame via the port. | | | | | | 0: For non-low-speed communication | | | | | | 1: For low-speed communication | | | | | | This bit is valid only when the host controller function is selected. Even when the host controller function is selected, the setting of this bit has no effect on the transaction-enabled time during high-speed communication. | | | | | | This bit should be set to 0 when the function controller function is selected. | | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | BRDYM | 0 | R/W | BRDY Interrupt Status Clear Timing for each Pipe | | | | | | Specifies the timing for clearing the BRDY interrupt status for each pipe. | | | | | | 0: Software clears the status. | | | | | | 1: This module clears the status when data has been read from the FIFO buffer or data has been written to the FIFO buffer. | | 5 | _ | 0* | R | Reserved | | | | | | This bit is reserved. The previously read value should be written to this bit. | | | | | | Note: Although this bit is initialized to 0 by a power-<br>on reset, be sure to set this bit to 1 using the<br>initialization routine of this module. | | 4 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Note: \* Although this bit is initialized to 0 by a power-on reset, be sure to set this bit to 1 using the initialization routine of this module. # 17.3.16 Interrupt Status Register 0 (INTSTS0) INTSTS0 is a register that indicates the status of the various interrupts detected. This register is initialized by a power-on reset. By a USB bus reset, the DVSQ2 to DVSQ0 bits are initialized. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---------|---------|---------|---------|---------|------|------|------|-------|----|-----------|----|----------|---|-----------|---| | | VBINT | RESM | SOFR | DVST | CTRT | BEMP | NRDY | BRDY | VBSTS | | DVSQ[2:0] | | VALID | | CTSQ[2:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | *3 | *2 | *2 | *2 | 0 | 0 | 0 | 0 | | R/W | D/\//∗7 | ₽/\//*7 | ₽/\//*7 | ₽/\//*7 | ₽/\//*7 | R | R | R | R | R | R | R | ₽/\\\/*7 | B | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | VBINT | 0 | R/W* <sup>7</sup> | VBUS Interrupt Status*4*5 | | | | | | 0: VBUS interrupts not generated | | | | | | 1: VBUS interrupts generated | | | | | | This module sets this bit to 1 on detecting a level change (high to low or low to high) in the VBUS pin input value. This module sets the VBSTS bit to indicate the VBUS pin input value. When the VBUS interrupt is generated, use software to repeat reading the VBSTS bit until the same value is read three or more times, and eliminate chattering. | | 14 | RESM | 0 | R/W* <sup>7</sup> | Resume Interrupt Status* <sup>4</sup> * <sup>5</sup> * <sup>6</sup> | | | | | | 0: Resume interrupts not generated | | | | | | 1: Resume interrupts generated | | | | | | When the function controller function is selected, this module sets this bit to 1 on detecting the falling edge of the signal on the DP pin in the suspended state (DVSQ = 1XX). | | | | | | When the host controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | SOFR | 0 | R/W* <sup>7</sup> | Frame Number Refresh Interrupt Status*4 | | | | | | 0: SOF interrupts not generated | | | | | | 1: SOF interrupts generated | | | | | | (1) When the host controller function is selected | | | | | | This module sets this bit to 1 on updating the frame number when software has set the UACT bit to 1. (This interrupt is detected every 1 ms.) | | | | | | (2) When the function controller function is selected | | | | | | This module sets this bit to 1 on updating the frame number. (This interrupt is detected every 1 ms.) | | | | | | This module can detect an SOFR interrupt through the internal interpolation function even when a damaged SOF packet is received from the USB host. | | 12 | DVST | 0/1*1 | R/W*7 | Device State Transition Interrupt Status* <sup>4</sup> * <sup>6</sup> | | | | | | 0: Device state transition interrupts not generated | | | | | | 1: Device state transition interrupts generated | | | | | | When the function controller function is selected, this module updates the DVSQ value and sets this bit to 1 on detecting a change in the device state. | | | | | | When this interrupt is generated, clear the status before this module detects the next device state transition. | | | | | | When the host controller function is selected, the read value is invalid. | | 11 | CTRT | 0 | R/W*7 | Control Transfer Stage Transition Interrupt Status*** | | | | | | Control transfer stage transition interrupts not generated | | | | | | Control transfer stage transition interrupts<br>generated | | | | | | When the function controller function is selected, this module updates the CTSQ value and sets this bit to 1 on detecting a change in the control transfer stage. | | | | | | When this interrupt is generated, clear the status before this module detects the next control transfer stage transition. | | | | | | When the host controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 | ВЕМР | 0 | R | Buffer Empty Interrupt Status | | | | | | 0: BEMP interrupts not generated | | | | | | 1: BEMP interrupts generated | | | | | | This module sets this bit to 1 when at least one PIPEBEMP bit in BEMPSTS is set to 1 among the PIPEBEMP bits corresponding to the PIPEBEMPE bits in BEMPENB to which 1 has been set (when this module detects the BEMP interrupt status in at least one pipe among the pipes for which software enables the BEMP interrupt output). | | | | | | For the conditions for PIPEBEMP status assertion, refer to (3) BEMP Interrupts under section 17.4.2, Interrupt Functions. | | | | | | This module clears this bit to 0 when software writes 0 to all the PIPEBEMP bits corresponding to the PIPEBEMPE bits to which 1 has been set. | | | | | | This bit cannot be cleared to 0 even if software writes 0 to this bit. | | 9 | NRDY | 0 | R | Buffer Not Ready Interrupt Status | | | | | | 0: NRDY interrupts not generated | | | | | | 1: NRDY interrupts generated | | | | | | This module sets this bit to 1 when at least one PIPENRDY bit in NRDYSTS is set to 1 among the PIPENRDY bits corresponding to the PIPENRDYE bits in NRDYENB to which 1 has been set (when this module detects the NRDY interrupt status in at least one pipe among the pipes for which software enables the NRDY interrupt output). | | | | | | For the conditions for PIPENRDY status assertion, refer to (2) NRDY Interrupts under section 17.4.2, Interrupt Functions. | | | | | | This module clears this bit to 0 when software writes 0 to all the PIPENRDY bits corresponding to the PIPENRDYE bits to which 1 has been set. | | | | | | This bit cannot be cleared to 0 even if software writes 0 to this bit. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | BRDY | 0 | R | Buffer Ready Interrupt Status | | | | | | Indicates the BRDY interrupt status. | | | | | | 0: BRDY interrupts not generated | | | | | | 1: BRDY interrupts generated | | | | | | This module sets this bit to 1 when at least one PIPEBRDY bit in BRDYSTS is set to 1 among the PIPEBRDY bits corresponding to the PIPEBRDYE bits in BRDYENB to which 1 has been set (when this module detects the BRDY interrupt status in at least one pipe among the pipes for which software enables the BRDY interrupt output). | | | | | | For the conditions for PIPEBRDY status assertion, refer to (1) BRDY Interrupts under section 17.4.2, Interrupt Functions. | | | | | | This module clears this bit to 0 when software writes 0 to all the PIPEBRDY bits corresponding to the PIPEBRDYE bits to which 1 has been set. | | | | | | This bit cannot be cleared to 0 even if software writes 0 to this bit. | | 7 | VBSTS | 0/1*3 | R | VBUS Input Status | | | | | | 0: The VBUS pin is low level. | | | | | | 1: The VBUS pin is high level. | | 6 to 4 | DVSQ[2:0] | 000/001*2 | R | Device State | | | | | | 000: Powered state | | | | | | 001: Default state | | | | | | 010: Address state | | | | | | 011: Configured state | | | | | | 1xx: Suspended state | | | | | | When the host controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-----------|------------------|-------------------|---------------------------------------------------------------------------| | 3 | VALID | 0 | R/W* <sup>7</sup> | USB Request Reception | | | | | | 0: Not detected | | | | | | 1: Setup packet reception | | | | | | When the host controller function is selected, the read value is invalid. | | 2 to 0 | CTSQ[2:0] | 000 | R | Control Transfer Stage | | | | | | 000: Idle or setup stage | | | | | | 001: Control read data stage | | | | | | 010: Control read status stage | | | | | | 011: Control write data stage | | | | | | 100: Control write status stage | | | | | | 101: Control write (no data) status stage | | | | | | 110: Control transfer sequence error | | | | | | 111: Setting prohibited | | | | | | When the host controller function is selected, the read value is invalid. | Notes: 1. This bit is initialized to B'0 by a power-on reset and B'1 by a USB bus reset. - 2. These bits are initialized to B'000 by a power-on reset and B'001 by a USB bus reset. - 3. This bit is initialized to 0 when the level of the VBUS pin input is high and 1 when low. - 4. To clear the VBINT, RESM, SOFR, DVST, or CTRT bit, write 0 only to the bits to be cleared; write 1 to the other bits. Do not write 0 to the status bits indicating 0. - 5. A change in the status indicated by the VBINT and RESM bits can be detected even while the clock supply is stopped (while SCKE is 0), and the interrupts are output when the corresponding interrupt enable bits are enabled. Clearing the status through software should be done after enabling the clock supply. - A change in the status of the RESM, DVST, and CTRT bits occur only when the function controller function is selected; disable the corresponding interrupt enable bits (set to 0) when the function controller function is selected. - 7. Only 0 can be written to. ### 17.3.17 Interrupt Status Register 1 (INTSTS1) INTSTS1 is a register that is used to confirm interrupt status. Interrupt generation can be confirmed simply by referencing one of the registers: INTSTS0 when the function controller function is selected and INTSTS1 when the host controller function is selected. The various interrupts indicated by the bits in this register should be enabled only when the host controller function is selected. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-------|----|-------|-------|----|---|---|---|------------|-------|-------|---|---|---|---| | [ | _ | BCHG | _ | DTCH | ATTCH | _ | _ | _ | _ | EOF<br>ERR | SIGN | SACK | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W*1 | R | R/W*1 | R/W*1 | R | R | R | R | R/W*1 | R/W*1 | R/W*1 | R | R | R | R | | | | 1 141 - 1 | | | |-----|----------|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Initial<br>Value | R/W | Description | | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 | BCHG | 0 | R/W*1 | USB Bus Change Interrupt Status | | | | | | Indicates the status of the USB bus change interrupt. | | | | | | 0: BCHG interrupts not generated | | | | | | 1: BCHG interrupts generated | | | | | | This module detects the BCHG interrupt when a change in the full-speed or low-speed signal level occurs on the USB port (a change from J-state, K-state, or SE0 to J-state, K-state, or SE0), and sets this bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, this module generates the interrupt. | | | | | | This module sets the LNST bits in SYSSTS0 to indicate the current input state of the USB port. When the BCHG interrupt is generated, use software to repeat reading the LNST bits until the same value is read three or more times, and eliminate chattering. | | | | | | A change in the USB bus state can be detected even while the internal clock supply is stopped. | | | | | | When the function controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | DTCH | 0 | R/W*1 | USB Disconnection Detection Interrupt Status | | | | | | Indicates the status of the USB disconnection detection interrupt when the host controller function is selected. | | | | | | 0: DTCH interrupts not generated | | | | | | 1: DTCH interrupts generated | | | | | | This module detects the DTCH interrupt on detecting USB bus disconnection, and sets this bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, this module generates the interrupt. This module detects bus disconnection based on USB Specification 2.0. | | | | controls hardware as describe the set value of the correspond Software should terminate all to communications are currently port and make a transition to to connection to the USB port (w | After detecting the DTCH interrupt, this module controls hardware as described below (irrespective of the set value of the corresponding interrupt enable bit). Software should terminate all the pipes in which communications are currently carried out for the USB port and make a transition to the wait state for bus connection to the USB port (wait state for ATTCH interrupt generation). | | | | | | | • Modifies the UACT bit for the port in which a DTCH interrupt has been detected to 0. | | | | | | <ul> <li>Puts the port in which a DTCH interrupt has been<br/>generated into the idle state.</li> </ul> | | | | | | When the function controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | ATTCH | 0 | R/W*1 | ATTCH Interrupt Status | | | | | | Indicates the status of the ATTCH interrupt when the host controller function is selected. | | | | | | 0: ATTCH interrupts not generated | | | | | | 1: ATTCH interrupts generated | | | | | | This module detects the ATTCH interrupt on detecting J-state or K-state of the full-speed or low-speed level signal for 2.5 $\mu$ s, and sets this bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, this module generates the interrupt. | | | | | | Specifically, this module detects the ATTCH interrupt on any of the following conditions. | | | | | | • K-state, SE0, or SE1 changes to J-state, and J-state continues 2.5 μs. | | | | | | • J-state, SE0, or SE1 changes to K-state, and K-state continues 2.5 μs. | | | | | | When the function controller function is selected, the read value is invalid. | | 10 to 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | EOFERR | 0 | R/W* <sup>1</sup> | • | | | | | | Indicates the status of the EOFERR interrupt when the host controller function is selected. | | | | | | 0: EOFERR interrupt not generated | | | | | | 1: EOFERR interrupt generated | | | | | | This module detects the EOFERR interrupt on detecting that communication is not completed at the EOF2 timing prescribed by USB Specification 2.0, and sets this bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, this module generates the EOFERR interrupt. | | | | | | After detecting the EOFERR interrupt, this module controls hardware as described below (irrespective of the set value of the corresponding interrupt enable bit). Software should terminate all the pipes in which communications are currently carried for the USB port and perform re-enumeration of the USB port. | | | | | | <ul> <li>Modifies the UACT bit for the port in which an<br/>EOFERR interrupt has been detected to 0.</li> </ul> | | | | | | Puts the port in which an EOFERR interrupt has been generated into the idle state. | | | | | | When the function controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | SIGN | 0 | R/W*1 | Setup Transaction Error Interrupt Status | | | | | | Indicates the status of the setup transaction error interrupt when the host controller function is selected. | | | | | | 0: SIGN interrupts not generated | | | | | | 1: SIGN interrupts generated | | | | | | This module detects the SIGN interrupt when ACK response is not returned from the peripheral device three consecutive times during the setup transactions issued by this module, and sets this bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, this module generates the SIGN interrupt. | | | | | | Specifically, this module detects the SIGN interrupt when any of the following response conditions occur for three consecutive setup transactions. | | | | | | • Timeout is detected when the peripheral device has returned no response. | | | | | | A damaged ACK packet is received. | | | | | | A handshake other than ACK (NAK, NYET, or | | | | | | STALL) is received. | | | | | | When the function controller function is selected, the read value is invalid. | | 4 | SACK | 0 | R/W*1 | Setup Transaction Normal Response Interrupt Status | | | | | | Indicates the status of the setup transaction normal response interrupt when the host controller function is selected. | | | | | | 0: SACK interrupts not generated | | | | | | 1: SACK interrupts generated | | | | | | This module detects the SACK interrupt when ACK response is returned from the peripheral device during the setup transactions issued by this module, and sets this bit to 1. Here, if software has set the corresponding interrupt enable bit to 1, this module generates the SACK interrupt. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------| | 3 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | - Notes: 1. To clear the status indicated by the bits in this register, write 0 only to the bits to be cleared; write 1 to the other bits. - A change in the status indicated by the BCHG bit can be detected even while the clock supply is stopped (while SCKE is 0), and the interrupt is output when the corresponding interrupt enable bit is enabled. Clearing the status through software should be done after enabling the clock supply. - No interrupts other than BCHG can be detected while the clock supply is stopped (while SCKE is 0). # 17.3.18 BRDY Interrupt Status Register (BRDYSTS) BRDYSTS is a register that indicates the BRDY interrupt status for each pipe. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------| | | _ | _ | _ | _ | _ | _ | PIPE9<br>BRDY | PIPE8<br>BRDY | PIPE7<br>BRDY | PIPE6<br>BRDY | PIPE5<br>BRDY | PIPE4<br>BRDY | PIPE3<br>BRDY | PIPE2<br>BRDY | PIPE1<br>BRDY | PIPE0<br>BRDY | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W*1 | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|-------|----------------------------------------------------------------------| | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PIPE9BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE9*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 8 | PIPE8BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE8*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 7 | PIPE7BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE7*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 6 | PIPE6BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE6*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 5 | PIPE5BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE5*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 4 | PIPE4BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE4*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 3 | PIPE3BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE3*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|-----------|------------------|-------|-----------------------------------| | 2 | PIPE2BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE2*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 1 | PIPE1BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE1*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 0 | PIPE0BRDY | 0 | R/W*1 | BRDY Interrupt Status for PIPE0*2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | Notes: 1. When BRDYM is 0, to clear the status indicated by the bits in this register, write 0 only to the bits to be cleared; write 1 to the other bits. 2. When BRDYM is 0, clearing this bit should be done before accessing the FIFO. ### 17.3.19 NRDY Interrupt Status Register (NRDYSTS) NRDYSTS is a register that indicates the NRDY interrupt status for each pipe. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|----|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------| | [ | _ | _ | _ | _ | _ | _ | PIPE9<br>NRDY | PIPE8<br>NRDY | PIPE7<br>NRDY | PIPE6<br>NRDY | PIPE5<br>NRDY | PIPE4<br>NRDY | PIPE3<br>NRDY | PIPE2<br>NRDY | PIPE1<br>NRDY | PIPE0<br>NRDY | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | R | R | R | R | R | R | R/W* | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|------|----------------------------------------------------------------------| | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PIPE9NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE9 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 8 | PIPE8NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE8 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|-----------|------------------|------|---------------------------------| | 7 | PIPE7NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE7 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 6 | PIPE6NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE6 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 5 | PIPE5NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE5 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 4 | PIPE4NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE4 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 3 | PIPE3NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE3 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 2 | PIPE2NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 1 | PIPE1NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE1 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 0 | PIPE0NRDY | 0 | R/W* | NRDY Interrupt Status for PIPE0 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | Note: \* To clear the status indicated by the bits in this register, write 0 only to the bits to be cleared; write 1 to the other bits. # 17.3.20 BEMP Interrupt Status Register (BEMPSTS) BEMPSTS is a register that indicates the BEMP interrupt status for each pipe. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---------------|---------------|---------------|---------------|---------------|---------------|---------------|------|---------------|---------------| | [ | _ | _ | _ | _ | _ | - | PIPE9<br>BEMP | PIPE8<br>BEMP | PIPE7<br>BEMP | PIPE6<br>BEMP | PIPE5<br>BEMP | PIPE4<br>BEMP | PIPE3<br>BEMP | | PIPE1<br>BEMP | PIPE0<br>BEMP | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R | R | R | R | R | R/M* | R/M* | R/M* | R/W* | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|-----------|------------------|------|----------------------------------------------------------------------| | 15 to 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PIPE9BEMP | 0 | R/W* | BEMP Interrupts for PIPE9 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 8 | PIPE8BEMP | 0 | R/W* | BEMP Interrupts for PIPE8 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 7 | PIPE7BEMP | 0 | R/W* | BEMP Interrupts for PIPE7 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 6 | PIPE6BEMP | 0 | R/W* | BEMP Interrupts for PIPE6 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | - | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|-----------|------------------|------|-----------------------------| | 5 | PIPE5BEMP | 0 | R/W* | BEMP Interrupts for PIPE5 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 4 | PIPE4BEMP | 0 | R/W* | BEMP Interrupts for PIPE4 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 3 | PIPE3BEMP | 0 | R/W* | BEMP Interrupts for PIPE3 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 2 | PIPE2BEMP | 0 | R/W* | BEMP Interrupts for PIPE2 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 1 | PIPE1BEMP | 0 | R/W* | BEMP Interrupts for PIPE1 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | | 0 | PIPE0BEMP | 0 | R/W* | BEMP Interrupts for PIPE0 | | | | | | 0: Interrupts not generated | | | | | | 1: Interrupts generated | Note: \* To clear the status indicated by the bits in this register, write 0 only to the bits to be cleared; write 1 to the other bits. # 17.3.21 Frame Number Register (FRMNUM) FRMNUM is a register that determines the source of isochronous error notification and indicates the frame number. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|------|----|----|----|----|---|---|---|---|---------|----|---|---|---|---| | [ | OVRN | CRCE | _ | - | _ | | | | | F | RNM[10: | 0] | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W* | R/W* | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | OVRN | 0 | R/W* | Overrun/Underrun Detection Status | | | | | | Indicates whether an overrun/underrun error has been detected in the pipe during isochronous transfer. | | | | | | 0: No error | | | | | | 1: An error occurred | | | | | | Software can clear this bit to 0 by writing 0 to the bit. Here, 1 should be written to the other bits in this register. | | | | | | (1) When the host controller function is selected | | | | | | This module sets this bit to 1 on any of the following conditions. | | | | | | <ul> <li>For the isochronous transfer pipe in the<br/>transmitting direction, the time to issue an OUT<br/>token comes before all the transmit data has<br/>been written to the FIFO buffer.</li> </ul> | | | | | | <ul> <li>For the isochronous transfer pipe in the receiving<br/>direction, the time to issue an IN token comes<br/>when no FIFO buffer planes are empty.</li> </ul> | | | | | | (2) When the function controller function is selected | | | | | | This module sets this bit to 1 on any of the following conditions. | | | | | | <ul> <li>For the isochronous transfer pipe in the<br/>transmitting direction, the IN token is received<br/>before all the transmit data has been written to<br/>the FIFO buffer.</li> </ul> | | | | | | <ul> <li>For the isochronous transfer pipe in the receiving<br/>direction, the OUT token is received when no<br/>FIFO buffer planes are empty.</li> </ul> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|--------------|------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 14 | CRCE | 0 | R/W* | Receive Data Error | | | | | | Indicates whether a CRC error or bit stuffing error has been detected in the pipe during isochronous transfer. | | | | | | 0: No error | | | | | | 1: An error occurred | | | | | | Software can clear this bit to 0 by writing 0 to the bit. Here, 1 should be written to the other bits in this register. | | | | | | (1) When the host controller function is selected | | | | | | On detecting a CRC error, this module generates the internal NRDY interrupt request. | | | | | | (2) When the function controller function is selected | | | | | | On detecting a CRC error, this module does not generate the internal NRDY interrupt request. | | 13 to 11 | | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 to 0 | FRNM[10:0] | H'000 | R | Frame Number | | | | | | This module sets these bits to indicate the latest frame number, which is updated every time an SOF packet is issued or received (every 1 ms) | | Note: * | Only 0 con h | | | Repeat reading these bits until the same value is read twice. | Note: \* Only 0 can be written to # 17.3.22 µFrame Number Register (UFRMNUM) UFRMNUM is a register that indicates the µframe number. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---------|----| | [ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | U | FRNM[2: | 0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | B | R | R | R | R | R | B | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|------------|------------------|-----|---------------------------------------------------------------------------------------------| | 15 to 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 to 0 | UFRNM[2:0] | 000 | R | μFrame | | | | | | The $\mu$ frame number can be confirmed. | | | | | | This module sets these bits to indicate the $\mu$ frame number during high-speed operation. | | | | | | During operation other than high-speed operation, this module sets these bits to B'000. | | | | | | Repeat reading these bits until the same value is read twice. | #### 17.3.23 USB Address Register (USBADDR) USBADDR is a register that indicates the USB address. This register is valid only when the function controller function is selected. When the host controller function is selected, peripheral device addresses should be set using the DEVSEL bits in PIPEMAXP. This register is initialized by a power-on reset or a USB bus reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------| | 15 to 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 6 to 0 | USBADDR | H'00 | R | USB Address | | | [6:0] | | When the function controller function is selected, these bits indicate the USB address assigned by the host when the SET_ADDRESS request is successfully processed. | | | | | | | On detecting the USB reset, this module sets these bits to H'00. | | | | | | When the host controller function is selected, these bits are invalid. | ### **USB Request Type Register (USBREQ)** USBREQ is a register that stores setup requests for control transfers. When the function controller function is selected, the values of bRequest and bmRequestType that have been received are stored. When the host controller function is selected, the values of bRequest and bmRequestType to be transmitted are set. This register is initialized by a power-on reset or a USB bus reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------------|------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 8 | BREQUEST [7:0] | H'00 | R/W* | Request These bits store the USB request bRequest value. (1) When the host controller function is selected The USB request data value for the setup transaction to be transmitted should be set in these bits. Do not modify these bits while SUREQ is 1. | | | | | | (2) When the function controller function is selected Indicates the USB request data value received during the setup transaction. Writing to these bits is invalid. | | | | Initial | | | |--------|------------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 7 to 0 | BMREQUEST- | H'00 | R/W* | Request Type | | | TYPE[7:0] | | | These bits store the USB request bmRequestType value. | | | | | | (1) When the host controller function is selected | | | | | | The USB request type value for the setup transaction to be transmitted should be set in these bits. Do not modify these bits while SUREQ is 1. | | | | | | (2) When the function controller function is selected | | | | | | Indicates the USB request type value received during the setup transaction. Writing to these bits is invalid. | #### 17.3.25 USB Request Value Register (USBVAL) USBVAL is a register that stores setup requests for control transfers. When the function controller function is selected, the value of wValue that has been received is stored. When the host controller function is selected, the value of wValue to be transmitted is set. This register is initialized by a power-on reset or a USB bus reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----------------|-------|-------|------|------|--------|-------|-------|---------|------|------|------|------|------|-------|------| | | | | | | | | | WVALU | E[15:0] | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W·I | <b>Ω/</b> ///× | D/M/* | D/M/* | ₽/M* | ₽/M* | ₽/\//× | ₽/M/* | D/M/* | ₽/M* | R/M* | ₽/M* | ₽/M* | D/M* | ₽/M* | D/M/* | ₽/M* | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 0 | WValue[15:0] | H'0000 | R/W* | Value | | | | | | These bits store the USB request wValue value. | | | | | | (1) When the host controller function is selected | | | | | | The USB request wValue value for the setup transaction to be transmitted should be set in these bits. Do not modify these bits while SUREQ is 1. | | | | | | (2) When the function controller function is selected | | | | | | Indicates the USB request wValue value received during the setup transaction. Writing to these bits is invalid. | #### 17.3.26 USB Request Index Register (USBINDX) USBINDEX is a register that stores setup requests for control transfers. When the function controller function is selected, the value of wIndex that has been received is stored. When the host controller function is selected, the value of wIndex to be transmitted is set. This register is initialized by a power-on reset or a USB bus reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 0 | WINDEX[15:0] | H'0000 | R/W* | Index | | | | | | These bits store the USB request wIndex value. | | | | | | (1) When the host controller function is selected | | | | | | The USB request windex value for the setup transaction to be transmitted should be set in these bits. Do not modify these bits while SUREQ is 1. | | | | | | (2) When the function controller function is selected | | | | | | Indicates the USB request windex value received during the setup transaction. Writing to these bits is invalid. | #### 17.3.27 USB Request Length Register (USBLENG) USBLENG is a register that stores setup requests for control transfers. When the function controller function is selected, the value of wLength that has been received is stored. When the host controller function is selected, the value of wLength to be transmitted is set. This register is initialized by a power-on reset or a USB bus reset. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|-------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 0 | WLENGTH | H'0000 | R/W* | Length | | [15:0] | | These bits store the USB request wLength value. | | | | | | | | (1) When the host controller function is selected | | | | | | The USB request wLength value for the setup transaction to be transmitted should be set in these bits. Do not modify these bits while SUREQ is 1. | | | | | | (2) When the function controller function is selected | | | | | | Indicates the USB request wLength value received during the setup transaction. Writing to these bits is invalid. | # 17.3.28 DCP Configuration Register (DCPCFG) DCPCFG is a register that specifies the data transfer direction for the default control pipe (DCP). | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|-----|---|---|---|---| | | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | 1 | _ | DIR | _ | _ | | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------------------------------------| | 15 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | DIR | 0 | R/W | Transfer Direction | | | | | | When the host controller function is selected, this bit sets the transfer direction of data stage. | | | | | | 0: Data receiving direction | | | | | | 1: Data transmitting direction | | | | | | When the function controller function is selected, this bit should be cleared to 0. | | 3 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | # 17.3.29 DCP Maximum Packet Size Register (DCPMAXP) DCPMAXP is a register that specifies the maximum packet size for the DCP. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|------|---------|-----|----|----|---|---|---|-----|-----|-----|------------|---|---|---| | [ | | DEVS | EL[3:0] | | _ | _ | _ | _ | _ | | | Ņ | //XPS[6:0] | ] | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | R/W | R/W | R/W | R/M | R/W | R | R | R | R | R | R/M | R/W | R/M | R/W | R | R | R | | | | Initial | | | |----------|-------------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 12 | DEVSEL[3:0] | 0000 | R/W | Device Select | | | | | | When the host controller function is selected, these bits specify the communication target peripheral device address. | | | | | | 0000: Address 0000 | | | | | | 0001: Address 0001 | | | | | | : : | | | | | | 1001: Address 1001 | | | | | | 1010: Address 1010 | | | | | | Other than above: Setting prohibited | | | | | | These bits should be set after setting the address to<br>the DEVADDn register corresponding to the value<br>to be set in these bits. | | | | | | For example, before setting DEVSEL to 0010, the address should be set to the DEVADD2 register. | | | | | | These bits should be set while CSSTS is 0, PID is NAK, and SUREQ is 0. | | | | | | Before modifying these bits after modifying the PID bits for the DCP from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | When the function controller function is selected, these bits should be set to B'0000. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 to 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 6 to 0 | MXPS[6:0] | H'40 | R/W | Maximum Packet Size | | | | | | Specifies the maximum data payload (maximum packet size) for the DCP. | | | | | | These bits are initialized to H'40 (64 bytes). | | | | | | These bits should be set to the value based on the USB Specification. | | | | | | These bits should be set while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | Before modifying these bits after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | While MXPS is 0, do not write to the FIFO buffer or do not set PID to BUF. | # 17.3.30 DCP Control Register (DCPCTR) DCPCTR is a register that is used to confirm the buffer memory status, change and confirm the data PID sequence bit, and set the response PID for the DCP. This register is initialized by a power-on reset. The CCPL and PID[1:0] bits are initialized by a USB bus reset. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|--------|--------|-------|--------------|----|---|---------|---------|-------|-------|-------|---|----------|-----|-------| | | BSTS | SUREQ | CSCLR | CSSTS | SUREQ<br>CLR | _ | _ | SQCLR | SQSET | SQMON | PBUSY | PINGE | _ | CCPL | PID | [1:0] | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/M | . р | D/M/*2 | D/M/*1 | D/M | D /\\/∗1 | D | D | D/\//*1 | D/\//*1 | D | D | D/M | D | D /\∧/∗1 | DAM | DAM | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | BSTS | 0 | R | Buffer Status | | | | | | Indicates whether DCP FIFO buffer access is enabled or disabled. | | | | | | 0: Buffer access is disabled. | | | | | | 1: Buffer access is enabled. | | | | | | The meaning of the BSTS bit depends on the ISEL bit setting as follows. | | | | | | <ul> <li>When ISEL = 0, BSTS indicates whether the<br/>received data can be read from the buffer.</li> </ul> | | | | | | • When ISEL = 1, BSTS indicates whether the | | | | | | data to be transmitted can be written to the buffer. | | 14 | SUREQ | 0 | R/W* <sup>2</sup> | SETUP Token Transmission | | | | | | Transmits the setup packet by setting this bit to 1 when the host controller function is selected. | | | | | | 0: Invalid | | | | | | 1: Transmits the setup packet. | | | | | | After completing the setup transaction process, this module generates either the SACK or SIGN interrupt and clears this bit to 0. | | | | | | This module also clears this bit to 0 when software sets the SUREQCLR bit to 1. | | | | | | Before setting this bit to 1, set the DEVSEL bits, USBREQ register, USBVAL register, USBINDX register, and USBLENG register appropriately to transmit the desired USB request in the setup transaction. | | | | | | Before setting this bit to 1, check that the PID bits for the DCP are set to NAK. After setting this bit to 1, do not modify the DEVSEL bits, USBREQ register, USBVAL register, USBINDX register, or USBLENG register until the setup transaction is completed (SUREQ = 1). | | | | | | Write 1 to this bit only when transmitting the setup token; for the other purposes, write 0. | | | | | | When the function controller function is selected, be sure to write 0 to this bit. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | CSCLR | 0 | R/W*1 | C-SPLIT Status Clear for Split Transaction | | | | | | When the host controller function is selected, setting this bit to 1 clears the CSSTS bit to 0 for the transfer using the split transaction. In this case, the next DCP transfer restarts with the S-SPLIT. | | | | | | 0: Invalid | | | | | | 1: Clears the CSSTS bit to 0. | | | | | | When software sets this bit to 1, this module clears the CSSTS bit to 0. | | | | | | For the transfer using the split transaction, to restart the next transfer with the S-SPLIT forcibly, set this bit to 1 through software. However, for the normal split transaction, this module automatically clears the CSSTS bit to 0 upon completion of the C-SPLIT; therefore, clearing the CSSTS bit through software is not necessary. | | | | | | Controlling the CSSTS bit through this bit must be done while UACT is 0 and thus communication is halted or while no transfer is being performed with bus disconnection detected. | | | | | | Setting this bit to 1 while CSSTS is 0 has no effect. | | | | | | When the function controller function is selected, be sure to write 0 to this bit. | | 12 | CSSTS | 0 | R | COMPLETE SPLIT (C-SPLIT) Status of Split<br>Transaction | | | | | | Indicates the C-SPLIT status of the split transaction when the host controller function is selected. | | | | | | START-SPLIT (S-SPLIT) transaction being processed or the device not using the split transaction being processed | | | | | | 1: C-SPLIT transaction being processed | | | | | | This module sets this bit to 1 upon start of the C-SPLIT and clears this bit to 0 upon detection of C-SPLIT completion. | | | | | | When the function controller function is selected, the read value is invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-------|----------|------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | SUREQCLR | 0 | R/W*1 | SUREQ Bit Clear | | | | | | When the host controller function is selected, setting this bit to 1 clears the SUREQ bit to 0. | | | | | | 0: Invalid | | | | | | 1: Clears the SUREQ bit to 0. | | | | | | This bit always indicates 0. | | | | | | Set this bit to 1 through software when communication has stopped with SUREQ being 1 during the setup transaction. However, for normal setup transactions, this module automatically clears the SUREQ bit to 0 upon completion of the transaction; therefore, clearing the SUREQ bit through software is not necessary. | | | | | | Controlling the SUREQ bit through this bit must be done while UACT is 0 and thus communication is halted or while no transfer is being performed with bus disconnection detected. | | | | | | When the function controller function is selected, be sure to write 0 to this bit. | | 10, 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 8 | SQCLR | 0 | R/W*1 | Toggle Bit Clear | | | | | | Specifies DATA0 as the expected value of the sequence toggle bit for the next transaction during the DCP transfer. | | | | | | 0: Invalid | | | | | | 1: Specifies DATA0. | | | | | | This bit always indicates 0. | | | | | | Do not set the SQCLR and SQSET bits to 1 simultaneously. | | | | | | Set this bit to 1 while CSSTS is 0, PID is NAK, and CURPIPE bits are not yet set. | | | | | | Before setting this bit to 1 after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. | | | | | | However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | 7 | SQSET | 0 | R/W*1 | Toggle Bit Set | | | | | | Specifies DATA1 as the expected value of the sequence toggle bit for the next transaction during the DCP transfer. | | | | | | 0: Invalid | | | | | | 1: Specifies DATA1. | | | | | | Do not set the SQCLR and SQSET bits to 1 simultaneously. | | | | | | Set this bit to 1 while CSSTS is 0, PID is NAK, and CURPIPE bits are not yet set. | | | | | | Before setting this bit to 1 after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. | | | | | | However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | SQMON | 1 | R | Sequence Toggle Bit Monitor | | | | | | Indicates the expected value of the sequence toggle bit for the next transaction during the DCP transfer. | | | | | | 0: DATA0 | | | | | | 1: DATA1 | | | | | | This module allows this bit to toggle upon normal completion of the transaction. However, this bit is not allowed to toggle when a DATA-PID disagreement occurs during the transfer in the receiving direction. | | | | | | When the function controller function is selected, this module sets this bit to 1 (specifies DATA1 as the expected value) upon normal reception of the setup packet. | | | | | | When the function controller function is selected, this module does not reference to this bit during the IN/OUT transaction of the status stage, and does not allow this bit to toggle upon normal completion. | | 5 | PBUSY | 0 | R | Pipe Busy | | | | | | This bit indicates whether DCP is used or not for the transaction when USB changes the PID bits from BUF to NAK. | | | | | | 0: DCP is not used for the transaction. | | | | | | 1: DCP is used for the transaction. | | | | | | This module modifies this bit from 0 to 1 upon start of the USB transaction for the pertinent pipe, and modifies the bit from 1 to 0 upon completion of one transaction. | | | | | | Reading this bit after software has set PID to NAK allows checking that modification of the pipe settings is possible. | | | | | | For details, refer to (1) Pipe Control Register<br>Switching Procedures under section 17.4.3, Pipe<br>Control. | | Enable troller function is selected, allows this module to issue the transfers in the transmitting a transfer in the transmitting PING transaction. | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | allows this module to issue the transfers in the transmitting a transfer in the transmitting | | | | PING token. | | PING operation. | | cted the ACK handshake during<br>, this module performs the OUT<br>next transaction. | | cted the NAK handshake during this module performs the PING next transaction. | | troller function is selected,<br>through software prevents this<br>of the PING token during<br>asmitting direction and only<br>to perform OUT transactions for<br>transmitting direction. | | be modified while CSSTS is 0 | | bit to 1 after modifying the PID onding pipe from BUF to NAK, and PBUSY are 0. However, if been modified to NAK by this PBUSY through software is not | | controller function is selected, be nis bit. | | | | ead as 0. The write value should | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | CCPL | 0 | R/W*1 | Control Transfer End Enable | | | | | | When the function controller function is selected, setting this bit to 1 enables the status stage of the control transfer to be completed. | | | | | | 0: Invalid | | | | | | 1: Completion of control transfer is enabled. | | | | | | When software sets this bit to 1 while the corresponding PID bits are set to BUF, this module completes the control transfer stage. | | | | | | Specifically, during control read transfer, this module transmits the ACK handshake in response to the OUT transaction from the USB host, and outputs the zero-length packet in response to the IN transaction from the USB host during control write or no-data control transfer. However, on detecting the SET_ADDRESS request, this module operates in auto response mode from the setup stage up to the status stage completion irrespective of the setting of this bit. | | | | | | This module modifies this bit from 1 to 0 on receiving the new setup packet. | | | | | | Software cannot write 1 to this bit while VALID is 1. | | | | | | When the host controller function is selected, be sure to write 0 to this bit. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | PID[1:0] | 00 | R/W | Response PID | | | | | | Controls the response type of this module during control transfer. | | | | | | 00: NAK response | | | | | | 01: BUF response (depending on the buffer state) | | | | | | 10: STALL response | | | | | | 11: STALL response | | | | | | (1) When the host controller function is selected | | | | | | Modify the setting of these bits from NAK to BUF using the following procedure. | | | | | | <ul> <li>When the transmitting direction is set</li> </ul> | | | | | | Write all the transmit data to the FIFO buffer while UACT is 1 and PID is NAK, and then set PID to BUF. After PID has been set to BUF, this module executes the OUT transaction (or PING transaction). | | | | | | When the receiving direction is set | | | | | | Check that the FIFO buffer is empty (or empty the buffer) while UACT is 1 and PID is NAK, and then set PID to BUF. After PID has been set to BUF, this module executes the IN transaction. | | | | | | This module modifies the setting of these bits as follows. | | | | | | <ul> <li>This module sets PID to STALL (11) on<br/>receiving the data of the size exceeding the<br/>maximum packet size when software has set<br/>PID to BUF.</li> </ul> | | | | | | <ul> <li>This module sets PID to NAK on detecting a<br/>receive error such as a CRC error three<br/>consecutive times.</li> </ul> | | | | | | <ul> <li>This module also sets PID to STALL (11) on<br/>receiving the STALL handshake.</li> </ul> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------------|------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | PID[1:0] | 00 | R/W | Even if software modifies the PID bits to NAK after this module has issued S-SPLIT of the split transaction for the selected pipe (while CSSTS indicates 1), this module continues the transaction until C-SPLIT completes. On completion of C-SPLIT, this module sets PID to NAK. | | | | | | (2) When the function controller function is selected | | | | | | This module modifies the setting of these bits as follows. | | | | | | <ul> <li>This module modifies PID to NAK on receiving<br/>the setup packet. Here, this module sets VALID<br/>to 1. Software cannot modify the setting of PID<br/>until software sets VALID to 0.</li> </ul> | | | | | | <ul> <li>This module sets PID to STALL (11) on<br/>receiving the data of the size exceeding the<br/>maximum packet size when software has set<br/>PID to BUF.</li> </ul> | | | | | | <ul> <li>This module sets PID to STALL (1x) on<br/>detecting the control transfer sequence error.</li> </ul> | | | | | | <ul> <li>This module sets PID to NAK on detecting the<br/>USB bus reset.</li> </ul> | | | | | | This module does not reference to the setting of the PID bits while the SET_ADDRESS request is processed (auto processing). | | Notes: 1 | This hit is alwa | avs read as | Only | 1 can be written to | Notes: 1. This bit is always read as 0. Only 1 can be written to. 2. Only 1 can be written to. #### 17.3.31 Pipe Window Select Register (PIPESEL) PIPE1 to PIPE 9 should be set using PIPESEL, PIPECFG, PIPEBUF, PIPEMAXP, PIPEPERI, PIPENCTR, PIPENTRE, and PIPENTRN. After selecting the pipe using PIPESEL, functions of the pipe should be set using PIPECFG, PIPEBUF, PIPEMAXP, and PIPEPERI. PIPENCTR, PIPENTRE, and PIPENTRN can be set regardless of the pipe selection in PIPESEL. For a power-on reset and a USB bus reset, the corresponding bits for not only the selected pipe but all of the pipes are initialized. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|---|-----|--------|---------|-----| | | _ | _ | _ | - | 1 | 1 | _ | _ | 1 | 1 | _ | _ | | PIPESE | EL[3:0] | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to 4 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|--------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 to 0 | PIPESEL[3:0] | 0000 | R/W | Pipe Window Select | | | | | | Selects the pipe number corresponding to the PIPECFG, PIPEBUF, PIPEMAXP, and PIPEPERI registers which data is written to or read from. | | | | | | 0000: No pipe selected | | | | | | 0001: PIPE1 | | | | | | 0010: PIPE2 | | | | | | 0011: PIPE3 | | | | | | 0100: PIPE4 | | | | | | 0101: PIPE5 | | | | | | 0110: PIPE6 | | | | | | 0111: PIPE7 | | | | | | 1000: PIPE8 | | | | | | 1001: PIPE9 | | | | | | Other than above: Setting prohibited | | | | | | Selecting a pipe number through these bits allows writing to and reading from the PIPECFG, PIPEBUF, PIPEMAXP, and PIPEPERI registers that correspond to the selected pipe number. | | | | | | When PIPESEL = 0000, 0 is read from all of the bits in PIPECFG, PIPEBUF, PIPEMAXP, PIPEERI and PIPEnCTR. Writing to these bits is invalid. | #### 17.3.32 Pipe Configuration Register (PIPECFG) PIPECFG is a register that specifies the transfer type, buffer memory access direction, and endpoint numbers for PIPE1 to PIPE9. It also selects continuous or non-continuous transfer mode, single or double buffer mode, and whether to continue or disable pipe operation at the end of transfer. This register is initialized by a power-on reset. Only the TYPE[1:0] bits are initialized by a USB bus reset. | Bi | t: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|----|----|----|------|------|-------|------------|---|---|-----|-----|------|--------|-----| | | TYPE | E[1:0] | _ | _ | _ | BFRE | DBLB | CNTMD | SHT<br>NAK | - | _ | DIR | | EPNU | M[3:0] | | | Initial value | e: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/V | /: R/W | R/W | R | R | R | R/W | R/W | R/W | R/W | R | R | R/W | R/W | R/W | R/W | R/W | | | | Initial | | | |--------|-----------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15, 14 | TYPE[1:0] | 00 | R/W | Transfer Type | | | | | | Selects the transfer type for the pipe selected by the PIPESEL bits (selected pipe) | | | | | | PIPE1 and PIPE2 | | | | | | 00: Pipe not used | | | | | | 01: Bulk transfer | | | | | | 10: Setting prohibited | | | | | | 11: Isochronous transfer | | | | | | PIPE3 to PIPE5 | | | | | | 00: Pipe not used | | | | | | 01: Bulk transfer | | | | | | 10: Setting prohibited | | | | | | 11: Setting prohibited | | | | | | PIPE6 and PIPE7 | | | | | | 00: Pipe not used | | | | | | 01: Setting prohibited | | | | | | 10: Interrupt transfer | | | | | | 11: Setting prohibited | | | | | | Before setting PID to BUF for the selected pipe (before starting USB communication using the selected pipe), be sure to set these bits to the value other than 00. | | | | | | Modify these bits while the PID bits for the selected pipe are set to NAK. Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 | BFRE | 0 | R/W | BRDY Interrupt Operation Specification | | | | | | Specifies the BRDY interrupt generation timing from this module to the CPU with respect to the selected pipe. | | | | | | BRDY interrupt upon transmitting or receiving of data | | | | | | BRDY interrupt upon completion of reading of data | | | | | | When software has set this bit to 1 and the selected pipe is in the receiving direction, this module detects the transfer completion and generates the BRDY interrupt on having read the pertinent packet. | | | | | | When the BRDY interrupt is generated with the above conditions, software needs to write 1 to BCLR. The FIFO buffer assigned to the selected pipe is not enabled for reception until 1 is written to BCLR. | | | | | | When software has set this bit to 1 and the selected pipe is in the transmitting direction, this module does not generate the BRDY interrupt. | | | | | | For details, refer to (1) BRDY Interrupt under section 17.4.2, Interrupt Functions. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | To modify these bits after completing USB communication using the selected pipe, write 1 and then 0 to ACLRM continuously through software to clear the FIFO buffer assigned to the selected pipe while the CSSTS, PID, and CURPIPE bits are in the above-described state. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9 | DBLB | 0 | R/W | Double Buffer Mode | | | | | | Selects either single or double buffer mode for the FIFO buffer used by the selected pipe. | | | | | | 0: Single buffer | | | | | | 1: Double buffer | | | | | | This bit is valid when PIPE1 to PIPE5 are selected. | | | | | | When software has set this bit to 1, this module assigns two planes of the FIFO buffer size specified by the BUFSIZE bits in PIPEBUF to the selected pipe. | | | | | | Specifically, the following expression determines the FIFO buffer size assigned to the selected pipe by this module. | | | | | | (BUFSIZE + 1) * 64 * (DBLB + 1) [bytes] | | | | | | When software has set this bit to 1 and the selected pipe is in the transmitting direction, this module does not generate the BRDY interrupt. | | | | | | For details, refer to (1) BRDY Interrupt under section 17.4.2, Interrupt Functions. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | To modify these bits after completing USB communication using the selected pipe, write 1 and then 0 to ACLRM continuously through software to clear the FIFO buffer assigned to the selected pipe while the CSSTS, PID, and CURPIPE bits are in the above-described state. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | CNTMD | 0 | R/W | Continuous Transfer Mode | | | | | | Specifies whether to use the selected pipe in continuous transfer mode. | | | | | | 0: Non-continuous transfer mode | | | | | | 1: Continuous transfer mode | | | | | | This bit is valid when PIPE1 to PIPE5 are selected by the PIPESEL bits and bulk transfer is selected (TYPE = 01). | | | | | | Modify these bits while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | To modify these bits after completing USB communication using the selected pipe, write 1 and then 0 to ACLRM continuously through software to clear the FIFO buffer assigned to the selected pipe while the CSSTS, PID, and CURPIPE bits are in the above-described state. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SHTNAK | 0 | R/W | Pipe Disabled at End of Transfer | | | | | | Specifies whether to modify PID to NAK upon the end of transfer when the selected pipe is in the receiving direction. | | | | | | 0: Pipe continued at the end of transfer | | | | | | 1: Pipe disabled at the end of transfer | | | | | | This bit is valid when the selected pipe is PIPE1 to PIPE5 in the receiving direction. | | | | | | When software has set this bit to 1 for the selected pipe in the receiving direction, this module modifies the PID bits corresponding to the selected pipe to NAK on determining the end of the transfer. This module determines that the transfer has ended on any of the following conditions. | | | | | | <ul> <li>A short packet (including a zero-length packet) is<br/>successfully received.</li> </ul> | | | | | | The transaction counter is used and the number | | | | | | of packets specified by the counter are | | | | | | successfully received. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | This bit should be cleared to 0 for the pipe in the transmitting direction. | | 6, 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|------------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | DIR | 0 | R/W | Transfer Direction | | | | | | Specifies the transfer direction for the selected pipe. | | | | | | 0: Receiving direction | | | | | | 1: Sending direction | | | | | | When software has set this bit to 0, this module uses<br>the selected pipe in the receiving direction, and when<br>software has set this bit to 1, this module uses the<br>selected pipe in the transmitting direction. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | To modify these bits after completing USB communication using the selected pipe, write 1 and then 0 to ACLRM continuously through software to clear the FIFO buffer assigned to the selected pipe while the CSSTS, PID, and CURPIPE bits are in the above-described state. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | 3 to 0 | EPNUM[3:0] | 0000 | R/W | Endpoint Number | | | | | | These bits specify the endpoint number for the selected pipe. | | | | | | Setting 0000 means unused pipe. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | Do not make the settings such that the combination of the set values in the DIR and EPNUM bits should be the same for two or more pipes (EPNUM = 0000 can be set for all the pipes). | # 17.3.33 Pipe Buffer Setting Register (PIPEBUF) PIPEBUF is a register that specifies the buffer size and buffer number for PIPE1 to PIPE9. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-----|-----|----------|-----|-----|---|---|-----|-----|-----|------|---------|-----|-----|-----| | [ | _ | | BU | JFSIZE[4 | :0] | | _ | _ | | | | BUFN | ИВ[7:0] | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | B/W· | R | R/W | R/M | R/W | R/W | R/W | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 to 10 BUFSIZE[4:0] H'00 R/W Buffer Siz<br>Specifies | the size of the buffer for the pipe selected | |--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Specifies | the size of the huffer for the nine selected | | by the PIF | PESEL bits (selected pipe) in terms of here one block comprises 64 bytes. | | 00000 (H <sup>1</sup> | '00): 64 bytes | | 00001 (H | '01): 128 bytes | | : | : | | 11111 (H | 1F): 2 Kbytes | | module as | tware has set the DBLB bit to 1, this ssigns two planes of the FIFO buffer size by the BUFSIZE bits to the selected pipe. | | | lly, the following expression determines the er size assigned to the selected pipe by this | | (BUFS | SIZE + 1) * 64 * (DBLB + 1) [bytes] | | The valid selected p | value for these bits depends on the bipe. | | PIPE1 valid. | to PIPE5: Any value from H'00 to H'1F is | | • PIPE6 | 6 to PIPE9: H'00 should be set. | | | ed with CNTMD = 1, set an integer multiple ximum packet size to the BUFSIZE bits. | | | ese bits while CSSTS is 0 and PID is NAK ethe pipe is selected by the CURPIPE bits. | | bits for the<br>that CSS <sup>-</sup><br>bits have | odifying these bits after modifying the PID e selected pipe from BUF to NAK, check TS and PBUSY are 0. However, if the PID been modified to NAK by this module, PBUSY through software is not necessary. | | 9,8 — All 0 R Reserved | | | | s are always read as 0. The write value ways be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 to 0 | BUFNMB[7:0] | H'00 | R/W | Buffer Number | | | | | | These bits specify the FIFO buffer number for the selected pipe (from H'04 to H'7F). | | | | | | When the selected pipe is one of PIPE1 to PIPE5, any value can be set to these bits according to the user system. | | | | | | BUFNUMB = H'00 to H'03 are used exclusively for DCP. | | | | | | BUFNMB = H'04 is used exclusively for PIPE6. | | | | | | When PIPE6 is not used, H'04 can be used for other pipes. | | | | | | When PIPE6 is selected, writing to these bits is invalid and H'04 is automatically assigned by this module. | | | | | | BUFNMB = H'05 is used exclusively for PIPE7. | | | | | | When PIPE7 is not used, H'05 can be used for other pipes. | | | | | | When PIPE7 is selected, writing to these bits is invalid and H'05 is automatically assigned by this module. | | | | | | BUFNUMB = H'06 is used exclusively for PIPE8. | | | | | | When PIPE8 is not used, H'06 can be used for other pipes. | | | | | | When PIPE8 is selected, writing to these bits is invalid and H'06 is automatically assigned by this module. | | | | | | BUFNUMB = H'07 is used exclusively for PIPE9. | | | | | | When PIPE9 is not used, H'07 can be used for other pipes. | | | | | | When PIPE9 is selected, writing to these bits is invalid and H'07 is automatically assigned by this module. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | # 17.3.34 Pipe Maximum Packet Size Register (PIPEMAXP) PIPEMAXP is a register that specifies the maximum packet size for PIPE1 to PIPE9. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|------|---------|-----|----|-----|-----|-----|-----|-----|---------|-----|-----|-----|-----|-----| | [ | | DEVS | EL[3:0] | | _ | | | | | N | XPS[10: | 0] | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R | R/W | | | Initial | | | |----------|-------------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 12 | DEVSEL[3:0] | 00 | R/W | Device Select | | | | | | When the host controller function is selected, these bits specify the USB address of the communication target peripheral device. | | | | | | 0000: Address 0000 | | | | | | 0001: Address 0001 | | | | | | 0010: Address 0010 | | | | | | : : | | | | | | 1010: Address 1010 | | | | | | Other than above: Setting prohibited | | | | | | These bits should be set after setting the address to<br>the DEVADDn register corresponding to the value to<br>be set in these bits. | | | | | | For example, before setting DEVSEL to 0010, the address should be set to the DEVADD2 register. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | When the function controller function is selected, these bits should be set to B'0000. | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | | | Initial | | | | |---------|------------|---------|-----|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | | 10 to 0 | MXPS[10:0] | * | R/W | Maximum Packet Siz | e | | | | | | packet size) for the s | um data payload (maximum<br>elected pipe. The valid value for<br>n the pipe as follows. | | | | | | PIPE1, PIPE2: | 1 byte (H'001) to 1,024 bytes (H'400) | | | | | | PIPE3 to PIPE5: | 8 bytes (H'008), 16 bytes<br>(H'010), 32 bytes (H'020),<br>64 bytes (H'040), and<br>512 bytes (H'200) (Bits 2 to 0<br>are not provided.) | | | | | | PIPE6 to PIPE9: | 1 byte (H'001) to 64 bytes<br>(H'040) | | | | | | | set to the appropriate value for used on the USB Specification. | | | | | | • | using the isochronous pipe,<br>set to 188 bytes or less. | | | | | | bits for the selected p<br>that CSSTS and PBU<br>bits have been modif | se bits after modifying the PID bipe from BUF to NAK, check JSY are 0. However, if the PID ied to NAK by this module, bugh software is not necessary. | | | | | | While MXPS is 0, do set PID to BUF. | not write to the FIFO buffer or | Note: \* The initial value of MXPS is H'000 when no pipe is selected with the PIPESEL bits in PIPESEL and H'040 when a pipe is selected with the PIPESEL bit in PIPESEL. ## 17.3.35 Pipe Timing Control Register (PIPEPERI) PIPEPERI is a register that selects whether the buffer is flushed or not when an interval error occurred during isochronous IN transfer, and sets the interval error detection interval for PIPE1 to PIPE9. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|-----|----|----|------|----|----|---|---|---|---|---|---|---|-----|-----------|-----|--| | [ | _ | _ | _ | IFIS | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IITV[2:0] | | | | Initial value: | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W | R | R | R | R/W | R | R | R | R | R | R | R | R | R | R/W | R/W | R/M | | | | | Initial | | | |----------|----------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 | IFIS | 0 | R/W | Isochronous IN Buffer Flush | | | | | | Specifies whether to flush the buffer when the pipe selected by the PIPESEL bits (selected pipe) is used for isochronous IN transfers. | | | | | | 0: The buffer is not flushed. | | | | | | 1: The buffer is flushed. | | | | | | When the function controller function is selected and the selected pipe is for isochronous IN transfers, this module automatically clears the FIFO buffer when this module fails to receive the IN token from the USB host within the interval set by the IITV bits in terms of $(\mu)$ frames. | | | | | | In double buffer mode (DBLB = 1), this module only clears the data in the plane used earlier. | | | | | | This module clears the FIFO buffer on receiving the SOF packet immediately after the ( $\mu$ ) frame in which this module has expected to receive the IN token. Even if the SOF packet is corrupted, this module also clears the FIFO buffer at the right timing to receive the SOF packet by using the internal interpolation. | | | | | | When the host controller function is selected, set this bit to 0. | | | | | | When the selected pipe is not for the isochronous transfer, set this bit to 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 to 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 to 0 | IITV[2:0] | 000 | R/W | Interval Error Detection Interval | | | | | | Specifies the interval error detection timing for the selected pipe in terms of frames, which is expressed as n-th power of 2 (n is the value to be set). | | | | | | As described later, the detailed functions are different in host controller mode and in function controller mode. | | | | | | Modify these bits while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | Before modifying these bits after modifying the PID bits for the selected pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | Before modifying these bits after USB communication has been completed with these bits set to a certain value, set PID to NAK and then set ACLRM to 1 to initialize the interval timer. | | | | | | The IITV bits are invalid for PIPE3 to PIPE5; set these bits to 000 for these pipes. | ## 17.3.36 PIPEn Control Registers (PIPEnCTR) (n = 1 to 9) PIPEnCTR is a register that is used to confirm the buffer memory status for the corresponding pipe, change and confirm the data PID sequence bit, determine whether auto response mode is set, determine whether auto buffer clear mode is set, and set a response PID for PIPE1 to PIPE9. This register can be set regardless of the pipe selection in PIPESEL. This register is initialized by a power-on reset. Bits PID[1:0] are initialized by a USB bus reset. #### (1) PIPEnCTR (n = 1 to 5) | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|--------|-------|-------|----|------------|-------|-------|-------|-------|-------|---|---|---|------|-------| | | BSTS | INBUFN | CSCLR | CSSTS | _ | AT<br>REPM | ACLRM | SQCLR | SQSET | SQMON | PBUSY | _ | _ | _ | PID[ | [1:0] | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | ': R | R | R/W*2 | R | R | R/W | R/W | R/W*1 | R/W*1 | R | R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------| | 15 | BSTS | 0 | R | Buffer Status | | | | | | Indicates the FIFO buffer status for the pertinent pipe. | | | | | | 0: Buffer access is disabled. | | | | | | 1: Buffer access is enabled. | | | | | | The meaning of this bit depends on the settings of the DIR, BFRE, and DCLRM bits as shown in table 17.11. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 | INBUFM | 0 | R | IN Buffer Monitor | | | | | | Indicates the pertinent FIFO buffer status when the pertinent pipe is in the transmitting direction. | | | | | | <ol> <li>There is no data to be transmitted in the buffer<br/>memory.</li> </ol> | | | | | | <ol> <li>There is data to be transmitted in the buffer<br/>memory.</li> </ol> | | | | | | When the pertinent pipe is in the transmitting direction (DIR = 1), this module sets this bit to 1 when software (or DMAC) completes writing data to at least one FIFO buffer plane. | | | | | | This module sets this bit to 0 when this module completes transmitting the data from the FIFO buffer plane to which all the data has been written. In double buffer mode (DBLB = 1), this module sets this bit to 0 when this module completes transmitting the data from the two FIFO buffer planes before software (or DMAC) completes writing data to one FIFO buffer plane. | | | | | | This bit indicates the same value as the BSTS bit when the pertinent pipe is in the receiving direction (DIR = 0). | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | CSCLR | 0 | R/W* <sup>2</sup> | C-SPLIT Status Clear Bit | | | | | | When the host controller function is selected, setting this bit to 1 through software allows this module to clear the CSSTS bit to 0. | | | | | | 0: Writing invalid | | | | | | 1: Clears the CSSTS bit to 0. | | | | | | For the transfer using the split transaction, to restart the next transfer with the S-SPLIT forcibly, set this bit to 1 through software. However, for the normal split transaction, this module automatically clears the CSSTS bit to 0 upon completion of the C-SPLIT; therefore, clearing the CSSTS bit through software is not necessary. | | | | | | Controlling the CSSTS bit through this bit must be done while UACT is 0 and thus communication is halted or while no transfer is being performed with bus disconnection detected. | | | | | | Setting this bit to 1 while CSSTS is 0 has no effect. | | | | | | When the function controller function is selected, be sure to write 0 to this bit. | | 12 | CSSTS | 0 | R | CSSTS Status Bit | | | | | | Indicates the C-SPLIT status of the split transaction when the host controller function is selected. | | | | | | START-SPLIT (S-SPLIT) transaction being processed or the transfer not using the split transaction in progress | | | | | | 1: C-SPLIT transaction being processed | | | | | | This module sets this bit to 1 upon start of the C-SPLIT and clears this bit to 0 upon detection of C-SPLIT completion. | | | | | | Indicates the valid value only when the host controller function is selected. | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 | ATREPM | 0 | R/W | Auto Response Mode | | | | | | Enables or disables auto response mode for the pertinent pipe. | | | | | | 0: Auto response disabled | | | | | | 1: Auto response enabled | | | | | | When the function controller function is selected and<br>the pertinent pipe is for bulk transfer, this bit can be<br>set to 1. | | | | | | When this bit is set to 1, this module responds to the token from the USB host as described below. | | | | | | (1) When the pertinent pipe is for bulk IN transfer (TYPE = 01 and DIR = 1) | | | | | | When ATREPM = 1 and PID = BUF, this module transmits a zero-length packet in response to the IN token. | | | | | | This module updates (allows toggling of) the sequence toggle bit (DATA-PID) each time this module receives the ACK from the USB host (in a single transaction, IN token is received, zerolength packet is transmitted, and then ACK is received.). | | | | | | In this case, this module does not generate the BRDY or BEMP interrupt. | | | | | | (2) When the pertinent pipe is for bulk OUT transfer (TYPE = 01 and DIR = 0) | | | | | | When ATREPM = 1 and PID = BUF, this module returns NAK in response to the OUT (or PING) token and generates the NRDY interrupt. | | | | | | Modify this bit while CSSTS is 0 and PID is NAK. Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 | ATREPM | 0 | R/W | For USB communication in auto response mode, set this bit to 1 while the FIFO buffer is empty. Do not write to the FIFO buffer during USB communication in auto response mode. | | | | | | When the pertinent pipe is for isochronous transfer, be sure to set this bit to 0. | | | | | | When the host controller function is selected, set this bit to 0. | | 9 | ACLRM | 0 | R/W | Auto Buffer Clear Mode | | | | | | Enables or disables automatic buffer clear mode for the pertinent pipe. | | | | | | 0: Disabled | | | | | | 1: Enabled (all buffers are initialized) | | | | | | To delete the information in the FIFO buffer assigned to the pertinent pipe completely, write 1 and then 0 to this bit continuously. | | | | | | Table 17.12 shows the information cleared by writing 1 and 0 to this bit continuously and the cases in which clearing the information is necessary. | | | | | | Modify this bit while CSSTS is 0 and PID is NAK. | | | | | | Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | | |-----|----------|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 8 | SQCLR | 0 | R/W*1 | Toggle Bit Clear | | | | | | | | | | | This bit should be set to 1 to clear the expected value (to set DATA0 as the expected value) of the sequence toggle bit for the next transaction of the pertinent pipe. | | | | | | | | | | | 0: Invalid | | | | | | | | | | | 1: Specifies DATA0. | | | | | | | | | | | Setting this bit to 1 through software allows this module to set DATA0 as the expected value of the sequence toggle bit of the pertinent pipe. This module always sets this bit to 0. | | | | | | | | | | | When the host controller function is selected, setting this bit to 1 for the pipe for bulk OUT transfer, this module starts the next transfer of the pertinent pipe with the PING token. | | | | | | | | | | | Set the SQCLR bit to 1 while CSSTS is 0 and PID is NAK. | | | | | | | | | | | Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | Page 742 of 1278 | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SQSET | 0 | R/W*1 | Toggle Bit Set | | | | | | This bit should be set to 1 to setDATA1 as the expected value of the sequence toggle bit for the next transaction of the pertinent pipe. | | | | | | 0: Invalid | | | | | | 1: Specifies DATA1. | | | | | | Setting this bit to 1 through software allows this module to set DATA1 as the expected value of the sequence toggle bit of the pertinent pipe. This module always sets this bit to 0. | | | | | | Set the SQSET bit to 1 while CSSTS is 0 and PID is NAK. | | | | | | Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | 6 | SQMON | 0 | R | Toggle Bit Confirmation | | | | | | Indicates the expected value of the sequence toggle bit for the next transaction of the pertinent pipe. | | | | | | 0: DATA0 | | | | | | 1: DATA1 | | | | | | When the pertinent pipe is not for the isochronous transfer, this module allows this bit to toggle upon normal completion of the transaction. However, this bit is not allowed to toggle when a DATA-PID disagreement occurs during the receiving transfer. | | D., | B" N | Initial | D.444 | B 1.00 | |--------|----------|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 5 | PBUSY | 0 | R | Pipe Busy | | | | | | This bit indicates whether the relevant pipe is used or not for the transaction. | | | | | | 0: The relevant pipe is not used for the transaction. | | | | | | 1: The relevant pipe is used for the transaction. | | | | | | This module modifies this bit from 0 to 1 upon start of<br>the USB transaction for the pertinent pipe, and<br>modifies the bit from 1 to 0 upon completion of one<br>transaction. | | | | | | Reading this bit after software has set PID to NAK allows checking that modification of the pipe settings is possible. | | | | | | For details, refer to (1) Pipe Control Register<br>Switching Procedures under section 17.4.3, Pipe<br>Control. | | 4 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------------|------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | PID[1:0] | 00 | R/W | Response PID | | | | | | Specifies the response type for the next transaction of the pertinent pipe. | | | | | | 00: NAK response | | | | | | 01: BUF response (depending on the buffer state) | | | | | | 10: STALL response | | | | | | 11: STALL response | | | | | | The default setting of these bits is NAK. Modify the setting to BUF to use the pertinent pipe for USB transfer. Tables 17.13 and 17.14 show the basic operation (operation when there are no errors in the transmitted and received packets) of this module depending on the PID bit setting. | | | | | | After modifying the setting of these bits through software from BUF to NAK during USB communication using the pertinent pipe, check that PBUSY is 1 to see if USB communication using the pertinent pipe has actually entered the NAK state. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Notes: | 1 Only 0 can b | na raad and | 1 can be | a written to | Notes: 1. Only 0 can be read and 1 can be written to. 2. Only 1 can be written to. Table 17.11 Meaning of BSTS Bit | DIR Bit | <b>BFRE Bit</b> | DCLRM Bit | Meaning of BSTS Bit | |---------|-----------------|-----------|---------------------------------------------------------------------------------------------------| | 0 | 0 | 0 | 1: The received data can be read from the FIFO buffer. | | | | | 0: The received data has been completely read from the FIFO buffer. | | | | 1 | Setting prohibited | | | 1 | 0 | 1: The received data can be read from the FIFO buffer. | | | | | Software has set BCLR to 1 after the received data has been completely read from the FIFO buffer. | | | | 1 | 1: The received data can be read from the FIFO buffer. | | | | | 0: The received data has been completely read from the FIFO buffer. | | 1 | 0 | 0 | 1: The transmit data can be written to the FIFO buffer. | | | | | 0: The transmit data has been completely written to the FIFO buffer. | | | | 1 | Setting prohibited | | | 1 | 0 | Setting prohibited | | | | 1 | Setting prohibited | Table 17.12 Information Cleared by this Module by Setting ACLRM = 1 | No. | Information Cleared by ACLRM Bit Manipulation | Cases in which Clearing the Information is Necessary | |-----|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------| | 1 | All the information in the FIFO buffer assigned to the pertinent pipe (all the information in two FIFO buffer planes in double buffer mode) | | | 2 | The interval count value when the pertinent pipe is for isochronous transfer | When the interval count value is to be reset | | 3 | Values of the internal flags related to the BFRE bit | When the BFRE setting is modified | | 4 | FIFO buffer toggle control | When the DBLB setting is modified | | 5 | Values of the internal flags related to the transaction count | When the transaction count function is forcibly terminated | Table 17.13 Operation of This Module depending on PID Setting (when Host Controller Function is Selected) | PID | Transfer Type | Transfer Direction (DIR Bit) | Operation of This Module | |-----------------------------|-------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------| | 00 (NAK) | Operation does not depend on the setting. | Operation does not depend on the setting. | Does not issue tokens. | | 01 (BUF) | Bulk or interrupt | Operation does not depend on the setting. | Issues tokens while UACT is 1 and the FIFO buffer corresponding to the pertinent pipe is ready for transmission and reception. | | | | | Does not issue tokens while UACT is 0 or the FIFO buffer corresponding to the pertinent pipe is not ready for transmission or reception. | | | Isochronous | Operation does not depend on the setting. | Issues tokens irrespective of the status of the FIFO buffer corresponding to the pertinent pipe. | | 10 (STALL) or<br>11 (STALL) | Operation does not depend on the setting. | Operation does not depend on the setting. | Does not issue tokens. | Table 17.14 Operation of This Module depending on PID Setting (when Function Controller Function is Selected) | PID | Transfer Type | Transfer Direction (DIR Bit) | Operation of This Module | | | | |----------|-------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 00 (NAK) | Bulk or interrupt | depend on the | Returns NAK in response to the token from the USB host. | | | | | | | setting. | For the operation when ATREPM is 1, refer to the description of the ATREPM bit. | | | | | | Isochronous | Operation does not depend on the setting. | Returns nothing in response to the token from the USB host. | | | | | • | | Receiving direction<br>(DIR = 0) | Receives data and returns ACK in response to the OUT token from the USB host if the FIFO buffer corresponding to the pertinent pipe is ready for reception. Returns NAK if not ready. | | | | | | | | Returns ACK in response to the PING token from the USB host if the FIFO buffer corresponding to the pertinent pipe is ready for reception. Returns NYET if not ready. | | | | | | Interrupt | Receiving direction (DIR = 0) | Receives data and returns ACK in response to the OUT token from the USB host if the FIFO buffer corresponding to the pertinent pipe is ready for reception. Returns NAK if not ready. | | | | | | Bulk or interrupt | Transmitting direction (DIR = 1) | Transmits data in response to the token from the USB host if the corresponding FIFO buffer is ready for transmission. Returns NAK if not ready. | | | | | | Isochronous | Receiving direction (DIR = 0) | Receives data in response to the OUT token from the USB host if the FIFO buffer corresponding to the pertinent pipe is ready for reception. Discards data if not ready. | | | | | PID | Transfer Type | Transfer Direction (DIR Bit) | Operation of This Module | | | |-----------------------------|-------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 01 (BUF) | Isochronous | Transmitting direction (DIR = 1) | Transmits data in response to the token from the USB host if the corresponding FIFO buffer is ready for transmission. Transmits the zero-length packet if not ready. | | | | 10 (STALL) or<br>11 (STALL) | Bulk or interrupt | Operation does not depend on the setting. | Returns STALL in response to the token from the USB host. | | | | | Isochronous | Operation does not depend on the setting | Returns nothing in response to the token from the USB host. | | | # (2) PIPEnCTR (n = 6 to 9) | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|---------|-------|----|----|-------|---------|---------|-------|-------|---|---|---|------|------| | | BSTS | _ | CSCLR | CSSTS | _ | _ | ACLRM | SQCLR | SQSET | SQMON | PBUSY | _ | _ | - | PID[ | 1:0] | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | D/M | . р | D | D/\//*1 | D/M | D | D | D/M | D/\//*1 | D/\//*1 | D | D | D | D | D | DAM | DAM | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------| | 15 | BSTS | 0 | R | Buffer Status | | | | | | Indicates the FIFO buffer status for the pertinent pipe. | | | | | | 0: Buffer access is disabled. | | | | | | 1: Buffer access is enabled. | | | | | | The meaning of this bit depends on the settings of<br>the DIR, BFRE, and DCLRM bits as shown in table<br>17.11. | | 14 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | CSCLR | 0 | R/W* <sup>1</sup> | C-SPLIT Status Clear Bit | | | | | | Setting this bit to 1 allows this module to clear the CSSTS bit of the pertinent pipe to 0. | | | | | | 0: Writing invalid | | | | | | 1: Clears the CSSTS bit to 0. | | | | | | For the transfer using the split transaction, to restart the next transfer with the S-SPLIT forcibly, set this bit to 1 through software. However, for the normal split transaction, this module automatically clears the CSSTS bit to 0 upon completion of the C-SPLIT; therefore, clearing the CSSTS bit through software is not necessary. | | | | | | Controlling the CSSTS bit through this bit must be done while UACT is 0 thus communication is halted or while no transfer is being performed with bus disconnection detected. | | | | | | Setting this bit to 1 while CSSTS is 0 has no effect. | | | | | | When the function controller function is selected, be sure to write 0 to this bit. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | CSSTS | 0 | R/W | CSSTS Status Bit | | | | | | Indicates the C-SPLIT status of the split transaction when the host controller function is selected. | | | | | | START-SPLIT (S-SPLIT) transaction being processed or the transfer not using the split transaction in progress | | | | | | 1: C-SPLIT transaction being processed | | | | | | This module sets this bit to 1 upon start of the C-SPLIT and clears this bit to 0 upon detection of C-SPLIT completion. | | | | | | Indicates the valid value only when the host controller function is selected. | | 11, 10 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 9 | ACLRM | 0 | R/W | Auto Buffer Clear Mode*3*4 | | | | | | Enables or disables automatic buffer clear mode for the pertinent pipe. | | | | | | 0: Disabled | | | | | | 1: Enabled (all buffers are initialized) | | | | | | To delete the information in the FIFO buffer assigned to the pertinent pipe completely, write 1 and then 0 to this bit continuously. | | | | | | Table 17.15 shows the information cleared by writing 1 and 0 to this bit continuously and the cases in which clearing the information is necessary. | | | | | | Modify this bit while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. | | | | | | Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | D'' | D'I M | Initial | D.04/ | B | |-----|----------|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 8 | SQCLR | 0 | R/W*1 | Toggle Bit Clear*3*4 | | | | | | This bit should be set to 1 to clear the expected value (to set DATA0 as the expected value) of the sequence toggle bit for the next transaction of the pertinent pipe. | | | | | | 0: Invalid | | | | | | 1: Specifies DATA0. | | | | | | Setting this bit to 1 through software allows this module to set DATA0 as the expected value of the sequence toggle bit of the pertinent pipe. This module always sets this bit to 0. | | | | | | When the host controller function is selected, setting this bit to 1 for the pipe for bulk OUT transfer, this module starts the next transfer of the pertinent pipe with the PING token. | | | | | | Set the SQCLR bit to 1 while CSSTS is 0 and PID is NAK. | | | | | | Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SQSET | 0 | R/W*1 | Toggle Bit Set*3*4 | | | | | | This bit should be set to 1 to set DATA1 as the expected value of the sequence toggle bit for the next transaction of the pertinent pipe. | | | | | | 0: Invalid | | | | | | 1: Specifies DATA1. | | | | | | Setting this bit to 1 through software allows this module to set DATA1 as the expected value of the sequence toggle bit of the pertinent pipe. This module always sets this bit to 0. | | | | | | Set the SQSET bit to 1 while CSSTS is 0 and PID is NAK. | | | | | | Before modifying this bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | 6 | SQMON | 0 | R | Toggle Bit Confirmation | | | | | | Indicates the expected value of the sequence toggle bit for the next transaction of the pertinent pipe. | | | | | | 0: DATA0 | | | | | | 1: DATA1 | | | | | | When the pertinent pipe is not for the isochronous transfer, this module allows this bit to toggle upon normal completion of the transaction. However, this bit is not allowed to toggle when a DATA-PID disagreement occurs during the receiving transfer. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | PBUSY | 0 | R | Pipe Busy | | | | | | This bit indicates whether the relevant pipe is used or not for the transaction. | | | | | | 0: The relevant pipe is not used for the transaction. | | | | | | 1: The relevant pipe is used for the transaction. | | | | | | This module modifies this bit from 0 to 1 upon start of<br>the USB transaction for the pertinent pipe, and<br>modifies the bit from 1 to 0 upon completion of one<br>transaction. | | | | | | Reading this bit after software has set PID to NAK allows checking that modification of the pipe settings is possible. | | | | | | For details, refer to (1) Pipe Control Register<br>Switching Procedures under section 17.4.3, Pipe<br>Control. | | 4 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | PID[1:0] | 00 | R/W | Response PID | | 1, 0 | PID[1.0] | 00 | □/ VV | Specifies the response type for the next transaction of the pertinent pipe. | | | | | | 00: NAK response | | | | | | 01: BUF response (depending on the buffer state) | | | | | | 10: STALL response | | | | | | 11: STALL response | | | | | | The default setting of these bits is NAK. Modify the setting to BUF to use the pertinent pipe for USB transfer. Tables 17.13 and 17.14 show the basic operation (operation when there are no errors in the transmitted and received packets) of this module depending on the PID bit setting. | | | | | | After modifying the setting of these bits through software from BUF to NAK during USB communication using the pertinent pipe, check that PBUSY is 1 to see if USB communication using the pertinent pipe has actually entered the NAK state. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. | | | | | | This module modifies the setting of these bits as follows. | | | | | | <ul> <li>This module sets PID to NAK on recognizing the completion of the transfer when the pertinent pipe is in the receiving direction and software has set the SHTNAK bit for the selected pipe to 1.</li> <li>This module sets PID to STALL (11) on receiving the data packet with the payload exceeding the maximum packet size of the pertinent pipe.</li> <li>This module sets PID to NAK on detecting a USB bus reset when the function controller function is selected.</li> </ul> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | PID[1:0] | 00 | R/W | This module sets PID to NAK on detecting a<br>receive error such as a CRC error three<br>consecutive times when the host controller<br>function is selected. | | | | | | <ul> <li>This module sets PID to STALL (11) on receiving<br/>the STALL handshake when the host controller<br/>function is selected.</li> </ul> | | | | | | To specify each response type, set these bits as follows. | | | | | | <ul> <li>To make a transition from NAK (00) to STALL,<br/>set 10.</li> </ul> | | | | | | <ul> <li>To make a transition from BUF (01) to STALL,<br/>set 11.</li> </ul> | | | | | | <ul> <li>To make a transition from STALL (11) to NAK,<br/>set 10 and then 00.</li> </ul> | | | | | | <ul> <li>To make a transition from STALL to BUF, set 00<br/>(NAK) and then 01 (BUF).</li> </ul> | Notes: 1. Only 0 can be read and 1 can be written to. 1--:4:-1 - 2. Only 1 can be written to. - 3. The ACLRM, SQCLR, or SQSET bits should be set while CSSTS is 0 and PID is NAK and before the pipe is selected by the CURPIPE bits. - 4. Before modifying ACLRM, SQCLR, or SQSET bits after modifying the PID bits from BUF to NAK, it should be checked that CSSTS and PBUSY for the selected pipe are 0. However, if the PID bits have been modified to NAK through hardware control, checking PBUSY is not necessary. Table 17.15 Information Cleared by this Module by Setting ACLRM = 1 | No. | Information Cleared by ACLRM Bit<br>Manipulation | Cases in which Clearing the Information is Necessary | |-----|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------| | 1 | All the information in the FIFO buffer assigned to the pertinent pipe | | | 2 | When the host controller function is selected, the interval count value when the pertinent pipe is for isochronous transfer | When the interval count value is to be reset | | 3 | Values of the internal flags related to the BFRE bit | When the BFRE setting is modified | | 4 | Values of the internal flags related to the transaction count | When the transaction count function is forcibly terminated | ### 17.3.37 PIPEn Transaction Counter Enable Registers (PIPEnTRE) (n = 1 to 5) PIPEnTRE is a register that enables or disables the transaction counter corresponding to PIPE1 to PIPE5, and clears the transaction counter. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|----|----|----|----|----|-------|-------|---|---|---|---|---|---|---|---| | [ | _ | _ | _ | _ | _ | _ | TRENB | TRCLR | _ | _ | _ | _ | _ | - | _ | _ | | Initial value: | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | R/W | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to 10 | ) — | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | g this bit<br>tets to<br>ware<br>scribed<br>kets | |--------------------------------------------------| | ets to<br>ware<br>scribed | | ets to<br>ware<br>scribed | | cets to<br>ware<br>scribed | | cets to<br>ware<br>scribed | | | | de<br>FIFO<br>ouffer is | | s the PID<br>n having<br>the set | | BRDY of ICNT d data. this bit | | t this bit | | e<br>this bit<br>unted by | | | | ounter<br>sets this | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|----------------------------------------------------------------------| | 7 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Note: Modify each bit in this register while CSSTS is 0 and PID is NAK. Before modifying each bit after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. #### 17.3.38 PIPEn Transaction Counter Registers (PIPEnTRN) (n = 1 to 5) PIPEnTRN is a transaction counter corresponding to PIPE1 to PIPE5. This register is initialized by a power-on reset, but retains the set value by a USB bus reset. | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|-----|-----|-----|-----|-----|-----|-------|----------|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | TRNCN | IT[15:0] | | | | | | | | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|--------------|------------------|-----|--------------------------------------------------------------------------| | 15 to 0 | TRNCNT[15:0] | All 0 | R/W | Transaction Counter | | | | | | When written to: | | | | | | Specifies the number of transactions to be transferred through DMA. | | | | | | When read from: | | | | | | Indicates the specified number of transactions if TRENB is 0. | | | | | | Indicates the number of the currently counted transaction if TRENB is 1. | | | | Initial | | | |---------|--------------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 0 | TRNCNT[15:0] | All 0 | R/W | This module increments the value of these bits by one when all of the following conditions are satisfied on receiving the packet. TRENB is 1. | | | | | | | | | | | | <ul> <li>(TRNCNT set value ≠ current counter value + 1)<br/>on receiving the packet.</li> </ul> | | | | | | <ul> <li>The payload of the received packet agrees with</li> </ul> | | | | | | the set value in the MXPS bits. | | | | | | This module clears the value of these bits to 0 when any of the following conditions are satisfied. | | | | | | All the following conditions are satisfied. | | | | | | TRENB is 1. | | | | | | (TRNCNT set value = current counter value + 1) on receiving the packet. | | | | | | The payload of the received packet agrees with the set value in the MXPS bits. | | | | | | All the following conditions are satisfied. | | | | | | TRENB is 1. | | | | | | This module has received a short packet. | | | | | | All the following conditions are satisfied. | | | | | | TRENB is 1. | | | | | | Software has set the TRCLR bit to 1. | | | | | | For the pipe in the transmitting direction, set these bits to 0. | | | | | | When the transaction counter is not used, set these bits to 0. | | | | | | Modify these bits while CSSTS is 0, PID is NAK, and TRENB is 0. | | | | | | Before modifying these bits after modifying the PID bits for the corresponding pipe from BUF to NAK, check that CSSTS and PBUSY are 0. However, if the PID bits have been modified to NAK by this module, checking PBUSY through software is not necessary. To modify the value of these bits, set TRNCNT to 1 | | | | | | before setting TRENB to 1. | #### 17.3.39 Device Address n Configuration Registers (DEVADDn) (n = 0 to A) DEVADDn is a register that specifies the address and port number of the hub to which the communication target peripheral device is connected and that also specifies the transfer speed of the peripheral device for PIPE0 to PIPEA. When the host controller function is selected, this register should be set before starting communication using each pipe. The bits in this register should be modified while no valid pipes are using the settings of this register. Valid pipes refer to the ones satisfying both of condition 1 and 2 below. - 1. This register is selected by the DEVSEL bits as the communication target. - 2. The PID bits are set to BUF for the selected pipe or the selected pipe is the DCP with SUREQ being 1. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-----|------|---------|-----|-----|--------|------|-------|---------|---|---|---|---|---|---| | [ | _ | | UPPH | UB[3:0] | | HU | BPORT[ | 2:0] | USBSF | PD[1:0] | _ | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | | |----------|--------------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--| | 14 to 11 | UPPHUB[3:0] | 0000 | R/W | Address of Hub to which Communication Target is Connected | | | | | | | | | | | Specifies the USB address of the hub to which the communication target peripheral device is connected. | | | | | | | | | | | 0000: | The peripheral device is directly connected to the port of this LSI. | | | | | | | | | | 0001 to 1010 | ): USB address of the hub | | | | | | | | | | 1011 to 1111 | : Setting prohibited | | | | | | | | | | When the host controller function is selected, this module refers to the setting of these bits to generate packets for split transactions. | | | | | | | | | | | When the fur these bits to | nction controller function is selected, set 0000. | | | | | | 10 to 8 | HUBPORT[2:0] | 000 | R/W | Port Number is Connected | of Hub to which Communication Target | | | | | | | | | | • | port number of the hub to which the on target peripheral device is | | | | | | | | | | | The peripheral device is directly connected to the port of this LSI. | | | | | | | | | | 001 to 111: | Port number of the hub | | | | | | | | | | module refer | est controller function is selected, this is to the setting of these bits to generate eplit transactions. | | | | | | | | | | When the fur these bits to | nction controller function is selected, set 000. | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|-------------|------------------|-----|---------------------------------------------------------------------------------------------------------------------| | 7, 6 | USBSPD[1:0] | 00 | R/W | Transfer Speed of the Communication Target Device | | | | | | Specifies the USB transfer speed of the communication target peripheral device. | | | | | | 00: DEVADDn is not used. | | | | | | 01: Low speed | | | | | | 10: Full speed | | | | | | 11: High speed | | | | | | When the host controller function is selected, this module refers to the setting of these bits to generate packets. | | | | | | When the function controller function is selected, set these bits to 00. | | 5 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | Bit: 15 14 13 12 #### 17.3.40 Bus Wait Register (D0FWAIT, D1FWAIT) D0FWAIT and D1FWAIT each specify the number of access waits for those registers of this module that are connected to the internal bus (that is, D0FWAIT, D1FWAIT, D0FIFO, and D1FIFO). The basic clock for this module is a USB clock of 48 MHz, and access from the internal bus is performed through B $\phi$ synchronization. For this reason, the USB clock must be multiplied by a certain number of cycles when accessing registers of this module via the internal bus. The number of access waits should be adjusted to produce at least the approximate value shown below: 83.4 ns (USB clock $\times$ 4 cycles) when the size of access is 32 bits, 41.7 ns (USB clock $\times$ 2 cycles) when the size of access is 16 bits, or 20.8 ns (USB clock $\times$ 1 cycle) when the size of access is 8 bits. | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | BWAI | T[3:0] | | |----------------|-------|---------|----|--------|---|-----|----|--------|-------------------|---------|---------------------------|--------|---------|--------|-------------------|-------| | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | | | | | | Initia | I | | | | | | | | | | | | | Bit | Bit I | Name | | Value | 9 | R/W | De | escrip | tion | | | | | | | | | 15 to 4 | _ | | | All 0 | | R | Re | eserve | ed | | | | | | | | | | | | | | | | | | its are<br>always | | ys rea | ıd as | 0. The | write | value | 9 | | 3 to 0 | BW | AIT[3:0 | 0] | 1111 | | R/W | Bu | ıs Wa | it betw | /een [ | OMAC | and | FIFO | | | | | | | | | | | | | cessii | | • | the nu<br>of this | | | | | | | | | | | | | | 00 | 00: 0 | ) wait | (acce | ssing | two cy | ycles o | on a E | ₿ф bas | is) | | | | | | | | | 00 | 01: 1 | wait | (acce | ssing | three | cycles | on a | B¢ ba | asis) | | | | | | | | | 00 | 10: 2 | waits | (acc | essing | four | cycles | on a | B <sub>0</sub> ba | asis) | | | | | | | | | : | | | | | | | | | | | | | | | | | | 11 | 11: 1 | 5 wai | ts (ac | cessin | ıg 17 | cycles | on a | Βφ ba | asis) | | | | | | | | | No | ro | utine | of this | t this I<br>modu<br>ccess | ıle by | - | | | ınt | ## 17.4 Operation #### 17.4.1 System Control and Oscillation Control This section describes the register operations that are necessary to the initial settings of this module, and the registers necessary for power consumption control. #### (1) Resets Table 17.16 lists the types of controller resets. For the initialized states of the registers following the reset operations, see section 17.3, Register Description. Table 17.16 Types of Reset | Name | Operation | |----------------|------------------------------------------------------------------------------------------------------------------| | Power-on reset | Low level input from the RES pin | | USB bus reset | Automatically detected by this module from the D+ and D- lines when the function controller function is selected | #### (2) Controller Function Selection This module can select the host controller function or function controller function using the DCFM bit in SYSCFG. Changing the DCFM bit should be done in the initial settings immediately after a power-on reset or in the D+ pull-up disabled (DPRPU = 0) and D + /D – pull-down disabled (DRPD = 0) state. # (3) Enabling High-Speed Operation This module can select a USB communication speed (communication bit rate) using software. When the host controller function is selected, either of the high-speed operation or full-speed/low-speed operation can be selected. In order to enable the high-speed operation for this module, the HSE bit in SYSCFG should be set to 1. If high-speed mode has been enabled, this module executes the reset handshake protocol, and the USB communication speed is set automatically. The results of the reset handshake can be confirmed using the RHST bit in DVSTCTR. If high-speed operation has been disabled, this module operates at full-speed or low-speed. If the function controller function is also selected, this module operates at full-speed. Changing the HSE bit should be done between the ATTCH interrupt detection and bus reset execution when the host controller function is selected, or with the D+ line pull-up disabled (DPRPU = 0) when the host controller function is selected. #### **(4) USB Data Bus Resistor Control** Figure 17.1 shows a diagram of the connections between this module and the USB connectors. This module incorporates a pull-up resistor for the D+ signal and a pull-down resistor for the D+ and D- signals. These signals can be pulled up or down using the DPRPU and DRPD bits in SYSCFG. This module controls the terminal resistor for the D+ and D- signals during high-speed operation and the output resistor for the signals during full-speed operation. This module automatically switches the resistor after connection with the host controller or peripheral device by means of reset handshake, suspended state and resume detection. When the function controller function is selected and the DPRPU bit in SYSCFG is cleared to 0 during communication with the host controller, the pull-up resistor (or the terminal resistor) of the USB data line is disabled, making it possible to notify the USB host of the device disconnection. Figure 17.1 UBS Connector Connection #### 17.4.2 **Interrupt Functions** Table 17.17 lists the interrupt generation conditions for this module. When an interrupt generation condition is satisfied and the interrupt output is enabled using the corresponding interrupt enable register, this module issues a USB interrupt request to the INTC. **Table 17.17 Interrupt Generation Conditions** | Bit | Interrupt Name | Cause of Interrupt | Function That<br>Generates the<br>Interrupt | Related<br>Status | |-------|-------------------------|------------------------------------------------------------------------------------------|---------------------------------------------|-------------------| | VBINT | VBUS interrupt | When a change in the state of the VBUS input pin has been detected | Host, | VBSTS | | | | (low to high or high to low) | function | | | RESM | Resume interrupt | When a change in the state of the USB bus has been detected in the suspended state | Function | _ | | | | (J-state to K-state or J-state to SE0) | | | | SOFR | Frame number | When the host controller function is | Host, | _ | | | update interrupt | selected: | function | | | | | <ul> <li>When an SOF packet with a<br/>different frame number has been</li> </ul> | | | | | | transmitted | | | | | | When the function controller function is selected: | | | | | | • SOFRM = 0: | | | | | | When an SOF packet with a different frame number is received | | | | | | • SOFRM = 1: | | | | | | When the SOF with the μframe number 0 cannot be received due to a corruption of a packet | | | | DVST | Device state transition | When a device state transition is detected | Function | DVSQ | | i | interrupt | A USB bus reset detected | | | | | | The suspend state detected | | | | | | SET_ADDRESS request received | | | | | | SET_CONFIGURATION request | | | | | | received | | | | Bit | Interrupt Name | Cause of Interrupt | Function That<br>Generates the<br>Interrupt | Related<br>Status | |------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------| | CTRT | Control transfer<br>stage transition<br>interrupt | <ul> <li>When a stage transition is detected in control transfer</li> <li>Setup stage completed</li> <li>Control write transfer status stage transition</li> <li>Control read transfer status stage transition</li> <li>Control transfer completed</li> <li>A control transfer sequence error occurred</li> </ul> | Function | CTSQ | | BEMP | Buffer empty<br>interrupt | <ul> <li>When transmission of all of the data in the buffer memory has been completed</li> <li>When an excessive maximum packet size error has been detected</li> </ul> | Host,<br>Function | BEMPSTS.<br>PIPEBEMP | | NRDY | Buffer not ready<br>interrupt | <ul> <li>When the host controller function is selected:</li> <li>When STALL is received from the peripheral side for the issued token</li> <li>When a response cannot be received correctly from the peripheral side for the issued token (No response is returned three consecutive times or a packet reception error occurred three consecutive times.)</li> <li>When an overrun/underrun occurred during isochronous transfer</li> </ul> | Host, function | NRDYSTS.<br>PIPENRDY | Jun 21, 2011 | Bit | Interrupt Name | Cause of Interrupt | Function That<br>Generates the<br>Interrupt | Related<br>Status | |-----------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------| | NRDY | Buffer not ready interrupt | When the function controller function is selected: | Host, function | NRDYSTS.<br>PIPENRDY | | | | <ul> <li>When NAK is returned for an<br/>IN/OUT/PING token.</li> </ul> | | | | | | When a CRC error or a bit stuffing<br>error occurred during data<br>reception in isochronous transfer | | | | | | <ul> <li>When an overrun/underrun<br/>occurred during data reception in<br/>isochronous transfer</li> </ul> | | | | BRDY | Buffer ready interrupt | When the buffer is ready (reading or writing is enabled) | Host, function | BRDYSYS<br>PIPEBRDY | | BCHG | Bus change interrupt | When a change of USB bus state is detected | Host, function | _ | | DTCH | Disconnection<br>detection during<br>full-speed<br>operation | When disconnection of a peripheral device during full-speed operation is detected | Host | _ | | ATTCH | Device connection | When J-state or K-state is detected on the USB port for 2.5 $\mu$ s. | Host | _ | | detection | | Used for checking whether a peripheral device is connected. | | | | EOFERR | EOF error detection | When EOF error of a peripheral device is detected | Host | _ | | SACK | Normal setup operation | When the normal response (ACK) for the setup transaction is received | Host | _ | | SIGN | Setup error | When a setup transaction error (no response or ACK packet corruption) is detected three consecutive times. | Host | _ | Note: All the bits without register name indication are in INTSTS0. Figure 17.2 shows a diagram relating to interrupts of this module. Figure 17.2 Items Relating to Interrupts #### **(1) BRDY Interrupt** The BRDY interrupt is generated when either of the host controller function or function controller function is selected. The following shows the conditions under which this module sets 1 to a corresponding bit in BRDYSTS. Under this condition, this module generates BRDY interrupt, if software sets the PIPEBRDYE bit in BRDYENB that corresponds to the pipe to 1 and the BRDYE bit in INTENB0 to 1. The conditions for generating and clearing the BRDY interrupt depend on the settings of the BRDYM bit and BFRE bit for the pertinent pipe as described below. #### When the BRDYM bit is 0 and BFRE bit is 0 (a) With these settings, the BRDY interrupt indicates that the FIFO port is accessible. On any of the following conditions, this module generates the internal BRDY interrupt request trigger and sets 1 to the PIPEBRDY bit corresponding to the pertinent pipe. - For the pipe in the transmitting direction: (i) - When software changes the DIR bit from 0 to 1. - When packet transmission is completed using the pertinent pipe when write-access from the CPU to the FIFO buffer for the pertinent pipe is disabled (when the BSTS bit is read as 0). - In continuous transmission/reception mode, the request trigger is generated on completion of transmitting data of one plane of the FIFO buffer. - When one FIFO buffer is empty on completion of writing data to the other FIFO buffer in double buffer mode. - The request trigger is not generated until completion of writing data to the currently-written FIFO buffer plane even if transmission to the other FIFO buffer is completed. - When the hardware flushes the buffer of the pipe for isochronous transfers. - When 1 is written to the ACLRM bit, which causes the FIFO buffer to make transition from the write-disabled to write-enabled state. The request trigger is not generated for the DCP (that is, during data transmission for control transfers). ## (ii) For the pipe in the receiving direction: — When packet reception is completed successfully thus enabling the FIFO buffer to be read when read-access from the CPU to the FIFO buffer for the pertinent pipe is disabled (when the BSTS bit is read as 0). The request trigger is not generated for the transaction in which DATA-PID disagreement occurs. In continuous transmission/reception mode, the request trigger is not generated when the data is of the specified maximum packet size and the buffer has available space. When a short packet is received, the request trigger is generated even if the FIFO buffer has available space. When the transaction counter is used, the request trigger is generated on receiving the specified number of packets. In this case, the request trigger is generated even if the FIFO buffer has available space. When one FIFO buffer is read-enabled on completion of reading data from the other FIFO buffer in double buffer mode. The request trigger is not generated until completion of reading data from the currently-read FIFO buffer plane even if reception by the other FIFO buffer is completed. When the function controller function is selected, the BRDY interrupt is not generated in the status stage of control transfers. The PIPEBRDY interrupt status of the pertinent pipe can be cleared to 0 by writing 0 to the corresponding PIPEBRDY interrupt status bit in the BRDYSTS register through software. In this case, 1s should be written to the PIPEBRDY interrupt status bits for the other pipes. Be sure to clear the BRDY status before accessing the FIFO buffer. #### (b) When the BRDYM bit is 0 and the BFRE bit is 1 With these settings, this module generates the BRDY interrupt on completion of reading all the data for a single transfer using the pipe in the receiving direction, and sets 1 to the PIPEBRDY bit corresponding to the pertinent pipe. On any of the following conditions, this module determines that the last data for a single transfer has been received. - When a short packet including a zero-length packet is received. - When the transaction counter register (TRNCNT bits) is used and the number of packets specified by the TRNCNT bits are completely received. When the pertinent data is completely read out after any of the above determination conditions has been satisfied, this module determines that all the data for a single transfer has been completely read out. When a zero-length packet is received when the FIFO buffer is empty, this module determines that all the data for a single transfer has been completely read out upon passing the zero-length packet data to the CPU. In this case, to start the next transfer, write 1 to the BCLR bit in the corresponding FIFOCTR register through software. With these settings, this module does not detect the BRDY interrupt for the pipe in the transmitting direction. The PIPEBRDY interrupt status of the pertinent pipe can be cleared to 0 by writing 0 to the corresponding PIPEBRDY interrupt status bit through software. In this case, 1s should be written to the PIPEBRDY interrupt status bits for the other pipes. In this mode, the BFRE bit setting should not be modified until all the data for a single transfer has been processed. When it is necessary to modify the BFRE bit before completion of processing, all the FIFO buffers for the pertinent pipe should be cleared using the ACLRM bit. #### (c) When the BRDYM bit is 1 and the BFRE bit is 0 With these settings, the PIPEBRDY values are linked to the BSTS bit settings for each pipe. In other words, the BRDY interrupt status bits (PIPEBRDY) are set to 1 or 0 by this module depending on the FIFO buffer status. (i) For the pipe in the transmitting direction: The BRDY interrupt status bits are set to 1 when the FIFO buffer is write-enabled and are set to 0 when write-disabled. However, the BRDY interrupt is not generated if the DCP in the transmitting direction is writeenabled. (ii) For the pipe in the receiving direction: The BRDY interrupt status bits are set to 1 when the FIFO buffer is read-enabled and are set to 0 when all the data have been read (read-disabled). When a zero-length packet is received when the FIFO buffer is empty, the pertinent bit is set to 1 and the BRDY interrupt is continuously generated until BCLR = 1 is written through software. With this setting, the PIPEBRDY bit cannot be cleared to 0 through software. When BRDYM is set to 1, all of the BFRE bits (for all pipes) should be cleared to 0. Figure 17.3 shows the timing at which the BRDY interrupt is generated. Figure 17.3 Timing at which a BRDY Interrupt is Generated ## (2) NRDY Interrupt On generating the internal NRDY interrupt request for the pipe whose PID bits are set to BUF by software, this module sets the corresponding PIPENRDY bit in NRDYSTS to 1. If the corresponding bit in NRDYENB is set to 1 by software, this module sets the NRDY bit in INTSTSO to 1, allowing the USB interrupt to be generated. The following describes the conditions on which this module generates the internal NRDY interrupt request for a given pipe. However, the internal NRDY interrupt request is not generated during setup transaction execution when the host controller function is selected. During setup transactions when the host controller function is selected, the SACK or SIGN interrupt is detected. The internal NRDY interrupt request is not generated during status stage execution of the control transfer when the function controller function is selected. # (a) When the host controller function is selected and when the connection is used in which no split transactions occur (i) For the pipe in the transmitting direction: On any of the following conditions, this module detects the NRDY interrupt. - For the pipe for isochronous transfers, when the time to issue an OUT token comes in a state in which there is no data to be transmitted in the FIFO buffer. In this case, this module transmits a zero-length packet following the OUT token, setting the corresponding PIPENRDY bit and the OVRN bit to 1. - During communications other than setup transactions using the pipe for the transfers other than isochronous transfers, when any combination of the following two cases occur three consecutive times: 1) no response is returned from the peripheral device (when timeout is detected before detection of the handshake packet from the peripheral device) and 2) an error is detected in the packet from the peripheral device. - In this case, this module sets the corresponding PIPENRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to NAK. - During communications other than setup transactions, when the STALL handshake is received from the peripheral device (including the STALL handshake in response to PING in addition to the STALL handshake in response to OUT). In this case, this module sets the corresponding PIPENRDY bit to 1 and modifies the - In this case, this module sets the corresponding PIPENRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to STALL (11). #### For the pipe in the receiving direction (ii) - For the pipe for isochronous transfers, when the time to issue an IN token comes in a state in which there is no space available in the FIFO buffer. - In this case, this module discards the received data for the IN token, setting the PIPENRDY bit of the corresponding pipe and the OVRN bit to 1. - When a packet error is detected in the received data for the IN token, this module also sets the CRCE bit to 1. - For the pipe for the transfers other than isochronous transfers, when any combination of the following two cases occur three consecutive times: 1) no response is returned from the peripheral device for the IN token issued by this module (when timeout is detected before detection of the DATA packet from the peripheral device) and 2) an error is detected in the packet from the peripheral device. - In this case, this module sets the corresponding PIPENRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to NAK. - For the pipe for isochronous transfers, when no response is returned from the peripheral device for the IN token (when timeout is detected before detection of the DATA packet from the peripheral device) or an error is detected in the packet from the peripheral device. In this case, this module sets the corresponding PIPENRDY bit to 1. (The setting of the PID bits of the corresponding pipe to NAK is not modified.) - For the pipe for isochronous transfers, when a CRC error or a bit stuffing error is detected in the received data packet. - In this case, this module sets the corresponding PIPENRDY bit and CRCE bit to 1. - When the STALL handshake is received. In this case, this module sets the corresponding PIPENRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to STALL. # (b) When the host controller function is selected and when the connection is used in which split transactions occur - (i) For the pipe in the transmitting direction: - For the pipe for isochronous transfers, when the time to issue an OUT token comes in a state in which there is no data to be transmitted in the FIFO buffer. In this case, this module transmits a zero-length packet following the OUT token, setting the corresponding PIPENRDY bit and the OVRN bit to 1 at the issuance of the start-split transaction (S-SPLIT). - For the pipe for the transfers other than isochronous transfers, when any combination of the following two cases occur three consecutive times: 1) no response is returned from the HUB for the S-SPLIT or complete-split transaction (C-SPLIT) (when timeout is detected before detection of the handshake packet from the HUB) and 2) an error is detected in the packet from the HUB. - In this case, this module sets the PIPENRDY bit of the corresponding pipe to 1 and modifies the setting of the PID bits of the corresponding pipe to NAK. - If the NRDY interrupt is detected when the C-SPLIT is issued, this module clears the CSSTS bit to 0. - When the STALL handshake is received in response to the C-SPLIT. In this case, this module sets the corresponding PIPENRDY bit to 1, modifies the setting of the PID bits of the corresponding pipe to STALL (11) and clears the CSSTS bit to 0. This interrupt is not detected for SETUP transactions. - When the NYET is received in response to the C-SPLIT and the microframe number = 4. In this case, this module sets the corresponding PIPENRDY bit to 1 and clears the CSSTS bit to 0 (does not modify the setting of the PID bits). - (ii) For the pipe in the receiving direction: - For the pipe for isochronous transfers, when the time to issue an IN token comes in a state in which there is no space available in the FIFO buffer. - In this case, this module discards the received data for the IN token, setting the corresponding PIPENRDY bit and the OVRN bit to 1 at the issuance of the S-SPLIT. - During bulk-pipe transfers or the transfers other than SETUP transactions with the DCP, when any combination of the following two cases occur three consecutive times: 1) no response is returned from the HUB for the IN token issued by this module at the issuance of S-SPLIT or C-SPLIT (when timeout is detected before detection of the DATA packet from the HUB) and 2) an error is detected in the packet from the HUB. - In this case, this module sets the corresponding PIPENRDY bit to 1 and modifies the setting of the PID bits of the corresponding pipe to NAK. When the condition is generated during the C-SPLIT transaction, this module clears the CSSTS bit to 0. - During the C-SPLIT transaction for the pipe for isochronous transfers or interrupt transfers, when any combination of the following two cases occur three consecutive times: 1) no response is returned from the HUB for the IN token issued by this module (when timeout is detected before detection of the DATA packet from the HUB) and 2) an error is detected in the packet from the HUB. - On generating this condition for the pipe for interrupt transfers, this module sets the corresponding PIPENRDY bit to 1, modifies the setting of the PID bits of the corresponding pipe to NAK and clears the CSSTS bit to 0. - On generating this condition for the pipe for isochronous transfers, this module sets the corresponding PIPENRDY bit to 1 and CRCE bit to 1, and clears the CSSTS bit to 0 (does not modify the setting of the PID bits). - During the C-SPLIT transaction, when the STALL handshake is received for the pipe for the transfers other than isochronous transfers. - In this case, this module sets the corresponding PIPENRDY bit to 1, modifies the setting of the PID bits of the corresponding pipe to STALL (11) and clears the CSSTS bit to 0. - During the C-SPLIT transaction, when the NYET handshake is received for the pipe for the isochronous transfers or interrupt transfers and the microframe number = 4. - In this case, this module sets the corresponding PIPENRDY bit to 1 and CRCE bit to 1, and clears the CSSTS bit to 0 (does not modify the setting of the PID bits). #### (c) When the function controller function is selected - (i) For the pipe in the transmitting direction: - On receiving an IN token when there is no data to be transmitted in the FIFO buffer. In this case, this module generates a NRDY interrupt request at the reception of the IN token, setting the PIPENRDY bit to 1. For the pipe for the isochronous transfers in which an interrupt is generated, this module transmits a zero-length packet, setting the OVRN bit to 1. - (ii) For the pipe in the receiving direction: - On receiving an OUT token when there is no space available in the FIFO buffer. For the pipe for the isochronous transfers in which an interrupt is generated, this module generates a NRDY interrupt request, setting the PIPENRDY bit to 1 and OVRN bit to 1. For the pipe for the transfers other than isochronous transfers in which an interrupt is generated, this module generates a NRDY interrupt request when a NAK handshake is transferred after the data following the OUT token was received, setting the PIPENRDY bit to 1. However, during re-transmission (due to DATA-PID disagreement), the NRDY interrupt request is not generated. In addition, if an error occurs in the DATA packet, the NRDY interrupt request is not generated. - On receiving a PING token when there is no space available in the FIFO buffer. In this case, this module generates a NRDY interrupt request at the reception of the PING token, setting the PIPENRDY bit to 1. - For the pipe for isochronous transfers, when a token is not received normally within an interval frame. In this case, this module generates a NRDY interrupt request, setting the PIPENRDY bit to 1. Figure 17.4 shows the timing at which an NRDY interrupt is generated when the function controller function is selected. Figure 17.4 Timing at which NRDY Interrupt is Generated when Function Controller **Function is Selected** ## (3) BEMP Interrupt On generating the BEMP interrupt for the pipe whose PID bits are set to BUF by software, this module sets the corresponding PIPEBEMP bit in BEMPSTS to 1. If the corresponding bit in BEMPENB is set to 1 by software, this module sets the BEMP bit in INTSTS0 to 1, allowing the USB interrupt to be generated. The following describes the conditions on which this module generates the internal BEMP interrupt request. - (a) For the pipe in the transmitting direction, when the FIFO buffer of the corresponding pipe is empty on completion of transmission (including zero-length packet transmission). In single buffer mode, the internal BEMP interrupt request is generated simultaneously with the BRDY interrupt for the pipe other than DCP. However, the internal BEMP interrupt request is not generated on any of the following conditions. - When software (DMAC) has already started writing data to the FIFO buffer of the CPU on completion of transmitting data of one plane in double buffer mode. - When the buffer is cleared (emptied) by setting the ACLRM or BCLR bit to 1. - When IN transfer (zero-length packet transmission) is performed during the control transfer status stage in function controller mode. - (b) For the pipe in the receiving direction: - When the successfully-received data packet size exceeds the specified maximum packet size. In this case, this module generates the BEMP interrupt request, setting the corresponding PIPEBEMP bit to 1, and discards the received data and modifies the setting of the PID bits of the corresponding pipe to STALL (11). - Here, this module returns no response when used as the host controller, and returns STALL response when used as the function controller. - However, the internal BEMP interrupt request is not generated on any of the following conditions. - When a CRC error or bit stuffing error is detected in the received data. - When a setup transaction is being performed. Writing 0 to the PIPEBEMP bit clears the status; writing 1 to the PIPEBEMP bit has no effect. Figure 17.5 shows the timing at which a BEMP interrupt is generated when the function controller function has been selected. Figure 17.5 Timing at which BEMP Interrupt is Generated when Function Controller Function is Selected ## (4) Device State Transition Interrupt Figure 17.6 shows a diagram of this module device state transitions. This module controls device states and generates device state transition interrupts. However, recovery from the suspended state (resume signal detection) is detected by means of the resume interrupt. The device state transition interrupts can be enabled or disabled individually using INTENBO. The device state that made a transition can be confirmed using the DVSQ bit in INTSTSO. To make a transition to the default state, the device state transition interrupt is generated after the reset handshake protocol has been completed. Device state can be controlled only when the function controller function is selected. Also, the device state transition interrupts can be generated only when the function controller function is selected. Figure 17.6 Device State Transitions #### **(5) Control Transfer Stage Transition Interrupt** Figure 17.7 shows a diagram of how this module handles the control transfer stage transition. This module controls the control transfer sequence and generates control transfer stage transition interrupts. Control transfer stage transition interrupts can be enabled or disabled individually using INTENBO. The transfer stage that made a transition can be confirmed using the CTSQ bit in INTSTS0. The control transfer stage transition interrupts are generated only when the function controller function is selected. The control transfer sequence errors are described below. If an error occurs, the PID bit in DCPCTR is set to B'1x (STALL). #### (a) **During control read transfers** - At the IN token of the data stage, an OUT or PING token is received when there have been no data transfers at all. - An IN token is received at the status stage - A packet is received at the status stage for which the data packet is DATAPID = DATA0 ## (b) During control write transfers - At the OUT token of the data stage, an IN token is received when there have been no ACK response at all - A packet is received at the data stage for which the first data packet is DATAPID = DATA0 - At the status stage, an OUT or PING token is received ## (c) During no-data control transfers — At the status stage, an OUT or PING token is received At the control write transfer stage, if the number of receive data exceeds the wLength value of the USB request, it cannot be recognized as a control transfer sequence error. At the control read transfer status stage, packets other than zero-length packets are received by an ACK response and the transfer ends normally. When a CTRT interrupt occurs in response to a sequence error (SERR = 1), the CTSQ = 110 value is retained until CTRT = 0 is written from the system (the interrupt status is cleared). Therefore, while CTSQ = 110 is being held, the CTRT interrupt that ends the setup stage will not be generated even if a new USB request is received. (This module retains the setup stage end, and after the interrupt status has been cleared by software, a setup stage end interrupt is generated.) Figure 17.7 Control Transfer Stage Transitions #### (6)Frame Update Interrupt Figure 17.8 shows an example of the SOFR interrupt output timing of this module. With the host controller function selected, an interrupt is generated at the timing at which the frame number is updated. With the function controller function selected, the SOFR interrupt is generated when the frame number is updated. When the function controller function is selected, this module updates the frame number and generates an SOFR interrupt if it detects a new SOF packet during full-speed operation. During high-speed operation, however, this module does not update the frame number, or generates no SOFR interrupt until the module enters the µSOF locked state. Also, the SOF interpolation function is not activated. The uSOF lock state is the state in which uSOF packets with different frame numbers are received twice continuously without error occurrence. The conditions under which the µSOF lock monitoring begins and stops are as follows. - 1. Conditions under which µSOF lock monitoring begins USBE = 1 - 2. Conditions under which µSOF lock monitoring stops USBE = 0, a USB bus reset is received, or suspended state is detected. Figure 17.8 Example of SOFR Interrupt Output Timing ## (7) VBUS Interrupt If there has been a change in the VBUS pin, the VBUS interrupt is generated. The level of the VBUS pin can be checked with the VBSTS bit in INTSTSO. Whether the host controller is connected or disconnected can be confirmed using the VBUS interrupt. However, if the system is activated with the host controller connected, the first VBUS interrupt is not generated because there is no change in the VBUS pin. #### (8) Resume Interrupt The RESM interrupt is generated when the device state is the suspended state, and the USB bus state has changed (from J-state to K-state, or from J-state to SE0). Recovery from the suspended state is detected by means of the resume interrupt. ## (9) BCHG Interrupt The BCHG interrupt is generated when the USB bus state has changed. The BCHG interrupt can be used to detect whether or not the peripheral device is connected when the host controller function has been selected and can also be used to detect a remote wakeup. The BCHG interrupt is generated regardless of whether the host controller function or function controller function has been selected. ## (10) DTCH Interrupt The DTCH interrupt is generated if disconnection of the USB bus is detected when the host controller function has been selected. This module detects bus disconnection based on USB Specification 2.0. After detecting the DTCH interrupt, this module controls hardware as described below (irrespective of the set value of the corresponding interrupt enable bit). Software should terminate all the pipes in which communications are currently carried out for the pertinent port and make a transition to the wait state for bus connection to the pertinent port (wait state for ATTCH interrupt generation). - (a) Modifies the UACT bit for the port in which a DTCH interrupt has been detected to 0. - (b) Puts the port in which a DTCH interrupt has been generated into the idle state. ## (11) SACK Interrupt The SACK interrupt is generated when an ACK response for the transmitted setup packet has been received from the peripheral device with the host controller function selected. The SACK interrupt can be used to confirm that the setup transaction has been completed successfully. #### (12) SIGN Interrupt The SIGN interrupt is generated when an ACK response for the transmitted setup packet has not been correctly received from the peripheral device three consecutive times with the host controller function selected. The SIGN interrupt can be used to detect no ACK response transmitted from the peripheral device or corruption of an ACK packet. #### (13) ATTCH Interrupt The ATTCH interrupt is generated when J-state or K-state of the full-speed or low-speed level signal is detected on the USB port for 2.5 µs in host controller mode. To be more specific, the ATTCH interrupt is detected on any of the following conditions. - (a) When K-state, SE0, or SE1 changes to J-state, and J-state continues 2.5 μs. - (b) When J-state, SE0, or SE1 changes to K-state, and K-state continues 2.5 μs. ## (14) EOFERR Interrupt The EOFERR interrupt is generated when it is detected that communication is not completed at the EOF2 timing prescribed by USB Specification 2.0. After detecting the EOFERR interrupt, this module controls hardware as described below (irrespective of the set value of the corresponding interrupt enable bit). Software should terminate all the pipes in which communications are currently carried out for the pertinent port and perform re-enumeration of the pertinent port. - Modifies the UACT bit for the port in which an EOFERR interrupt has been detected to 0. (a) - Puts the port in which an EOFERR interrupt has been generated into the idle state. (b) # 17.4.3 Pipe Control Table 17.18 lists the pipe setting items of this module. With USB data transfer, data transmission has to be carried out using the logic pipe called the endpoint. This module has ten pipes that are used for data transfer. Settings should be entered for each of the pipes in conjunction with the specifications of the system. **Table 17.18 Pipe Setting Items** | Register<br>Name | Bit Name | Setting<br>Contents | Remarks | |-------------------|-----------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------| | DCPCFG<br>PIPECFG | TYPE | Specifies the transfer type | PIPE1 to PIPE9: Can be set | | | BFRE | Selects the<br>BRDY interrupt<br>mode | PIPE1 to PIPE5: Can be set | | | DBLB | Selects a double buffer | PIPE1 to PIPE5: Can be set | | | CNTMD | Selects continuous | PIPE1 and PIPE2: Can be set (only when bulk transfer has been selected). | | | | transfer or non-<br>continuous<br>transfer | PIPE3 to PIPE5: Can be set | | | DIR | Selects transfer direction | IN or OUT can be set | | | EPNUM | Endpoint number | PIPE1 to PIPE9: Can be set | | | | | A value other than 0000 should be set when the pipe is used. | | | SHTNAK Selects disabled state for pipe when transfer ends | PIPE1 and PIPE2: Can be set (only when bulk transfer has been selected) | | | | | | PIPE3 to PIPE5: Can be set | | PIPEBUF | BUFSIZE | Buffer memory size | DCP: Cannot be set (fixed at 256 bytes) | | | | | PIPE1 to PIPE5: Can be set (a maximum of 2<br>Kbytes can be specified) | | | | | PIPE6 to PIPE9: Cannot be set (fixed at 64 bytes) | | Register<br>Name | Bit Name | Setting<br>Contents | Remarks | |---------------------|----------|-------------------------|-----------------------------------------------------------------------------------------------| | PIPEBUF | BUFNMB | Buffer memory | DCP: Cannot be set (areas fixed at H'0 to H'3) | | | | number | PIPE1 to PIPE5: Can be set (can be specified in areas H'8 to H'7F) | | | | | PIPE6 to PIPE9: Cannot be set (areas fixed at H'4 to H'7) | | DCPMAXP<br>PIPEMAXP | DEVSEL | Selects a device | Referenced only when the host controller function is selected. | | | MXPS | Maximum packet size | Compliant with the USB standard. | | PIPEPERI | IFIS | Buffer flush | PIPE1 and PIPE2: Can be set (only when isochronous transfer has been selected) | | | | | PIPE3 to PIPE5: Cannot be set | | | | | PIPE6 to PIPE9: Can be set (only when the host controller function has been selected) | | | IITV | Interval counter | PIPE1 and PIPE2: Can be set (only when isochronous transfer has been selected) | | | | | PIPE3 to PIPE5: Cannot be set | | | | | PIPE6 to PIPE9: Can be set (only when the host controller function has been selected) | | DCPCTR<br>PIPEnCTR | BSTS | Buffer status | For the DCP, receive buffer status and transmit buffer status are switched with the ISEL bit. | | | INBUFM | IN buffer monitor | Mounted for PIPE3 to PIPE5. | | | SUREQ | SETUP request | Can be set only for the DCP. | | | | | Can be controlled only when the host controller function has been selected. | | | SUREQCLR | SUREQ clear | Can be set only for the DCP. | | | | | Can be controlled only when the host controller function has been selected. | | | CSCLR | CSSTS clear | Can be controlled only when the host controller function has been selected. | | | CSSTS | SPLIT status indication | Can be referenced only when the host controller function has been selected. | | Register<br>Name | Bit Name | Setting<br>Contents | Remarks | |------------------|----------|-----------------------------------------|---------------------------------------------------------------------------------| | DCPCTR | ATREPM | Auto response | PIPE1 to PIPE5: Can be set | | PIPEnCTR | | mode | Can be controlled only when the function controller function has been selected. | | | ACLRM | Auto buffer clear | PIPE1 to PIPE9: Can be set | | | SQCLR | Sequence clear | Clears the data toggle bit | | | SQSET | Sequence set | Sets the data toggle bit | | | SQMON | Sequence<br>monitor | Monitors the data toggle bit | | | PBUSY | Pipe busy status | | | | PID | Response PID | See section 17.4.3 (6), Response PID | | PIPEnTRE | TRENB | Transaction counter enable | PIPE1 to PIPE5: Can be set | | | TRCLR | Current<br>transaction<br>counter clear | PIPE1 to PIPE5: Can be set | | PIPEnTRN | TRNCNT | Transaction counter | PIPE1 to PIPE5: Can be set | #### (1)Pipe control register switching procedures The following bits in the pipe control registers can be modified only when USB communication is disabled (PID = NAK): Registers that Should Not be Set in the USB Communication Enabled (PID = BUF) State - Bits in DCPCFG and DCPMAXP - The SQCLR and SQSET bits in DCPCTR - Bits in PIPECFG, PIPEBUF, PIPEMAXP and PIPEPERI - The ATREPM, ACLRM, SQCLR and SQSET bits in PIPExCTR - Bits in PIPExTRE and PIPExTRN In order to modify the above bits from the USB communication enabled (PID = BUF) state, follow the procedure shown below: - 1. Generate a bit modification request with the pipe control register. - 2. Modify the PID corresponding to the pipe to NAK. - 3. Wait until the corresponding CSSTS bit is cleared to 0 (only when the host controller function has been selected). - 4. Wait until the corresponding PBUSY bit is cleared to 0. - 5. Modify the bits in the pipe control register. The following bits in the pipe control registers can be modified only when the pertinent information has not been set by the CURPIPE bits in CFIFOSEL, D0FIFOSEL and D1FIFOSEL. Registers that Should Not be Set When CURPIPE in FIFO-PORT is set. - Bits in DCPCFG and DCPMAXP - Bits in PIPECFG, PIPEBUF, PIPEMAXP and PIPEPERI In order to modify pipe information, the CURPIPE bits should be set to the pipes other than the pipe to be modified. For the DCP, the buffer should be cleared using BCLR after the pipe information is modified. ## (2) Transfer Types The TYPE bit in PIPEPCFG is used to specify the transfer type for each pipe. The transfer types that can be set for the pipes are as follows. - 1. DCP: No setting is necessary (fixed at control transfer). - 2. PIPE1 and PIPE2: These should be set to bulk transfer or isochronous transfer. - 3. PIPE3 to PIPE5: These should be set to bulk transfer. - 4. PIPE6 to PIPE9: These should be set to interrupt transfer. #### (3) Endpoint Number The EPNUM bit in PIPEPCFG is used to set the endpoint number for each pipe. The DCP is fixed at endpoint 0. The other pipes can be set from endpoint 1 to endpoint 15. - 1. DCP: No setting is necessary (fixed at end point 0). - 2. PIPE1 to PIPE9: The endpoint numbers from 1 to 15 should be selected and set. These should be set so that the combination of the DIR bit and EPNUM bit is unique. ## (4) Maximum Packet Size Setting The MXPS bit in DCPMAXP and PIPEMAXP is used to specify the maximum packet size for each pipe. DCP and PIPE1 to PIPE5 can be set to any of the maximum pipe sizes defined by the USB specification. For PIPE6 to PIPE9, 64 bytes are the upper limit of the maximum packet size. The maximum packet size should be set before beginning the transfer (PID = BUF). - 1. DCP: 64 should be set when using high-speed operation. - 2. DCP: Select and set 8, 16, 32, or 64 when using full-speed operation. - 3. PIPE1 to PIPE5: 512 should be set when using high-speed bulk transfer. - 4. PIPE1 to PIPE5: Select and set 8, 16, 32, or 64 when using full-speed bulk transfer. - 5. PIPE1 and PIPE2: Set a value between 1 and 1024 when using high-speed isochronous transfer. - 6. PIPE1 and PIPE2: Set a value between 1 and 1023 when using full-speed isochronous transfer. - 7. PIPE6 to PIPE9: Set a value between 1 and 64. The high bandwidth transfers used with interrupt transfers and isochronous transfers are not supported. #### **(5)** Transaction Counter (For PIPE1 to PIPE5 in Reading Direction) When the specified number of transactions have been completed in the data packet receiving direction, this module recognizes that the transfer has ended. The transaction counter function is available when the pipes assigned to the D0FIFO/D1FIFO port have been set in the direction of reading data from the buffer memory. Two transaction counters are provided: one is the TRNCNT register that specifies the number of transactions to be executed and the other is the current counter that internally counts the number of executed transactions. When the current counter value matches the number of the transactions specified in TRNCNT, reading the buffer memory is enabled. The current counter of the transaction counter function is initialized by the TRCLR bit, so that the transactions can be counted again starting from the beginning. The information read from TRNCNT differs depending on the setting of the TRENB bit. - TRENB = 0: The specified transaction counter value can be read. - TRENB = 1: The current counter value indicating the internally counted number of executed transactions can be read. When operating the TRCLR bit, the following should be noted. - If the transactions are being counted and PID = BUF, the current counter cannot be cleared. - If there is any data left in the buffer, the current counter cannot be cleared. #### **Response PID** (6) The PID bits in DCPCTR and PIPEnCTR are used to set the response PID for each pipe. The following shows this module operation with various response PID settings: #### Response PID settings when the host controller function is selected: (a) The response PID is used to specify the execution of transactions. - (i) NAK setting: Using pipes is disabled. No transaction is executed. - (ii) BUF setting: Transactions are executed based on the status of the buffer memory. For OUT direction: If there are transmit data in the buffer memory, an OUT token is issued. For IN direction: If there is an area to receive data in the buffer memory, an IN token is issued. - (iii) STALL setting: Using pipes is disabled. No transaction is executed. Setup transactions for the DCP are set with the SUREQ bit. #### (b) Response PID settings when the function controller function is selected: The response PID is used to specify the response to transactions from the host. - (i) NAK setting: The NAK response is always returned in response to the generated transaction. - (ii) BUF setting: Responses are made to transactions based on the status of the buffer memory. - (iii) STALL setting: The STALL response is always returned in response to the generated transaction. For setup transactions, an ACK response is always returned, regardless of the PID setting, and the USB request is stored in the register. This module may carry out writing to the PID bits, depending on the results of the transaction. - (c) When the host controller function has been selected and the response PID is set by hardware: - (i) NAK setting: In the following cases, PID = NAK is set and issuing of tokens is automatically stopped: - When a transfer other than isochronous transfer has been performed and the NRDY interrupt is generated. (For details, see descriptions of the NRDY interrupt.) - If a short packet is received when the SHTNAK bit in PIPECFG has been set to 1 for bulk transfer. - If the transaction counter ended when the SHTNAK bit has been set to 1 for bulk transfer. - (ii) BUF setting: There is no BUF writing by this module. - (iii) STALL setting: In the following cases, PID = STALL is set and issuing of tokens is automatically stopped: - When STALL is received in response to the transmitted token. - When the size of the receive data packet exceeds the maximum packet size. #### (d) When the function controller function has been selected and the response PID is set by hardware: - (i) NAK setting: In the following cases, PID = NAK is set and NAK is always returned in response to transactions: - When the SETUP token is received normally (DCP only). - If the transaction counter ended or a short packet is received when the SHTNAK bit in PIPECFG has been set to 1 for bulk transfer. - (ii) BUF setting: There is no BUF writing by this module. - STALL setting: In the following cases, PID = STALL is set and STALL is always returned (iii) in response to transactions: - When the size of the receive data packet exceeds the maximum packet size. - When a control transfer sequence error has been detected (DCP only). ## **Data PID Sequence Bit** This module automatically toggles the sequence bit in the data PID when data is transferred normally in the control transfer data stage, bulk transfer and interrupt transfer. The sequence bit of the data PID that was transmitted can be confirmed with the SQMON bit in DCPCTR and PIPEnCTR. When data is transmitted, the sequence bit switches at the timing at which the ACK handshake is received. When data is received, the sequence bit switches at the timing at which the ACK handshake is transmitted. The SQCLR bit in DCPCTR and the SQSET bit in PIPEnCTR can be used to change the data PID sequence bit. When the function controller function has been selected and control transfer is used, this module automatically sets the sequence bit when a stage transition is made. DATA0 is returned when the setup stage is ended and DATA1 is returned in a status stage. Therefore, software settings are not required. However, when the host controller function has been selected and control transfer is used, the sequence bit should be set by software at the stage transition. For the Clearfeature request transmission or reception, the data PID sequence bit should be set by software, regardless of whether the host controller function or function controller function is selected. With pipes for which isochronous transfer has been set, sequence bit operation cannot be carried out using the SQSET bit. ## (8) Response PID = NAK Function This module has a function that disables pipe operation (PID response = NAK) at the timing at which the final data packet of a transaction is received (this module automatically distinguishes this based on reception of a short packet or the transaction counter) by setting the SHTNAK bit in PIPECFG to 1. When a double buffer is being used for the buffer memory, using this function enables reception of data packets in transfer units. If pipe operation has disabled, the pipe has to be set to the enabled state again (PID response = BUF) using software. This function can be used only when bulk transfers are used. #### (9) Auto Transfer MODE With the pipes for bulk transfer (PIPE1 to PIPE5), when the ATREPM bit in PIPEnCTR is set to 1, a transition is made to auto response mode. During an OUT transfer (DIR = 0), OUT-NAK mode is entered, and during an IN transfer (DIR = 1), null auto response mode is entered. #### (a) OUT-NAK Mode With the pipes for bulk OUT transfer, NAK is returned in response to an OUT or PING token and an NRDY interrupt is output when the ATREPM bit is set to 1. To make a transition from normal mode to OUT-NAK mode, OUT-NAK mode should be specified in the pipe operation disabled state (response PID = NAK) before enabling pipe operation (response PID = BUF). After pipe operation has been enabled, OUT-NAK mode becomes valid. However, if an OUT token is received immediately before pipe operation is disabled, the token data is normally received, and an ACK is returned to the host. To make a transition from OUT-NAK mode to normal mode, OUT-NAK mode should be canceled in the pipe operation disabled state (response PID = NAK) before enabling pipe operation (response PID = BUF). In normal mode, reception of OUT data is enabled and an ACK is returned in response to a PING token if the buffer is ready to receive data. #### (b) **Null Auto Response Mode** With the pipes for bulk IN transfer, zero-length packets are continuously transmitted when the ATREPM bit is set to 1. To make a transition from normal mode to null auto response mode, null auto response mode should be set in the pipe operation disabled state (response PID = NAK) before enabling pipe operation (response PID = BUF). After pipe operation has been enabled, null auto response mode becomes valid. Before setting null auto response mode, INBUFM = 0 should be confirmed because the mode can be set only when the buffer is empty. If the INBUFM bit is 1, the buffer should be emptied with the ACLRM bit. While a transition to null auto response mode is being made, data should not be written from the FIFO port. To make a transition from null auto response mode to normal mode, pipe operation disabled state (response PID = NAK) should be retained for the period of zero-length packet transmission (fullspeed: 10 µs, high-speed: 3 µs) before canceling null auto response mode. In normal mode, data can be written from the FIFO port; therefore, packet transmission to the host is enabled by enabling pipe operation (response PID = BUF). ## 17.4.4 FIFO Buffer Memory #### (1) FIFO Buffer Memory Allocation Figure 17.9 shows an example of a FIFO buffer memory map for this module. The FIFO buffer memory is an area shared by the CPU and this module. In the FIFO buffer memory status, there are times when the access right to the buffer memory is allocated to the user system (CPU side), and times when it is allocated to this module (SIE side). The buffer memory sets independent areas for each pipe. In the memory areas, 64 bytes comprise one block, and the memory areas are set using the first block number of the number of blocks (specified using the BUFNMB and BUFSIZE bits in PIPEBUF). Independent buffer memory areas should be set for each pipe. Each memory area can be set using the first block number and the number of blocks (specified using the BUFNMB and BUFSIZE bits in PIPEBUF), where one block comprises 64 bytes. When continuous transfer mode has been selected using the CNTMD bit in PIPEnCFG, the BUFSIZE bits should be set so that the buffer memory size should be an integral multiple of the maximum packet size. When double buffer mode has been selected using the DBLB bit in PIPEnCFG, two planes of the memory area specified using the BUFSIZE bits in PIPEBUF can be assigned to a single pipe. Moreover, three FIFO ports are used for access to the buffer memory (reading and writing data). A pipe is assigned to the FIFO port by specifying the pipe number using the CURPIPE bit in C/DnFIFOSEL. The buffer statuses of the various pipes can be confirmed using the BSTS bit in DCPCTR and the INBUFM bit in PIPEnCTR. Also, the access right of the FIFO port can be confirmed using the FRDY bit in CFIFOCTR or DnFIFOCTR. Figure 17.9 Example of a Buffer Memory Map ## (a) Buffer Status Tables 17.19 and 17.20 show the buffer status. The buffer memory status can be confirmed using the BSTS bit in DCPCTR and the INBUFM bit in PIPEnCTR. The access direction for the buffer memory can be specified using either the DIR bit in PIPEnCFG or the ISEL bit in CFIFOSEL (when DCP is selected). The INBUFM bit is valid for PIPE0 to PIPE5 in the sending direction. For an IN pipe uses double buffer, software can refer the BSTS bit to monitor the buffer memory status of CPU side and the INBUFM bit to monitor the buffer memory status of SIE side. In the case like the BEMP interrupt may not shows the buffer empty status because the CPU (DMAC) writes data slowly, software can use the INBUFM bit to confirm the end of sending. Table 17.19 Buffer Status Indicated by the BSTS Bit | ISEL or DIR | BSTS | Buffer Memory State | |-------------------------|------|-----------------------------------------------------------------------------------------------------------------| | 0 (receiving direction) | 0 | There is no received data, or data is being received. | | | | Reading from the FIFO port is inhibited. | | 0 (receiving direction) | 1 | There is received data, or a zero-length packet has been received. | | | | Reading from the FIFO port is allowed. | | | | However, because reading is not possible when a zero-<br>length packet is received, the buffer must be cleared. | | 1 (transmitting | 0 | The transmission has not been finished. | | direction) | | Writing to the FIFO port is inhibited. | | 1 (transmitting | 1 | The transmission has been finished. | | direction) | | CPU write is allowed. | # Table 17.20 Buffer Status Indicated by the INBUFM Bit | IDIR | INBUFM | Buffer Memory State | |-------------------------|---------|-----------------------------------------------| | 0 (receiving direction) | Invalid | Invalid | | 1 (transmitting | 0 | The transmission has been finished. | | direction) | | There is no waiting data to be transmitted. | | 1 (transmitting | 1 | The FIFO port has written data to the buffer. | | direction) | | There is data to be transmitted | #### (b) FIFO Buffer Clearing Table 17.21 shows the clearing of the FIFO buffer memory by this module. The buffer memory can be cleared using the three bits indicated below. **Table 17.21 List of Buffer Clearing Methods** | Bit Name | BCLR | DCLRM | ACLRM | |----------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | Register | CFIFOCTR | DnFIFOSEL | PIPEnCTR | | | DnFIFOCTR | | | | Function | Clears the buffer memory<br>on the CPU side | In this mode, after the data of the specified pipe has been read, the buffer memory is cleared automatically. | This is the auto buffer clear mode, in which all of the received packets are discarded. | | Clearing | Cleared by writing 1 | 1: Mode valid | 1: Mode valid | | method | | 0: Mode invalid | 0: Mode invalid | #### (c) Buffer Areas Table 17.22 shows the FIFO buffer memory map of this controller. The buffer memory has special fixed areas to which pipes are assigned in advance, and user areas that can be set by the user. The buffer for the DCP is a special fixed area that is used both for control read transfers and control write transfers. The PIPE6 to PIPE9 area is assigned in advance, but the area for pipes that are not being used can be assigned to PIPE1 to PIPE5 as a user area. The settings should ensure that the various pipes do not overlap. Note that each area is twice as large as the setting value in the double buffer. Also, the buffer size should not be specified using a value that is less than the maximum packet size. **Table 17.22 Buffer Memory Map** | Buffer Memory<br>Number | Buffer Size | Pipe Setting | Note | |-------------------------|---------------------|-----------------------------|--------------------------------------------------------| | H'0 | 64 bytes | Fixed area only for the DCP | Single buffer, continuous transfers enabled | | H'1 to H'3 | _ | Prohibited to be used | _ | | H'4 | 64 bytes | Fixed area for<br>PIPE6 | Single buffer | | H'5 | 64 bytes | Fixed area for<br>PIPE7 | Single buffer | | H'6 | 64 bytes | Fixed area for PIPE8 | Single buffer | | H'7 | 64 bytes | Fixed area for<br>PIPE9 | Single buffer | | H'8 to H'7F | Up to 7616<br>bytes | PIPE1 to PIPE5<br>user area | Double buffer can be set, continuous transfers enabled | #### (d) Auto Buffer Clear Mode Function With this module, all of the received data packets are discarded if the ACLRM bit in PIPEnCTR is set to 1. If a normal data packet has been received, the ACK response is returned to the host controller. This function can be set only in the buffer memory reading direction. Also, if the ACLRM bit is set to 1 and then to 0, the buffer memory of the selected pipe can be cleared regardless of the access direction. An access cycle of at least 100 ns is required between ACLRM = 1 and ACLRM = 0. ## (e) Buffer Memory Specifications (Single/Double Setting) Either a single or double buffer can be selected for PIPE1 to PIPE5, using the DBLB bit in PIPEnCFG. The double buffer is a function that assigns two memory areas specified with the BUFSIZE bit in PIPEBUF to the same pipe. Figure 17.10 shows an example of buffer memory settings for this module. Figure 17.10 Example of Buffer Memory Settings #### (f) Buffer Memory Operation (Continuous Transfer Setting) Either the continuous transfer mode or the non-continuous transfer mode can be selected, using the CNTMD bit in PIPEnCFG. This selection is valid for PIPE1 to PIPE5. The continuous transfer mode function is a function that sends and receives multiple transactions in succession. When the continuous transfer mode is set, data can be transferred without interrupts being issued to the CPU, up to the buffer sizes assigned for each of the pipes. In the continuous sending mode, the data being written is divided into packets of the maximum packet size and sent. If the data being sent is less than the buffer size (short packet, or the integer multiple of the maximum packet size is less than the buffer size), BVAL = 1 must be set after the data being sent has been written. In the continuous reception mode, interrupts are not issued during reception of packets up to the buffer size, until the transaction counter has ended, or a short packet is received. Table 17.23 describes the relationship between the transfer mode settings by CNTMD bit and the timings at which reading data or transmitting data from the FIFO buffer is enabled. Table 17.23 Relationship between Transfer Mode Settings by CNTMD Bit and Timings at which Reading Data or Transmitting Data from FIFO Buffer is Enabled | Continuous or Non-<br>Continuous Transfer<br>Mode | |---------------------------------------------------| | Non-continuous | ## When Reading Data or Transmitting Data is Enabled ## transfer In the receiving direction (DIR = 0), reading data from the FIFO buffer is enabled when: (CNTMD = 0) This module receives one packet. In the transmitting direction (DIR = 1), transmitting data from the FIFO buffer is enabled when: Software (or DMAC) writes data of the maximum packet size to the FIFO buffer. or Software (or DMAC) writes data of the short packet size (including 0byte data) to the FIFO buffer and then writes 1 to BVAL. ## Continuous transfer (CNTMD = 1) In the receiving direction (DIR = 0), reading data from the FIFO buffer is enabled when: - The number of the data bytes received in the FIFO buffer assigned to the selected pipe becomes the same as the number of assigned data bytes ((BUFSIZE + 1) \* 64). - This module receives a short packet other than a zero-length packet. - This module receives a zero-length packet when data is already stored in the FIFO buffer assigned to the selected pipe. - This module receives the number of packets equal to the transaction counter value specified for the selected pipe by software. In the transmitting direction (DIR = 1), transmitting data from the FIFO buffer is enabled when: - The number of the data bytes written to the FIFO buffer by software (or DMAC) becomes the same as the number of data bytes in a single FIFO buffer plane assigned to the selected pipe. or - Software (or DMAC) writes to the FIFO buffer the number of data bytes less than the size of a single FIFO buffer plane (including 0-byte data) assigned to the selected pipe and then writes 1 to BVAL. Figure 17.11 shows an example of buffer memory operation for this module. Figure 17.11 Example of Buffer Memory Operation #### (2) FIFO Port Functions Table 17.24 shows the settings for the FIFO port functions of this module. In write access, writing data until the buffer is full (or the maximum packet size for non-continuous transfers) automatically enables sending of the data. To enable sending of data before the buffer is full (or before the maximum packet size for non-continuous transfers), the BVAL bit in C/DnFIFOCTR must be set to end the writing. Also, to send a zero-length packet, the BCLR bit in the same register must be used to clear the buffer and then the BVAL bit set in order to end the writing. In read access, reception of new packets is automatically enabled if all of the data has been read. Data cannot be read when a zero-length packet is being received (DTLN = 0), so the BCLR bit in the register must be used to release the buffer. The length of the data being received can be confirmed using the DTLN bit in C/DnFIFOCTR. **Table 17.24 FIFO Port Function Settings** | Register Name | Bit Name | Function | Note | |---------------|----------|--------------------------------------------------------------------------------------|-----------------| | C/DnFIFOSEL | RCNT | Selects DTLN read mode | | | | REW | Buffer memory rewind (re-read, rewrite) | | | | DCLRM | Automatically clears data received for a specified pipe after the data has been read | For DnFIFO only | | | DREQE | Enables DMA transfers | For DnFIFO only | | | MBW | FIFO port access bit width | | | | BIGEND | Selects FIFO port endian | | | | ISEL | FIFO port access direction | | | | CURPIPE | Selects the current pipe | For DCP only | | C/DnFIFOCTR | BVAL | Ends writing to the buffer memory | | | | BCLR | Clears the buffer memory on the CPU side | | | | DTLN | Checks the length of received data | | #### (a) FIFO Port Selection Table 17.25 shows the pipes that can be selected with the various FIFO ports. The pipe to be accessed is selected using the CURPIPE bit in C/DnFIFOSEL. After the pipe is selected, whether the CURPIPE value for the pipe which was written last can be correctly read should be checked. (If the previous pipe number is read, it indicates that the pipe modification is being executed by this module.) Then, the FIFO port can be accessed after FRDY = 1 is checked. Also, the bus width to be accessed should be selected using the MBW bit. The buffer memory access direction conforms to the DIR bit in PIPEnCFG. The ISEL bit determines this only for the DCP. Table 17.25 FIFO Port Access Categorized by Pipe | Access Method | Port that can be Used | | |---------------|-----------------------------|--| | CPU access | CFIFO port register | | | CPU access | CFIFO port register | | | | D0FIFO/D1FIFO port register | | | DMA access | D0FIFO/D1FIFO port register | | | | CPU access CPU access | | #### (b) REW Bit It is possible to temporarily stop access to the pipe currently being accessed, access a different pipe, and then continue processing using the current pipe once again. The REW bit in C/DnFIFOSEL is used for this. If a pipe is selected when the REW bit is set to 1 and at the same time the CURPIPE bit in C/DnFIFOSEL is set, the pointer used for reading from and writing to the buffer memory is reset, and reading or writing can be carried out from the first byte. Also, if a pipe is selected with 0 set for the REW bit, data can be read and written in continuation of the previous selection, without the pointer used for reading from and writing to the buffer memory being reset. To access the FIFO port, FRDY = 1 must be ensured after selecting a pipe. #### (3) DMA Transfers (D0FIFO/D1FIFO port) #### (a) Overview of DMA Transfers For pipes 1 to 9, the FIFO port can be accessed using the DMAC. When accessing the buffer for the pipe targeted for DMA transfer is enabled, a DMA transfer request is issued. The unit of transfer to the FIFO port should be selected using the MBW bit in DnFIFOSEL and the pipe targeted for the DMA transfer should be selected using the CURPIPE bit. The selected pipe should not be changed during the DMA transfer. ## (b) Auto Recognition of DMA Transfer Completion With this module, it is possible to complete FIFO data writing through DMA transfer by controlling DMA transfer end signal input. When a transfer end signal is sampled, the module enables buffer memory transmission (the same condition as when BVAL = 1). ## (c) DnFIFO Auto Clear Mode (D0FIFO/D1FIFO Port Reading Direction) If 1 is set for the DCLRM bit in DnFIFOSEL, the module automatically clears the buffer memory of the selected pipe when reading of the data from the buffer memory has been completed. Table 17.26 shows the packet reception and buffer memory clearing processing for each of the various settings. As shown, the buffer clear conditions depend on the value set to the BFRE bit. Using the DCLRM bit eliminates the need for the buffer to be cleared by software even if a situation occurs that necessitates clearing of the buffer. This makes it possible to carry out DMA transfers without involving software. This function can be set only in the buffer memory reading direction. Table 17.26 Packet Reception and Buffer Memory Clearing Processing #### Register Setting DCLRM = 0DCLRM = 1**Buffer Status** When Packet is Received BFRE = 1BFRE = 0BFRE = 1BFRE = 0Buffer full Doesn't need Doesn't need Doesn't need Doesn't need to be cleared to be cleared to be cleared to be cleared Zero-length packet reception Needs to be Needs to be Doesn't need Doesn't need cleared cleared to be cleared to be cleared Normal short packet reception Doesn't need Needs to be Doesn't need Doesn't need to be cleared cleared to be cleared to be cleared Transaction count ended Doesn't need Needs to be Doesn't need Doesn't need to be cleared cleared to be cleared to be cleared #### 17.4.5 Control Transfers (DCP) Data transfers of the data stage of control transfers are done using the default control pipe (DCP). The DCP buffer memory is a 256-byte single buffer, and is a fixed area that is shared for both control reading and control writing. The buffer memory can be accessed through the CFIFO port. ### (1) Control Transfers when the Host Controller Function is Selected ## (a) Setup Stage USQREQ, USBVAL, USBINDX, and USBLENG are the registers that are used to transmit a USB request for setup transactions. Writing setup packet data to the registers and writing 1 to the SUREQ bit in DCPCTR transmits the specified data for setup transactions. Upon completion of transactions, the SUREQ bit is cleared to 0. The above USB request registers should not be modified while SUREQ = 1. The device address for setup transactions is specified using the DEVSEL bits in DCPMAXP. When the data for setup transactions has been sent, a SIGN or SACK interrupt request is generated according to the response received from the peripheral device (SIGN1 or SACK bits in INTSTS1), by means of which the result of the setup transactions can be confirmed. A data packet of DATA0 (USB request) is transmitted as the data packet for the setup transactions regardless of the setting of the SQMON bit in DCPCTR. #### **(b) Data Stage** Data transfers are done using the DCP buffer memory. The access direction of the DCP buffer memory should be specified using the ISEL bit in CFIFOSEL. For the first data packet of the data stage, the data PID must be transferred as DATA1. Transaction is done by setting the data PID = DATA1 and the PID bit = BUF using the SQSET bit in DCPCFG. Completion of data transfer is detected using the BRDY and BEMP interrupts. Setting continuous transfer mode allows data transfers over multiple packets. Note that when continuous transfer mode is set for the receiving direction, the BRDY interrupt is not generated until the buffer becomes full or a short packet is received (the integer multiple of the maximum packet size, and less than 256 bytes). For control write transfers, when the number of data bytes to be sent is the integer multiple of the maximum packet size, software must control so as to send a zero-length packet at the end. #### (c) **Status Stage** Zero-length packet data transfers are done in the direction opposite to that in the data stage. As with the data stage, data transfers are done using the DCP buffer memory. Transactions are done in the same manner as the data stage. For the data packets of the status stage, the data PID must be transferred as DATA1. The data PID should be set to DATA1 using the SQSET bit in DCPCFG. For reception of a zero-length packet, the received data length must be confirmed using the DTLN bits in CFIFOCTR after the BRDY interrupt is generated, and the buffer memory must then be cleared using the BCLR bit. #### (2) Control Transfers when the Function Controller Function is Selected #### (a) Setup Stage This module always sends an ACK response in response to a setup packet that is normal with respect to this module. The operation of this module operates in the setup stage is noted below. - (i) When a new USB request is received, this module sets the following registers: - Set the VALID bit in INTSTS0 to 1. - Set the PID bit in DCPCTR to NAK. - Set the CCPL bit in DCPCTR to 0. - (ii) When a data packet is received right after the SETUP packet, the USB request parameters are stored in USBREQ, USBVAL, USBINDX, and USBLENG. Response processing with respect to the control transfer should always be carried out after first setting VALID = 0. In the VALID = 1 state, PID = BUF cannot be set, and the data stage cannot be terminated. Using the function of the VALID bit, this module is able to interrupt the processing of a request currently being processed if a new USB request is received during a control transfer, and can send a response in response to the newest request. Also, this module automatically judges the direction bit (bit 8 of the bmRequestType) and the request data length (wLength) of the USB request that was received, and then distinguishes between control read transfers, control write transfers, and no-data control transfers, and controls the stage transition. For a wrong sequence, the sequence error of the control transfer stage transition interrupt is generated, and the software is notified. For information on the stage control of this module, see figure 17.7. ### (b) Data Stage Data transfers corresponding to USB requests that have been received should be done using the DCP. Before accessing the DCP buffer memory, the access direction should be specified using the ISEL bit in CFIFOSEL. If the data being transferred is larger than the size of the DCP buffer memory, the data transfer should be carried out using the BRDY interrupt for control write transfers and the BEMP interrupt for control read transfers. With control write transfers during high-speed operation, the NYET handshake response is carried out based on the state of the buffer memory. #### (c) **Status Stage** Control transfers are terminated by setting the CCPL bit to 1 with the PID bit in DCPCTR set to PID = RUF After the above settings have been entered, this module automatically executes the status stage in accordance with the data transfer direction determined at the setup stage. The specific procedure is as follows. (i) For control read transfers: This module sends a zero-length packet and receives an ACK response from the USB host. (ii) For control write transfers and no-data control transfers: The zero-length packet is received from the USB host, and this module sends an ACK response. #### (d) **Control Transfer Auto Response Function** This module automatically responds to a normal SET\_ADDRESS request. If any of the following errors occur in the SET\_ADDRESS request, a response from the software is necessary. - (i) Any transfer other than a control read transfer: $bmRequestType \neq H'00$ - (ii) If a request error occurs: wIndex $\neq$ H'00 - For any transfer other than a no-data control transfer: wLength ≠ H'00 (ii) - (iv) If a request error occurs: wValue > H'7F - Control transfer of a device state error: DVSQ = 011 (Configured) For all requests other than the SET\_ADDRESS request, a response is required from the corresponding software. #### 17.4.6 Bulk Transfers (PIPE1 to PIPE5) The buffer memory specifications for bulk transfers (single/double buffer setting, or continuous/non-continuous transfer mode setting) can be selected. The maximum size that can be set for the buffer memory is 2 Kbytes. The buffer memory state is controlled by this module, with a response sent automatically for a PING packet/NYET handshake. #### (1) PING Packet Control when the Host Controller Function is Selected This module automatically sends a PING packet in the OUT direction. On receiving an ACK handshake in the initial state in which PING packet sending mode is set, this module sends an OUT packet as noted below. Reception of an NAK or NYET handshake returns this module to PING packet sending mode. This control also applies to the control transfers in the data stage and status stage. - 1. Sets OUT data sending mode. - 2. Sends a PING packet. - Receives an ACK handshake. - 4. Sends an OUT data packet. - 5. Receives an ACK handshake. (Repeats steps 4 and 5.) - 6. Sends an OUT data packet. - 7. Receives an NAK/NYET handshake. - 8. Sends a PING packet. Page 814 of 1278 This module is returned to PING packet sending mode by a power-on reset, receiving a NYET/NAK handshake, setting or clearing the sequence toggle bits (SQSET and SQCLR), and setting the buffer clear bit (ACLRM) in PIPEnCTR. #### NYET Handshake Control when the Function Controller Function is Selected **(2)** Table 17.27 shows the NYET handshake responses of this module. The NYET response of this module is made in conformance with the conditions noted below. When a short packet is received, however, the response will be an ACK response instead of a NYET packet response. The same applies to the data stages of control write transfers. **Table 17.27 NYET Handshake Responses** | Value Set<br>for PID Bit in | Buffer<br>Memory | | | | |-----------------------------|------------------|-----------------|-------------|---------------------------------------------------------| | DCPCTR | State | Token | Response | Note | | NAK/STALL | _ | SETUP | ACK | _ | | | _ | IN/OUT/<br>PING | NAK/STALL | _ | | BUF | _ | SETUP | ACK | _ | | | RCV-BRDY1 | OUT/PING | ACK | If an OUT token is received, a data packet is received. | | | RCV-BRDY2 | OUT | NYET | Notifies whether a data packet can be received | | | RCV-BRDY2 | OUT (Short) | ACK | Notifies whether a data packet can be received | | | RCV-BRDY2 | PING | ACK | Notifies that a data packet can be received | | | RCV-NRDY | OUT/PING | NAK | Notifies that a data packet cannot be received | | | TRN-BRDY | IN | DATA0/DATA1 | A data packet is transmitted | | | TRN-NRDY | IN | NAK | TRN-NRDY | [Legend] RCV-BRDY1: When an OUT/PING token is received, there is space in the buffer memory for two or more packets. RCV-BRDY2: When an OUT token is received, there is only enough space in the buffer memory for one packet. RCV-NRDY: When a PING token is received, there is no space in the buffer memory. TRN-BRDY: When an IN token is received, there is data to be sent in the buffer memory. TRN-NRDY: When an IN token is received, there is no data to be sent in the buffer memory. ### 17.4.7 Interrupt Transfers (PIPE6 to PIPE9) When the function controller function is selected, this module carries out interrupt transfers in accordance with the timing controlled by the host controller. For interrupt transfers, PING packets are ignored (no responses are sent), and the ACK, NAK, and STALL responses are carried out without an NYET handshake response being made. When the host controller function is selected, this module can set the timing of issuing a token using the interval timer. At this time, this module issues an OUT token even in the OUT direction, without issuing a PING token. This module does not support high bandwidth transfers of interrupt transfers. ## (1) Interval Counter during Interrupt Transfers when the Host Controller Function is Selected For interrupt transfers, intervals between transactions are set in the IITV bits in PIPEPERI. This controller issues an interrupt transfer token based on the specified intervals. #### (a) Counter Initialization This controller initializes the interval counter under the following conditions. (i) Power-on reset: The IITV bits are initialized. (ii) Buffer memory initialization using the ACLRM bit: The IITV bits are not initialized but the count value is. Setting the ACLRM bit to 0 starts counting from the value set in the IITV bits. Note that the interval counter is not initialized in the following case. (iii) USB bus reset, USB suspended: The IITV bits are not initialized. Setting 1 to the UACT bit starts counting from the value before entering the USB bus reset state or USB suspended state. ### (b) Operation when Transmission/Reception is Impossible at Token Issuance Timing This module cannot issue tokens even at token issuance timing in the following cases. In such a case, this module attempts transactions at the subsequent interval. - (i) When the PID is set to NAK or STALL. - (ii) When the buffer memory is full at the token sending timing in the receiving (IN) direction. - (iii) When there is no data to be sent in the buffer memory at the token sending timing in the sending (OUT) direction. #### 17.4.8 Isochronous Transfers (PIPE1 and PIPE2) - 1. This module has the following functions pertaining to isochronous transfers. - 2. Notification of isochronous transfer error information - 3. Interval counter (specified by the IITV bit) - 4. Isochronous IN transfer data setup control (IDLY function) - 5. Isochronous IN transfer buffer flush function (specified by the IFIS bit) This module does not support the High Bandwidth transfers of isochronous transfers. ### (1) Error Detection with Isochronous Transfers This module has a function for detecting the error information noted below, so that when errors occur in isochronous transfers, software can control them. Tables 17.28 and 17.29 show the priority in which errors are confirmed and the interrupts that are generated. - (i) PID errors - If the PID of the packet being received is illegal - (ii) CRC errors and bit stuffing errors - If an error occurs in the CRC of the packet being received, or the bit stuffing is illegal - (iii) Maximum packet size exceeded - The maximum packet size exceeded the set value. #### (iv) Overrun and underrun errors - When host controller function is selected: - When using isochronous IN transfers (reception), the IN token was received but the buffer memory is not empty. - When using isochronous OUT transfers (transmission), the OUT token was transmitted, but the data was not in the buffer memory. - When function controller function is selected: - When using isochronous IN transfers (transmission), the IN token was received but the data was not in the buffer memory. - When using isochronous OUT transfers (reception), the OUT token was received, but the buffer memory was not empty. #### (v) Interval errors - During an isochronous IN transfer, the token could not be received during the interval frame. - During an isochronous OUT transfer, the OUT token was received during frames other than the interval frame. Table 17.28 Error Detection when a Token is Received | Detection<br>Priority | Error | Generated Interrupt and Status | |-----------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | PID errors | No interrupts are generated in both cases when<br>the host controller function is selected and the<br>function controller function is selected (ignored<br>as a corrupted packet). | | 2 | CRC error and bit stuffing errors | No interrupts generated in both cases when the host controller function is selected and the function controller function is selected (ignored as a corrupted packet). | | 3 | Overrun and underrun errors | An NRDY interrupt is generated to set the OVRN bit in both cases when host controller function is selected and function controller function is selected. | | | | When the host controller function is selected, no tokens are transmitted. | | | | When the function controller function is selected, a zero-length packet is transmitted in response to IN token. However, no data packets are received in response to OUT token. | | 4 | Interval errors | An NRDY interrupt is generated when the function controller function is selected. It is not generated when the host controller function is selected. | Table 17.29 Error Detection when a Data Packet is Received | Detection<br>Priority Order | Error | Generated Interrupt and Status | |-----------------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | PID errors | No interrupts are generated (ignored as a corrupted packet) | | 2 | CRC error and bit stuffing errors | An NRDY interrupt is generated to set<br>the CRCE bit in both cases when the<br>host controller function is selected and<br>the function controller function is<br>selected. | | 3 | Maximum packet size exceeded error | A BEMP interrupt is generated to set<br>the PID bits to STALL in both cases<br>when the host controller function is<br>selected and the function controller<br>function is selected. | #### (2) DATA-PID This module does not support High Bandwidth transfers. When the function controller function is selected, this module operates as follows in response to the received PID. #### (a) IN direction - DATA0: Sent as data packet PID - DATA1: Not sent - DATA2: Not sent - mDATA: Not sent #### (b) OUT direction (when using full-speed operation) - DATA0: Received normally as data packet PID - DATA1: Received normally as data packet PID - DATA2: Packets are ignored - mDATA: Packets are ignored #### (c) OUT direction (when using high-speed operation) - DATA0: Received normally as data packet PID - DATA1: Received normally as data packet PID - DATA2: Received normally as data packet PID - mDATA: Received normally as data packet PID #### (3) Interval Counter The isochronous interval can be set using the IITV bits in PIPEPERI. The interval counter enables the functions shown in table 17.30 when the function controller function is selected. When the host controller function is selected, this module generates the token issuance timing. When the host controller function is selected, the interval counter operation is the same as the interrupt transfer operation. Table 17.30 Functions of the Interval Counter when the Function Controller Function is Selected | Transfer<br>Direction | Function | Conditions for Detection | |-----------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------| | IN | IN buffer flush function | When an IN token cannot be normally received in the interval frame during an isochronous IN transfer | | OUT | Notifies that a token not being received | When an OUT token cannot be normally received in the interval frame during an isochronous OUT transfer | The interval count is carried out when an SOF is received or for interpolated SOFs, so the isochronism can be maintained even if an SOF is damaged. The frame interval that can be set is the $2^{IITV}$ frame or $2^{IITV}$ $\mu$ frames. #### (a) Counter Initialization when the Function Controller Function is Selected This module initializes the interval counter under the following conditions. (i) Power-on reset The IITV bit is initialized. (ii) Buffer memory initialization using the ACLRM bit The IITV bits are not initialized but the count value is. Setting the ACLRM bit to 0 starts counting from the value set in the IITV bits. After the interval counter has been initialized, the counter is started under the following conditions 1 or 2 when a packet has been transferred normally. - 1. An SOF is received following transmission of data in response to an IN token, in the PID = BUF state. - 2. An SOF is received after data following an OUT token is received in the PID = BUF state. The interval counter is not initialized under the conditions noted below. - 1. When the PID bit is set to NAK or STALL - The interval timer does not stop. This module attempts the transactions at the subsequent interval. - The USB bus reset or the USB is suspended The IITV bit is not initialized. When the SOF has been received, the counter is restarted from the value prior to the reception of the SOF. ### (b) Interval Counting and Transfer Control when the Host Controller Function is Selected This module controls the interval between token issuance operations based on the IITV bit settings. Specifically, this module issues a token for a selected pipe once every 2IITV (µ) frames. This module counts the interval every 1-ms frame for the pipes used for communications with the full-speed or low-speed peripheral devices connected to a high-speed HUB. This module starts counting the token issuance interval at the $(\mu)$ frame following the $(\mu)$ frame in which software has set the PID bits to BUF. Figure 17.12 Token Issuance when IITV = 0 Figure 17.13 Token Issuance when IITV = 1 When the selected pipe is for isochronous transfers, this module carries out the operation below in addition to controlling token issuance interval. This module issues a token even when the NRDY interrupt generation condition is satisfied. #### (i) When the selected pipe is for isochronous IN transfers This module generates the NRDY interrupt when this module issues the IN token but does not receive a packet successfully from a peripheral device (no response or packet error). This module sets the OVRN bit to 1 generating the NRDY interrupt when the time to issue an IN token comes in a state in which this module cannot receive data because the FIFO buffer is full (due to the fact that software (DMAC) is too slow to read data from the FIFO buffer), #### When the selected pipe is for isochronous OUT transfers (ii) This module sets the OVRN bit to 1 generating the NRDY interrupt and transmitting a zero-length packet when the time to issue an OUT token comes in a state in which there is no data to be transmitted in the FIFO buffer (because software (DMAC) is too slow to write data to the FIFO buffer). The token issuance interval is reset on any of the following conditions. - When a hardware-reset is applied to this module (here, the IITV bits are also cleared to 0). - When software sets the ACLRM bit to 1. ## (c) Interval Counting and Transfer Control when the Function Controller Function is Selected (i) When the selected pipe is for isochronous OUT transfers This module generates the NRDY interrupt when this module fails to receive a data packet within the interval set by the IITV bits in terms of $(\mu)$ frames. This module generates the NRDY interrupt when this module fails to receive a data packet because of a CRC error or other errors contained in the packet, or because of the FIFO buffer being full. This module generates the NRDY interrupt on receiving an SOF packet. Even if the SOF packet is corrupted, the internal interpolation is used and allows the interrupt to be generated at the timing to receive the SOF packet. However, when the IITV bits are set to the value other than 0, this module generates the NRDY interrupt on receiving an SOF packet for every interval after starting interval counting operation. When the PID bits are set to NAK by software after starting the interval timer, this module does not generate the NRDY interrupt on receiving an SOF packet. The interval counting starts at the different timing depending on the IITV bit setting as follows. — When IITV = 0: The interval counting starts at the $(\mu)$ frame following the $(\mu)$ frame in which software has set the PID bits for the selected pipe to BUF. Figure 17.14 Relationship between ( $\mu$ ) Frames and Expected Token Reception when IITV = 0 — When IITV ≠ 0: The interval counting starts on completion of successful reception of the first data packet after the PID bits for the selected pipe have been modified to BUF. Figure 17.15 Relationship between (µ) Frames and Expected Token Reception when $IITV \neq 0$ (ii) When the selected pipe is for isochronous IN transfers The IFIS bit should be 1 for this use. When IFIS = 0, this module transmits a data packet in response to the received IN token irrespective of the IITV bit setting. When IFIS = 1, this module clears the FIFO buffer when this module fails to receive an IN token within the interval set by the IITV bits in terms of $(\mu)$ frames in a state in which there is data to be transmitted in the FIFO buffer This module also clears the FIFO buffer when this module fails to receive an IN token successfully because of a bus error such as a CRC error contained in the token. This module clears the FIFO buffer on receiving an SOF packet. Even if the SOF packet is corrupted, the internal interpolation is used and allows the FIFO buffer to be cleared at the timing to receive the SOF packet. The interval counting starts at the different timing depending on the IITV bit setting (similar to the timing during OUT transfers). The interval is counted on any of the following conditions in function controller mode. - When a hardware-reset is applied to this module (here, the IITV bits are also cleared to 0). - When software sets the ACLRM bit to 1. - When this module detects a USB reset. # (4) Setup of Data to be Transmitted using Isochronous Transfer when the Function Controller Function is Selected With isochronous data transmission using this module in function controller function, after data has been written to the buffer memory, a data packet can be sent with the next frame in which an SOF packet is detected. This function is called the isochronous transfer transmission data setup function, and it makes it possible to designate the frame from which transmission began. If a double buffer is used for the buffer memory, transmission will be enabled for only one of the two buffers even after the writing of data to both buffers has been completed, that buffer memory being the one to which the data writing was completed first. For this reason, even if multiple IN tokens are received, the only buffer memory that can be sent is one packet's worth of data. When an IN token is received, if the buffer memory is in the transmission enabled state, this module transmits the data. If the buffer memory is not in the transmission enabled state, however, a zero-length packet is sent and an underrun error occurs. Figure 17.16 shows an example of transmission using the isochronous transfer transmission data setup function with this module, when IITV = 0 (every frame) has been set. Sending of a zero-length packet is displayed in the figure as Null, in a shaded box. Figure 17.16 Example of Data Setup Function Operation # (5) Isochronous Transfer Transmission Buffer Flush when the Function Controller Function is Selected If an SOF packet or a µSOF packet is received without receiving an IN token in the interval frame during isochronous data transmission, this module operates as if an IN token had been corrupted, and clears the buffer for which transmission is enabled, putting that buffer in the writing enabled state. If a double buffer is being used and writing to both buffers has been completed, the buffer memory that was cleared is seen as the data having been sent at the same interval frame, and transmission is enabled for the buffer memory that is not discarded with SOF or $\mu$ SOF packets reception. The timing at which the operation of the buffer flush function varies depending on the value set for the IITV bit. #### (a) If IITV = 0 The buffer flush operation starts from the next frame after the pipe becomes valid. #### (b) In any cases other than IITV = 0 The buffer flush operation is carried out subsequent to the first normal transaction. Figure 17.17 shows an example of the buffer flush function of this module. When an unanticipated token is received prior to the interval frame, this module sends the written data or a zero-length packet according to the buffer state. Figure 17.17 Example of Buffer Flush Function Operation Figure 17.18 shows an example of this module generating an interval error. There are five types of interval errors, as shown below. The interval error is generated at the timing indicated by (1) in the figure, and the IN buffer flush function is activated. If an interval error occurs during an IN transfers, the buffer flush function is activated; and if it occurs during an OUT transfer, an NRDY interrupt is generated. The OVRN bit should be used to distinguish between NRDY interrupts such as received packet errors and overrun errors. In response to tokens that are shaded in the figure, responses occur based on the buffer memory status. #### IN direction: - If the buffer is in the transmission enabled state, the data is transferred as a normal response. - If the buffer is in the transmission disabled state, a zero-length packet is sent and an underrun error occurs. #### 2. OUT direction: - If the buffer is in the reception enabled state, the data is received as a normal response. - If the buffer is in the reception disabled state, the data is discarded and an overrun error occurs. Figure 17.18 Example of an Interval Error Being Generated when IITV = 1 #### 17.4.9 **SOF Interpolation Function** When the function controller function is selected and if data could not be received at intervals of 1 ms (when using full-speed operation) or 125 µs (when using high-speed operation) because an SOF packet was corrupted or missing, this module interpolates the SOF. The SOF interpolation operation begins when the USBE and SCKE bits in SYSCFG have been set to 1 and an SOF packet is received. The interpolation function is initialized under the following conditions. - Power-on reset - USB bus reset - Suspended state detected Also, the SOF interpolation operates under the following specifications. - 125 µs/1 ms conforms to the results of the reset handshake protocol. - The interpolation function is not activated until an SOF packet is received. - After the first SOF packet is received, either 125 µs or 1 ms is counted with an internal clock of 48 MHz, and interpolation is carried out. - After the second and subsequent SOF packets are received, interpolation is carried out at the previous reception interval. - Interpolation is not carried out in the suspended state or while a USB bus reset is being received. (With suspended transitions in high-speed operation, interpolation continues for 3 ms after the last packet is received.) This module supports the following functions based on the SOF detection. These functions also operate normally with SOF interpolation, if the SOF packet was corrupted. - Refreshing of the frame number and the micro-frame number - SOFR interrupt timing and µSOF lock - Isochronous transfer interval count If an SOF packet is missing when full-speed operation is being used, the FRNM bit in FRMNUM0 is not refreshed. If a μSOF packet is missing during high-speed operation, the UFRNM bit in FRMNUM1 is refreshed. However, if a $\mu$ SOF packet for which the $\mu$ FRNM = 000 is missing, the FRNM bit is not refreshed. In this case, the FRNM bit is not refreshed even if successive $\mu$ SOF packets other than $\mu$ FRNM = 000 are received normally. #### 17.4.10 Pipe Schedule #### (1) Conditions for Generating a Transaction When the host controller function is selected and UACT has been set to 1, this module generates a transaction under the conditions noted in table 17.31. Table 17.31 Conditions for Generating a Transaction | | Conditions for Generation | | | | | |----------------------------------------------------------|---------------------------|-----|---------|---------------------|----------------| | Transaction | DIR | PID | IITV0 | Buffer State | SUREQ | | Setup | * <sup>1</sup> | *¹ | *¹ | * <sup>1</sup> | 1 setting | | Control transfer data stage, status stage, bulk transfer | IN | BUF | Invalid | Receive area exists | * <sup>1</sup> | | | OUT | BUF | Invalid | Send data exists | *¹ | | Interrupt transfer | IN | BUF | Valid | Receive area exists | *¹ | | | OUT | BUF | Valid | Send data exists | * <sup>1</sup> | | Isochronous transfer | IN | BUF | Valid | *2 | * <sup>1</sup> | | | OUT | BUF | Valid | *3 | * <sup>1</sup> | Notes: 1. Symbols (—) in the table indicate that the condition is one that is unrelated to the generating of tokens. "Valid" indicates that, for interrupt transfers and isochronous transfers, the condition is generated only in transfer frames that are based on the interval counter. "Invalid" indicates that the condition is generated regardless of the interval counter. - 2. This indicates that a transaction is generated regardless of whether or not there is a receive area. If there was no receive area, however, the received data is destroyed. - 3. This indicates that a transaction is generated regardless of whether or not there is any data to be sent. If there was no data to be sent, however, a zero-length packet is sent. #### (2) Transfer Schedule This section describes the transfer scheduling within a frame of this module. After the module sends an SOF, the transfer is carried out in the sequence described below. #### (a) Execution of periodic transfers A pipe is searched in the order of Pipe $1 \to \text{Pipe } 2 \to \text{Pipe } 6 \to \text{Pipe } 7 \to \text{Pipe } 8 \to \text{Pipe } 9$ , and then, if the pipe is one for which an isochronous or interrupt transfer transaction can be generated, the transaction is generated. #### (b) Setup transactions for control transfers The DCP is checked, and if a setup transaction is possible, it is sent. #### (c) Execution of bulk and control transfer data stages and status stages A pipe is searched in the order of DCP $\rightarrow$ Pipe 1 $\rightarrow$ Pipe 2 $\rightarrow$ Pipe 3 $\rightarrow$ Pipe 4 $\rightarrow$ Pipe 5, and then, if the pipe is one for which a bulk or control transfer data stage or a control transfer status stage transaction can be generated, the transaction is generated. If a transfer is generated, processing moves to the next pipe transaction regardless of whether the response from the peripheral device is ACK or NAK. Also, if there is time for the transfer to be done within the frame, step 3 is repeated. ## (3) USB Communication Enabled Setting the UACT bit of the DVSTCTR register to 1 initiates sending of an SOF or $\mu$ SOF, and makes it possible to generate a transaction. Setting the UACT bit to 0 stops the sending of the SOF or $\mu$ SOF and initiates a suspend state. If the setting of the UACT bit is changed from 1 to 0, processing stops after the next SOF or $\mu$ SOF is sent. ## 17.5 Usage Notes Page 832 of 1278 #### 17.5.1 Power Supplies for the USB Module The power supply for the USB module must be turned on and off simultaneously with the other power supplies. An example of the USB peripheral circuit that is used as the USB function is shown in figure 17.19. Figure 17.19 Example of USB External Circuit when USB power supply is continuously supplied The example of the USB external circuit when USB module is used as a host is shown in figure 17.20. The circuit to control 5 V power supply by using the port etc. is required though the detection of VBUS connection/disconnection is unnecessary for the USB host. Figure 17.20 Example of USB External Circuit when USB module is used as host #### **(1) Power-on Procedure for USB Module** Turn on the power supplies for the USB module using the following procedure. - 1. Even if the USB function is not used, similar to power supplies for modules other than the USB, first turn on the 3.3-V system power supply and then turn on the 1.2-V system power supply. - 2. Return the USB module to the normal operation state if it is in the module stop state. #### **Power-off Procedure for USB Module (2)** Turn off the power supplies for the USB module using the following procedure. - 1. Before turning off the power supplies for the USB module, disable USB communication by canceling pull-up of the DP pin. - 2. Similar to power supplies for modules other than the USB, first turn off the 1.2-V system power supply and then turn off the 3.3-V system power supply. #### 17.5.2 DTCH Interrupt If the USB is disconnected in the host controller mode, the DTCH interrupt may be delayed for 5msec at the maximum, during which time, the NRDY interrupt may be generated. #### 17.5.3 Pin Treatment when USB is Not Used Even if this USB is not used, power must be supplied to the USB power supply pins (DV33/DG33, DV12/DG12, UV12/UG12, AV33/AG33, and AV12/AG12). The VBUS pin should be tied to ground or left open. The REFRIN, DP, and DM pins should be left open. The USB\_X1 pin should be pulled up and the USB\_X2 pin should be left open. # 17.5.4 Usage Precautions of USB Disconnection Process at the Time of Using the Function Controller Function and Full-Speed Operations #### (1) Phenomenon When the USB detach cable at the time of receiving the host packet in the case of using the function controller function and full-speed operations for the USB module, status of DVSQ and RHST are aborted and the USB module cannot execute USB communication at the time of the USB re-attaching. This phenomenon does not occur in the case of using the host controller function or the function controller function and high-speed operations. ## (2) Occurring Conditions The phenomenon will occur when conditions 1, 2, 3, and 4 are fulfilled at the same time. - 1. USB module uses function controller function (DCFM = 0) - 2. USB module full-speed operation (RHST = 010) - 3. When the USB detach cable at the time of receiving the host packet. - 4. When the USB D+ line pull-up is disabled (DPRPU = 1 -> 0 setting) after 3 ms from 3. [USB bus DETACH]\* Note: \* USB detach is USB bus signal level, not VBINT interrupt. #### (3) **Solution** When CPU detects the USB detach interruption, please process as follows. Note: Replace DPRPU = $1 \rightarrow 0$ process as follows. - 1. DPRPU = 0 - 2. Wait for 1 µs (1000 ns) - 3. DCFM = 1 - 4. Wait for 200 ns - 5. DCFM = 0 ## Section 18 SD Host Interface (SDHI) Renesas Electronics Corporation is only able to provide information contained in this section to parties with which we have concluded a nondisclosure agreement. Please contact one of our sales representatives for details. # Section 19 I<sup>2</sup>C Bus Interface 3 (IIC3) The I<sup>2</sup>C bus interface 3 conforms to and provides a subset of the Philips I<sup>2</sup>C (Inter-IC) bus interface functions. However, the configuration of the registers that control the I<sup>2</sup>C bus differs partly from the Philips register configuration. The I<sup>2</sup>C bus interface 3 has one channel. #### 19.1 Features - Selection of I<sup>2</sup>C format or clocked synchronous serial format - Continuous transmission/reception Since the shift register, transmit data register, and receive data register are independent from each other, the continuous transmission/reception can be performed. #### I<sup>2</sup>C bus format: - Start and stop conditions generated automatically in master mode - Selection of acknowledge output levels when receiving - Automatic loading of acknowledge bit when transmitting - Bit synchronization function - In master mode, the state of SCL is monitored per bit, and the timing is synchronized automatically. If transmission/reception is not yet possible, set the SCL to low until preparations are completed. - Six interrupt sources - Transmit data empty (including slave-address match), transmit end, receive data full (including slave-address match), arbitration lost, NACK detection, and stop condition detection - The direct memory access controller (DMAC) can be activated by a transmit-data-empty request or receive-data-full request to transfer data. - Direct bus drive - Two pins, SCL and SDA pins, function as NMOS open-drain outputs when the bus drive function is selected. ### **Clocked synchronous serial format:** - Four interrupt sources - Transmit-data-empty, transmit-end, receive-data-full, and overrun error - The direct memory access controller (DMAC) can be activated by a transmit-data-empty request or receive-data-full request to transfer data. Figure 19.1 shows a block diagram of the I<sup>2</sup>C bus interface 3. Figure 19.1 Block Diagram of I<sup>2</sup>C Bus Interface 3 ## 19.2 Input/Output Pins Table 19.1 shows the pin configuration of the I<sup>2</sup>C bus interface 3. **Table 19.1 Pin Configuration** | Pin Name | Symbol | I/O | Function | |--------------|--------|-----|--------------------------------------------| | Serial clock | SCL | I/O | I <sup>2</sup> C serial clock input/output | | Serial data | SDA | I/O | I <sup>2</sup> C serial data input/output | Figure 19.2 shows an example of I/O pin connections to external circuits. Figure 19.2 External Circuit Connections of I/O Pins ## 19.3 Register Descriptions The I<sup>2</sup>C bus interface 3 has the following registers. **Table 19.2 Register Configuration** | Channel | Register Name | Abbreviation | R/W | Initial<br>Value | Address | Access<br>Size | |---------|------------------------------------------------|--------------|-----|------------------|------------|----------------| | 0 | I <sup>2</sup> C bus control register 1 | ICCR1_0 | R/W | H'00 | H'FFFEE000 | 8 | | | I <sup>2</sup> C bus control register 2 | ICCR2_0 | R/W | H'7D | H'FFFEE001 | 8 | | | I <sup>2</sup> C bus mode register | ICMR_0 | R/W | H'38 | H'FFFEE002 | 8 | | | I <sup>2</sup> C bus interrupt enable register | ICIER_0 | R/W | H'00 | H'FFFEE003 | 8 | | | I <sup>2</sup> C bus status register | ICSR_0 | R/W | H'00 | H'FFFEE004 | 8 | | | Slave address register | SAR_0 | R/W | H'00 | H'FFFEE005 | 8 | | | I <sup>2</sup> C bus transmit data register | ICDRT_0 | R/W | H'FF | H'FFFEE006 | 8 | | | I <sup>2</sup> C bus receive data register | ICDRR_0 | R/W | H'FF | H'FFFEE007 | 8 | | | NF2CYC register | NF2CYC_0 | R/W | H'00 | H'FFFEE008 | 8 | | | | NF2CYC_0 | R/W | H'00 | H'FFFEE008 | 8 | ### 19.3.1 I<sup>2</sup>C Bus Control Register 1 (ICCR1) ICCR1 is an 8-bit readable/writable register that enables or disables the I<sup>2</sup>C bus interface 3, controls transmission or reception, and selects master or slave mode, transmission or reception, and transfer clock frequency in master mode. | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | ICE | 0 | R/W | I <sup>2</sup> C Bus Interface 3 Enable | | | | | | 0: SCL and SDA output is disabled. (Input to SCL and SDA is enabled.) | | | | | | 1: This bit is enabled for transfer operations. (SCL and SDA pins are bus drive state.) | | 6 | RCVD | 0 | R/W | Reception Disable | | | | | | Enables or disables the next operation when TRS is 0 and ICDRR is read. | | | | | | 0: Enables next reception | | | | | | 1: Disables next reception | | 5 | MST | 0 | R/W | Master/Slave Select | | 4 | TRS | 0 | R/W | Transmit/Receive Select | | | | | | In master mode with the I <sup>2</sup> C bus format, when arbitration is lost, MST and TRS are both reset by hardware, causing a transition to slave receive mode. Modification of the TRS bit should be made between transfer frames. | | | | | | When seven bits after the start condition is issued in slave receive mode match the slave address set to SAR and the 8th bit is set to 1, TRS is automatically set to 1. If an overrun error occurs in master receive mode with the clocked synchronous serial format, MST is cleared and the mode changes to slave receive mode. | | | | | | Operating modes are described below according to MST and TRS combination. When clocked synchronous serial format is selected and MST = 1, clock is output. | | | | | | 00: Slave receive mode | | | | | | 01: Slave transmit mode | | | | | | 10: Master receive mode | | | | | | 11: Master transmit mode | | 3 to 0 | CKS[3:0] | 0000 | R/W | Transfer Clock Select | | | | | | These bits should be set according to the necessary transfer rate (table 19.3) in master mode. | **Table 19.3** Transfer Rate | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | Tra | nsfer Rate ( | (kHz) | | |-------|-------|-------|-------|--------|------------------|------------------|------------------|------------------|------------------| | CKS3 | CKS2 | CKS1 | CKS0 | Clock | Pφ =<br>16.7 MHz | Pφ =<br>20.0 MHz | Pφ =<br>25.0 MHz | Pφ =<br>26.7 MHz | Pφ =<br>33.3 MHz | | 0 | 0 | 0 | 0 | Рф/44 | 379 kHz | 455 kHz | 568 kHz | 606 kHz | 758 kHz | | | | | 1 | Ρφ/52 | 321 kHz | 385 kHz | 481 kHz | 513 kHz | 641 kHz | | | | 1 | 0 | Рф/64 | 260 kHz | 313 kHz | 391 kHz | 417 kHz | 521 kHz | | | | | 1 | Ρφ/72 | 231 kHz | 278 kHz | 347 kHz | 370 kHz | 463 kHz | | | 1 | 0 | 0 | Ρφ/84 | 198 kHz | 238 kHz | 298 kHz | 317 kHz | 397 kHz | | | | | 1 | Ρφ/92 | 181 kHz | 217 kHz | 272 kHz | 290 kHz | 362 kHz | | | | 1 | 0 | Рф/100 | 167 kHz | 200 kHz | 250 kHz | 267 kHz | 333 kHz | | | | | 1 | Pφ/108 | 154 kHz | 185 kHz | 231 kHz | 247 kHz | 309 kHz | | 1 | 0 | 0 | 0 | Pφ/176 | 94.7 kHz | 114 kHz | 142 kHz | 152 kHz | 189 kHz | | | | | 1 | Pφ/208 | 80.1 kHz | 96.2 kHz | 120 kHz | 128 kHz | 160 kHz | | | | 1 | 0 | Pφ/256 | 65.1 kHz | 78.1 kHz | 97.7 kHz | 104 kHz | 130 kHz | | | | | 1 | Pφ/288 | 57.9 kHz | 69.4 kHz | 86.8 kHz | 92.6 kHz | 116 kHz | | | 1 | 0 | 0 | Рф/336 | 49.6 kHz | 59.5 kHz | 74.4 kHz | 79.4 kHz | 99.2 kHz | | | | | 1 | Рф/368 | 45.3 kHz | 54.3 kHz | 67.9 kHz | 72.5 kHz | 90.6 kHz | | | | 1 | 0 | Ρφ/400 | 41.7 kHz | 50.0 kHz | 62.5 kHz | 66.7 kHz | 83.3 kHz | Note: The settings should satisfy external specifications. Pφ/432 38.6 kHz 46.3 kHz 57.9 kHz 61.7 kHz 77.2 kHz 1 ### 19.3.2 I<sup>2</sup>C Bus Control Register 2 (ICCR2) ICCR2 is an 8-bit readable/writable register that issues start/stop conditions, manipulates the SDA pin, monitors the SCL pin, and controls reset in the control part of the I<sup>2</sup>C bus. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|------|-----|------|-------|------|---|--------|---|---| | | BBSY | SCP | SDAO | SDAOP | SCLO | - | IICRST | - | ] | | Initial value: | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | _ | | R/W: | R/W | R/W | R/W | R/W | R | R | R/W | R | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | BBSY | 0 | R/W | Bus Busy | | | | | | Enables to confirm whether the I <sup>2</sup> C bus is occupied or released and to issue start/stop conditions in master mode. With the clocked synchronous serial format, this bit is always read as 0. With the I <sup>2</sup> C bus format, this bit is set to 1 when the SDA level changes from high to low under the condition of SCL = high, assuming that the start condition has been issued. This bit is cleared to 0 when the SDA level changes from low to high under the condition of SCL = high, assuming that the stop condition has been issued. Write 1 to BBSY and 0 to SCP to issue a start condition. Follow this procedure when also re-transmitting a start condition. Write 0 in BBSY and 0 in SCP to issue a stop condition. | | 6 | SCP | 1 | R/W | Start/Stop Issue Condition Disable | | | | | | Controls the issue of start/stop conditions in master mode. To issue a start condition, write 1 in BBSY and 0 in SCP. A retransmit start condition is issued in the same way. To issue a stop condition, write 0 in BBSY and 0 in SCP. This bit is always read as 1. Even if 1 is written to this bit, the data will not be stored. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | SDAO | 1 | R/W | SDA Output Value Control | | | | | | This bit is used with SDAOP when modifying output level of SDA. This bit should not be manipulated during transfer. | | | | | | 0: When reading, SDA pin outputs low. | | | | | | When writing, SDA pin is changed to output low. | | | | | | 1: When reading, SDA pin outputs high. | | | | | | When writing, SDA pin is changed to output Hi-Z (outputs high by external pull-up resistance). | | 4 | SDAOP | 1 | R/W | SDAO Write Protect | | | | | | Controls change of output level of the SDA pin by modifying the SDAO bit. To change the output level, clear SDAO and SDAOP to 0 or set SDAO to 1 and clear SDAOP to 0. This bit is always read as 1. | | 3 | SCLO | 1 | R | SCL Output Level | | | | | | Monitors SCL output level. When SCLO is 1, SCL pin outputs high. When SCLO is 0, SCL pin outputs low. | | 2 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. The write value should always be 1. | | 1 | IICRST | 0 | R/W | IIC Control Part Reset | | | | | | Resets the control part except for I <sup>2</sup> C registers. If this bit is set to 1 when hang-up occurs because of communication failure during I <sup>2</sup> C bus operation, some IIC3 registers and the control part can be reset. | | 0 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. The write value should always be 1. | ### 19.3.3 I<sup>2</sup>C Bus Mode Register (ICMR) ICMR is an 8-bit readable/writable register that selects whether the MSB or LSB is transferred first, performs master mode wait control, and selects the transfer bit count. Bits BC[2:0] are initialized to H'0 by the IICRST bit in ICCR2. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|---|---|---|------|-----|---------|-----| | | MLS | - | - | - | BCWP | | BC[2:0] | | | Initial value: | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | | R/W· | R/W | R | R | R | R/W | R/W | R/W | R/W | | Bit | Bit Name | Initial<br>Value | DAM | Description | |------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | R/W | Description | | 7 | MLS | 0 | R/W | MSB-First/LSB-First Select | | | | | | 0: MSB-first | | | | | | 1: LSB-first | | | | | | Set this bit to 0 when the I <sup>2</sup> C bus format is used. | | 6 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 5, 4 | _ | All 1 | R | Reserved | | | | | | These bits are always read as 1. The write value should always be 1. | | 3 | BCWP | 1 | R/W | BC Write Protect | | | | | | Controls the BC[2:0] modifications. When modifying the BC[2:0] bits, this bit should be cleared to 0. In clocked synchronous serial mode, the BC[2:0] bits should not be modified. | | | | | | 0: When writing, values of the BC[2:0] bits are set. | | | | | | 1: When reading, 1 is always read. | | | | | | When writing, settings of the BC[2:0] bits are invalid. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | |--------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 to 0 | BC[2:0] | 000 | R/W | Bit Counter | | | | | | | next. When read, t is indicated. With t transferred with or be made between to a value other th. while the SCL pin the end of a data t | the number of bits to be transferred the remaining number of transfer bits the I <sup>2</sup> C bus format, the data is ne addition acknowledge bit. Should transfer frames. If these bits are set an B'000, the setting should be made is low. The value returns to B'000 at transfer, including the acknowledge omatically return to B'111 after a stop ed. | | | | | | software standby r<br>These bits are also<br>ICCR2 to 1. With t | ared by a power-on reset and in mode and module standby mode. o cleared by setting the IICRST bit of the clocked synchronous serial should not be modified. | | | | | | I <sup>2</sup> C Bus Format | Clocked Synchronous Serial Format | | | | | | 000: 9 bits | 000: 8 bits | | | | | | 001: 2 bits | 001: 1 bit | | | | | | 010: 3 bits | 010: 2 bits | | | | | | 011: 4 bits | 011: 3 bits | | | | | | 100: 5 bits | 100: 4 bits | | | | | | 101: 6 bits | 101: 5 bits | | | | | | 110: 7 bits | 110: 6 bits | | | | | | 111: 8 bits | 111: 7 bits | ### 19.3.4 I<sup>2</sup>C Bus Interrupt Enable Register (ICIER) ICIER is an 8-bit readable/writable register that enables or disables interrupt sources and acknowledge bits, sets acknowledge bits to be transferred, and confirms acknowledge bits received. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|------|-----|-------|------|------|-------|-------| | | TIE | TEIE | RIE | NAKIE | STIE | ACKE | ACKBR | ACKBT | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R/W | R/W | R | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TIE | 0 | R/W | Transmit Interrupt Enable | | | | | | When the TDRE bit in ICSR is set to 1 or 0, this bit enables or disables the transmit data empty interrupt (TXI). | | | | | | <ol><li>Transmit data empty interrupt request (TXI) is<br/>disabled.</li></ol> | | | | | | <ol> <li>Transmit data empty interrupt request (TXI) is<br/>enabled.</li> </ol> | | 6 | TEIE | 0 | R/W | Transmit End Interrupt Enable | | | | | | Enables or disables the transmit end interrupt (TEI) at<br>the rising of the ninth clock while the TDRE bit in ICSR<br>is 1. TEI can be canceled by clearing the TEND bit or<br>the TEIE bit to 0. | | | | | | 0: Transmit end interrupt request (TEI) is disabled. | | | | | | 1: Transmit end interrupt request (TEI) is enabled. | | 5 | RIE | 0 | R/W | Receive Interrupt Enable | | | | | | Enables or disables the receive data full interrupt request (RXI) and the overrun error interrupt request (ERI) in the clocked synchronous format when receive data is transferred from ICDRS to ICDRR and the RDRF bit in ICSR is set to 1. RXI can be canceled by clearing the RDRF or RIE bit to 0. | | | | | | 0: Receive data full interrupt request (RXI) are disabled. | | | | | | 1: Receive data full interrupt request (RXI) are enabled. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | NAKIE | 0 | R/W | NACK Receive Interrupt Enable | | | | | | Enables or disables the NACK detection interrupt request (NAKI) and the overrun error (OVE set in ICSR) interrupt request (ERI) in the clocked synchronous format when the NACKF or AL/OVE bit in ICSR is set. NAKI can be canceled by clearing the NACKF, AL/OVE, or NAKIE bit to 0. | | | | | | 0: NACK receive interrupt request (NAKI) is disabled. | | | | | | 1: NACK receive interrupt request (NAKI) is enabled. | | 3 | STIE | 0 | R/W | Stop Condition Detection Interrupt Enable | | | | | | Enables or disables the stop condition detection interrupt request (STPI) when the STOP bit in ICSR is set. | | | | | | <ol><li>Stop condition detection interrupt request (STPI) is<br/>disabled.</li></ol> | | | | | | 1: Stop condition detection interrupt request (STPI) is enabled. | | 2 | ACKE | 0 | R/W | Acknowledge Bit Judgment Select | | | | | | <ol><li>The value of the receive acknowledge bit is ignored,<br/>and continuous transfer is performed.</li></ol> | | | | | | <ol> <li>If the receive acknowledge bit is 1, continuous<br/>transfer is halted.</li> </ol> | | 1 | ACKBR | 0 | R | Receive Acknowledge | | | | | | In transmit mode, this bit stores the acknowledge data that are returned by the receive device. This bit cannot be modified. This bit can be canceled by setting the BBSY bit in ICCR2 to 1. | | | | | | 0: Receive acknowledge = 0 | | | | | | 1: Receive acknowledge = 1 | | 0 | ACKBT | 0 | R/W | Transmit Acknowledge | | | | | | In receive mode, this bit specifies the bit to be sent at the acknowledge timing. | | | | | | 0: 0 is sent at the acknowledge timing. | | | | | | 1: 1 is sent at the acknowledge timing. | ## 19.3.5 I<sup>2</sup>C Bus Status Register (ICSR) ICSR is an 8-bit readable/writable register that confirms interrupt request flags and their status. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|------|------|-------|------|--------|-----|-----| | | TDRE | TEND | RDRF | NACKF | STOP | AL/OVE | AAS | ADZ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------| | 7 | TDRE | 0 | R/W | Transmit Data Register Empty | | | | | | [Clearing conditions] | | | | | | • When 0 is written in TDRE after reading TDRE = 1 | | | | | | When data is written to ICDRT | | | | | | [Setting conditions] | | | | | | <ul> <li>When data is transferred from ICDRT to ICDRS and<br/>ICDRT becomes empty</li> </ul> | | | | | | When TRS is set | | | | | | <ul> <li>When the start condition (including retransmission) is issued</li> </ul> | | | | | | When slave mode is changed from receive mode to transmit mode | | 6 | TEND | 0 | R/W | Transmit End | | | | | | [Clearing conditions] | | | | | | • When 0 is written in TEND after reading TEND = 1 | | | | | | When data is written to ICDRT | | | | | | [Setting conditions] | | | | | | <ul> <li>When the ninth clock of SCL rises with the I<sup>2</sup>C bus<br/>format while the TDRE flag is 1</li> </ul> | | | | | | When the final bit of transmit frame is sent with the clocked synchronous serial format | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------| | | | | | Description | | 5 | RDRF | 0 | R/W | Receive Data Full | | | | | | [Clearing conditions] | | | | | | <ul> <li>When 0 is written in RDRF after reading RDRF = 1</li> </ul> | | | | | | When ICDRR is read | | | | | | [Setting condition] | | | | | | <ul> <li>When a receive data is transferred from ICDRS to ICDRR</li> </ul> | | 4 | NACKF | 0 | R/W | No Acknowledge Detection Flag | | | | | | [Clearing condition] | | | | | | <ul> <li>When 0 is written in NACKF after reading NACKF</li> <li>= 1</li> </ul> | | | | | | [Setting condition] | | | | | | <ul> <li>When no acknowledge is detected from the receive<br/>device in transmission while the ACKE bit in ICIER<br/>is 1</li> </ul> | | 3 | STOP | 0 | R/W | Stop Condition Detection Flag | | | | | | [Clearing condition] | | | | | | • When 0 is written in STOP after reading STOP = 1 | | | | | | [Setting conditions] | | | | | | When a stop condition is detected after frame transfer is completed | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | AL/OVE | 0 | R/W | Arbitration Lost Flag/Overrun Error Flag | | | | | | Indicates that arbitration was lost in master mode with the $l^2C$ bus format and that the final bit has been received while RDRF = 1 with the clocked synchronous format. | | | | | | When two or more master devices attempt to seize the bus at nearly the same time, if the I <sup>2</sup> C bus interface 3 detects data differing from the data it sent, it sets AL to 1 to indicate that the bus has been occupied by another master. | | | | | | [Clearing condition] | | | | | | <ul> <li>When 0 is written in AL/OVE after reading AL/OVE</li> <li>= 1</li> </ul> | | | | | | [Setting conditions] | | | | | | <ul> <li>If the internal SDA and SDA pin disagree at the rise<br/>of SCL in master transmit mode</li> </ul> | | | | | | <ul> <li>When the SDA pin outputs high in master mode<br/>while a start condition is detected</li> </ul> | | | | | | <ul> <li>When the final bit is received with the clocked<br/>synchronous format while RDRF = 1</li> </ul> | | 1 | AAS | 0 | R/W | Slave Address Recognition Flag | | | | | | In slave receive mode, this flag is set to 1 if the first frame following a start condition matches bits SVA[6:0] in SAR. | | | | | | [Clearing condition] | | | | | | <ul> <li>When 0 is written in AAS after reading AAS = 1</li> </ul> | | | | | | [Setting conditions] | | | | | | When the slave address is detected in slave receive mode | | | | | | <ul> <li>When the general call address is detected in slave<br/>receive mode.</li> </ul> | | 0 | ADZ | 0 | R/W | General Call Address Recognition Flag | | | | | | This bit is valid in slave receive mode with the I <sup>2</sup> C bus format. | | | | | | [Clearing condition] | | | | | | <ul> <li>When 0 is written in ADZ after reading ADZ = 1</li> </ul> | | | | | | [Setting condition] | | | | | | <ul> <li>When the general call address is detected in slave receive mode</li> </ul> | #### 19.3.6 Slave Address Register (SAR) SAR is an 8-bit readable/writable register that selects the communications format and sets the slave address. In slave mode with the I<sup>2</sup>C bus format, if the upper seven bits of SAR match the upper seven bits of the first frame received after a start condition, this module operates as the slave device. | | | Initial | | | |--------|----------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 7 to 1 | SVA[6:0] | 0000000 | R/W | Slave Address | | | | | | These bits set a unique address in these bits, differing form the addresses of other slave devices connected to the I <sup>2</sup> C bus. | | 0 | FS | 0 | R/W | Format Select | | | | | | 0: I <sup>2</sup> C bus format is selected | | | | | | 1: Clocked synchronous serial format is selected | ### 19.3.7 I<sup>2</sup>C Bus Transmit Data Register (ICDRT) ICDRT is an 8-bit readable/writable register that stores the transmit data. When ICDRT detects the space in the shift register (ICDRS), it transfers the transmit data which is written in ICDRT to ICDRS and starts transferring data. If the next transfer data is written to ICDRT while transferring data of ICDRS, continuous transfer is possible. ### 19.3.8 I<sup>2</sup>C Bus Receive Data Register (ICDRR) ICDRR is an 8-bit register that stores the receive data. When data of one byte is received, ICDRR transfers the receive data from ICDRS to ICDRR and the next data can be received. ICDRR is a receive-only register, therefore the CPU cannot write to this register. ### 19.3.9 I<sup>2</sup>C Bus Shift Register (ICDRS) ICDRS is a register that is used to transfer/receive data. In transmission, data is transferred from ICDRT to ICDRS and the data is sent from the SDA pin. In reception, data is transferred from ICDRS to ICDRR after data of one byte is received. This register cannot be read directly from the CPU. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|---|---|---|---|---|---|---|---|---| | | | | | | | | | | ] | | Initial value: | - | - | - | - | - | - | - | - | _ | | R/W: | - | - | - | - | - | - | - | - | | ### 19.3.10 NF2CYC Register (NF2CYC) NF2CYC is an 8-bit readable/writable register that selects the range of the noise filtering for the SCL and SDA pins. For details of the noise filter, see section 19.4.7, Noise Filter. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|---|---|---|---|---|---|-----|------------|---| | | - | - | - | - | - | - | PRS | NF2<br>CYC | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | • | | R/W: | R | R | R | R | R | R | R/W | R/W | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |--------|----------|------------------|-----|------------------------------------------------------------------------------------------| | 7 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | PRS | 0 | R/W | Pulse Width Ratio Select | | | | | | Specifies the ratio of the high-level period to the low-level period for the SCL signal. | | | | | | 0: The ratio of high to low is 0.5 to 0.5. | | | | | | 1: The ratio of high to low is about 0.4 to 0.6. | | 0 | NF2CYC | 0 | R/W | Noise Filtering Range Select | | | | | | 0: The noise less than one cycle of the peripheral clock can be filtered out | | | | | | 1: The noise less than two cycles of the peripheral clock can be filtered out | ### 19.4 Operation The I<sup>2</sup>C bus interface 3 can communicate either in I<sup>2</sup>C bus mode or clocked synchronous serial mode by setting FS in SAR. #### 19.4.1 I<sup>2</sup>C Bus Format Figure 19.3 shows the I<sup>2</sup>C bus formats. Figure 19.4 shows the I<sup>2</sup>C bus timing. The first frame following a start condition always consists of eight bits. Figure 19.3 I<sup>2</sup>C Bus Formats Figure 19.4 I<sup>2</sup>C Bus Timing ### [Legend] S: Start condition. The master device drives SDA from high to low while SCL is high. SLA: Slave address R/W: Indicates the direction of data transfer: from the slave device to the master device when R/W is 1, or from the master device to the slave device when R/W is 0. A: Acknowledge. The receive device drives SDA to low. DATA: Transfer data P: Stop condition. The master device drives SDA from low to high while SCL is high. ### 19.4.2 Master Transmit Operation In master transmit mode, the master device outputs the transmit clock and transmit data, and the slave device returns an acknowledge signal. For master transmit mode operation timing, refer to figures 19.5 and 19.6. The transmission procedure and operations in master transmit mode are described below. - 1. Set the ICE bit in ICCR1 to 1. Also, set bits CKS[3:0] in ICCR1. (Initial setting) - 2. Read the BBSY flag in ICCR2 to confirm that the bus is released. Set the MST and TRS bits in ICCR1 to select master transmit mode. Then, write 1 to BBSY and 0 to SCP. (Start condition issued) This generates the start condition. - 3. After confirming that TDRE in ICSR has been set, write the transmit data (the first byte data show the slave address and R/W) to ICDRT. At this time, TDRE is automatically cleared to 0, and data is transferred from ICDRT to ICDRS. TDRE is set again. - 4. When transmission of one byte data is completed while TDRE is 1, TEND in ICSR is set to 1 at the rise of the 9th transmit clock pulse. Read the ACKBR bit in ICIER, and confirm that the slave device has been selected. Then, write second byte data to ICDRT. When ACKBR is 1, the slave device has not been acknowledged, so issue the stop condition. To issue the stop condition, write 0 to BBSY and SCP. SCL is fixed low until the transmit data is prepared or the stop condition is issued. - 5. The transmit data after the second byte is written to ICDRT every time TDRE is set. - 6. Write the number of bytes to be transmitted to ICDRT. Wait until TEND is set (the end of last byte data transmission) while TDRE is 1, or wait for NACK (NACKF in ICSR = 1) from the receive device while ACKE in ICIER is 1. Then, issue the stop condition to clear TEND or NACKF. - 7. When the STOP bit in ICSR is set to 1, the operation returns to the slave receive mode. Figure 19.5 Master Transmit Mode Operation Timing (1) Figure 19.6 Master Transmit Mode Operation Timing (2) ### 19.4.3 Master Receive Operation In master receive mode, the master device outputs the receive clock, receives data from the slave device, and returns an acknowledge signal. For master receive mode operation timing, refer to figures 19.7 and 19.8. The reception procedure and operations in master receive mode are shown below. - 1. Clear the TEND bit in ICSR to 0, then clear the TRS bit in ICCR1 to 0 to switch from master transmit mode to master receive mode. Then, clear the TDRE bit to 0. - 2. When ICDRR is read (dummy data read), reception is started, and the receive clock is output, and data received, in synchronization with the internal clock. The master device outputs the level specified by ACKBT in ICIER to SDA, at the 9th receive clock pulse. - 3. After the reception of first frame data is completed, the RDRF bit in ICSR is set to 1 at the rise of 9th receive clock pulse. At this time, the receive data is read by reading ICDRR, and RDRF is cleared to 0. - 4. The continuous reception is performed by reading ICDRR every time RDRF is set. If 8th receive clock pulse falls after reading ICDRR by the other processing while RDRF is 1, SCL is fixed low until ICDRR is read. - 5. If next frame is the last receive data, set the RCVD bit in ICCR1 to 1 before reading ICDRR. This enables the issuance of the stop condition after the next reception. - 6. When the RDRF bit is set to 1 at rise of the 9th receive clock pulse, issue the stage condition. - 7. When the STOP bit in ICSR is set to 1, read ICDRR. Then clear the RCVD bit to 0. - 8. The operation returns to the slave receive mode. Note: If only one byte is received, read ICDRR (dummy-read) after the RCVD bit in ICCR1 is set. Figure 19.7 Master Receive Mode Operation Timing (1) Figure 19.8 Master Receive Mode Operation Timing (2) #### 19.4.4 Slave Transmit Operation In slave transmit mode, the slave device outputs the transmit data, while the master device outputs the receive clock and returns an acknowledge signal. For slave transmit mode operation timing, refer to figures 19.9 and 19.10. The transmission procedure and operations in slave transmit mode are described below. - 1. Set the ICE bit in ICCR1 to 1. Set bits CKS[3:0] in ICCR1. (Initial setting) Set the MST and TRS bits in ICCR1 to select slave receive mode, and wait until the slave address matches. - 2. When the slave address matches in the first frame following detection of the start condition, the slave device outputs the level specified by ACKBT in ICIER to SDA, at the rise of the 9th clock pulse. At this time, if the 8th bit data (R/W) is 1, the TRS bit in ICCR1 and the TDRE bit in ICSR are set to 1, and the mode changes to slave transmit mode automatically. The continuous transmission is performed by writing transmit data to ICDRT every time TDRE is set. - 3. If TDRE is set after writing last transmit data to ICDRT, wait until TEND in ICSR is set to 1, with TDRE = 1. When TEND is set, clear TEND. - 4. Clear TRS for the end processing, and read ICDRR (dummy read). SCL is opened. - Clear TDRE. Figure 19.9 Slave Transmit Mode Operation Timing (1) Figure 19.10 Slave Transmit Mode Operation Timing (2) Page 865 of 1278 #### 19.4.5 Slave Receive Operation In slave receive mode, the master device outputs the transmit clock and transmit data, and the slave device returns an acknowledge signal. For slave receive mode operation timing, refer to figures 19.11 and 19.12. The reception procedure and operations in slave receive mode are described below. - 1. Set the ICE bit in ICCR1 to 1. Set bits CKS[3:0] in ICCR1. (Initial setting) Set the MST and TRS bits in ICCR1 to select slave receive mode, and wait until the slave address matches. - 2. When the slave address matches in the first frame following detection of the start condition, the slave device outputs the level specified by ACKBT in ICIER to SDA, at the rise of the 9th clock pulse. At the same time, RDRF in ICSR is set to read ICDRR (dummy read). (Since the read data show the slave address and R/W, it is not used.) - 3. Read ICDRR every time RDRF is set. If 8th receive clock pulse falls while RDRF is 1, SCL is fixed low until ICDRR is read. The change of the acknowledge before reading ICDRR, to be returned to the master device, is reflected to the next transmit frame. - 4. The last byte data is read by reading ICDRR. Figure 19.11 Slave Receive Mode Operation Timing (1) Figure 19.12 Slave Receive Mode Operation Timing (2) #### 19.4.6 Clocked Synchronous Serial Format This module can be operated with the clocked synchronous serial format, by setting the FS bit in SAR to 1. When the MST bit in ICCR1 is 1, the transfer clock output from SCL is selected. When MST is 0, the external clock input is selected. #### (1) Data Transfer Format Figure 19.13 shows the clocked synchronous serial transfer format. The transfer data is output from the fall to the fall of the SCL clock, and the data at the rising edge of the SCL clock is guaranteed. The MLS bit in ICMR sets the order of data transfer, in either the MSB first or LSB first. The output level of SDA can be changed during the transfer wait, by the SDAO bit in ICCR2. Figure 19.13 Clocked Synchronous Serial Transfer Format #### **Transmit Operation (2)** In transmit mode, transmit data is output from SDA, in synchronization with the fall of the transfer clock. The transfer clock is output when MST in ICCR1 is 1, and is input when MST is 0. For transmit mode operation timing, refer to figure 19.14. The transmission procedure and operations in transmit mode are described below. - 1. Set the ICE bit in ICCR1 to 1. Set the MST and CKS[3:0] bits in ICCR1. (Initial setting) - 2. Set the TRS bit in ICCR1 to select the transmit mode. Then, TDRE in ICSR is set. - 3. Confirm that TDRE has been set. Then, write the transmit data to ICDRT. The data is transferred from ICDRT to ICDRS, and TDRE is set automatically. The continuous transmission is performed by writing data to ICDRT every time TDRE is set. When changing from transmit mode to receive mode, clear TRS while TDRE is 1. Figure 19.14 Transmit Mode Operation Timing #### (3) Receive Operation In receive mode, data is latched at the rise of the transfer clock. The transfer clock is output when MST in ICCR1 is 1, and is input when MST is 0. For receive mode operation timing, refer to figure 19.15. The reception procedure and operations in receive mode are described below. - 1. Set the ICE bit in ICCR1 to 1. Set bits CKS[3:0] in ICCR1. (Initial setting) - 2. When the transfer clock is output, set MST to 1 to start outputting the receive clock. - 3. When the receive operation is completed, data is transferred from ICDRS to ICDRR and RDRF in ICSR is set. When MST = 1, the next byte can be received, so the clock is continually output. The continuous reception is performed by reading ICDRR every time RDRF is set. When the 8th clock is risen while RDRF is 1, the overrun is detected and AL/OVE in ICSR is set. At this time, the previous reception data is retained in ICDRR. - 4. To stop receiving when MST = 1, set RCVD in ICCR1 to 1, then read ICDRR. Then, SCL is fixed high after receiving the next byte data. Notes: Follow the steps below to receive only one byte with MST = 1 specified. See figure 19.16 for the operation timing. - 1. Set the ICE bit in ICCR1 to 1. Set bits CKS[3:0] in ICCR1. (Initial setting) - 2. Set MST = 1 while the RCVD bit in ICCR1 is 0. This causes the receive clock to be output. - 3. Check if the BC2 bit in ICMR is set to 1 and then set the RCVD bit in ICCR1 to 1. This causes the SCL to be fixed to the high level after outputting one byte of the receive clock. Figure 19.15 Receive Mode Operation Timing Figure 19.16 Operation Timing For Receiving One Byte (MST = 1) #### 19.4.7 Noise Filter The logic levels at the SCL and SDA pins are routed through noise filters before being latched internally. Figure 19.17 shows a block diagram of the noise filter circuit. The noise filter consists of three cascaded latches and a match detector. The SCL (or SDA) input signal is sampled on the peripheral clock. When NF2CYC is set to 0, this signal is not passed forward to the next circuit unless the outputs of both latches agree. When NF2CYC is set to 1, this signal is not passed forward to the next circuit unless the outputs of three latches agree. If they do not agree, the previous value is held. Figure 19.17 Block Diagram of Noise Filter ### 19.4.8 Example of Use Flowcharts in respective modes that use the I<sup>2</sup>C bus interface 3 are shown in figures 19.18 to 19.21. Figure 19.18 Sample Flowchart for Master Transmit Mode Figure 19.19 Sample Flowchart for Master Receive Mode Figure 19.20 Sample Flowchart for Slave Transmit Mode Figure 19.21 Sample Flowchart for Slave Receive Mode ## 19.5 Interrupt Requests There are six interrupt requests in this module; transmit data empty, transmit end, receive data full, NACK detection, STOP recognition, and arbitration lost/overrun error. Table 19.4 shows the contents of each interrupt request. **Table 19.4** Interrupt Requests | Interrupt Request | Abbreviation | Interrupt Condition | I <sup>2</sup> C Bus<br>Format | Clocked Synchronous<br>Serial Format | |------------------------------------|--------------|----------------------------|--------------------------------|--------------------------------------| | Transmit data Empty | TXI | (TDRE = 1) • (TIE = 1) | $\sqrt{}$ | $\sqrt{}$ | | Transmit end | TEI | (TEND = 1) • (TEIE = 1) | √ | $\checkmark$ | | Receive data full | RXI | (RDRF = 1) • (RIE = 1) | √ | $\sqrt{}$ | | STOP recognition | STPI | (STOP = 1) • (STIE = 1) | √ | _ | | NACK detection | NAKI | {(NACKF = 1) + (AL = 1)} ● | √ | _ | | Arbitration lost/<br>overrun error | _ | (NAKIE = 1) | √ | 1 | When the interrupt condition described in table 19.4 is 1, the CPU executes an interrupt exception handling. Note that a TXI or RXI interrupt can activate the DMAC if the setting for DMAC activation has been made. In such a case, an interrupt request is not sent to the CPU. Interrupt sources should be cleared in the exception handling. The TDRE and TEND bits are automatically cleared to 0 by writing the transmit data to ICDRT. The RDRF bit is automatically cleared to 0 by reading ICDRR. The TDRE bit is set to 1 again at the same time when the transmit data is written to ICDRT. Therefore, when the TDRE bit is cleared to 0, then an excessive data of one byte may be transmitted. # 19.6 Bit Synchronous Circuit In master mode, this module has a possibility that high level period may be short in the two states described below. - When SCL is driven to low by the slave device - When the rising speed of SCL is lowered by the load of the SCL line (load capacitance or pullup resistance) Therefore, it monitors SCL and communicates by bit with synchronization. Figure 19.22 shows the timing of the bit synchronous circuit and table 19.5 shows the time when the SCL output changes from low to Hi-Z then SCL is monitored. Figure 19.22 Bit Synchronous Circuit Timing **Table 19.5** Time for Monitoring SCL | CKS3 | CKS2 | Time for Monitoring SCL*1 | |------|------|---------------------------| | 0 | 0 | 9 tpcyc* <sup>2</sup> | | | 1 | 21 tpcyc* <sup>2</sup> | | 1 | 0 | 39 tpcyc* <sup>2</sup> | | | 1 | 87 tpcyc* <sup>2</sup> | Notes: 1. Monitors the (on-board) SCL level after the time (pcyc) for monitoring SCL has passed since the rising edge of the SCL monitor timing reference clock. 2. $pcyc = P\phi \times cyc$ ## 19.7 Usage Notes #### 19.7.1 Notes on Working in Multi-master Mode When working in multi-master mode, if the setting for the transfer route of the LSI (CKS3 to CKS0 in ICCR1) is lower than that for any other master, an SCL with an unexpected width may be output occasionally. The transfer rate that is set here must be at least 1/1.8 times the highest transfer rate of the other masters. ### 19.7.2 Notes on Working in Master Receive Mode If the ICDRR is read near the falling edge of the eighth clock, no receive data may be captured. If RCVD = 1 is set near the falling edge of the eighth clock when the receive buffer is full, no stop conditions may be issued. Use either of the following methods. - 1. In master receive mode, reading the ICDRR should be performed before the falling edge of the eighth is detected. - 2. In master receive mode, RCVD = 1 should be set so that processing proceeds on a per-byte basis. ## 19.7.3 Notes on Setting ACKBT in Master Receive Mode When working in master receive mode, the ACKBT should be set before the eighth SCL in the final data being transferred continuously starts falling. Otherwise, the slave's sending device might overrun. #### 19.7.4 Notes on the States of MST and TRN Bits when Arbitration Is Lost If the multi-master is used and the MST and TRS bits are operated sequentially to assign the master send setting, a conflict may occur as seen in the combination of AL = 1 in ICSR and master transmit mode (MST = 1 and TRS = 1), depending on the timing when arbitration is lost while the bit manipulation instruction in the TRS is being executed. The following methods can be used to avoid this phenomenon. - When working in multi-master mode, use the MOV instruction to set the MST and TRS. - If arbitration is lost, confirm the MST = 0 and TRS = 0 settings. If any settings other than MST = 0 and TRS = 0 are found, the MST = 0 and TRS = 0 settings must be performed again. ### 19.7.5 Note Regarding Master Receive Mode of I<sup>2</sup>C-Bus Interface Mode #### (1) Note When stop condition generation or start condition regeneration overlaps with the falling edge of the ninth clock cycle of the SCL signal, an additional cycle is output after the ninth clock cycle. ## (2) Countermeasure After a master receive operation is completed, confirm the falling edge of the ninth clock cycle of the SCL signal and generate a stop condition or regenerate a start condition. Confirm the falling edge of the ninth clock cycle of the SCL signal as follows: Confirm the SCLO bit in the ICCR2 register (SCL monitor flag) becomes 0 (SCL pin is low) after confirming the RDRF bit in the ICSR register (receive data register full flag) becomes 1. #### Accessing ICE and IICRST during I<sup>2</sup>C Bus Operation 19.7.6 #### **(1) Problem** When 0 is written to ICE in ICCR1 or 1 is written to IICRST in ICCR2 during I<sup>2</sup>C bus operation, the values of BBSY in ICCR2 and STOP in ICSR become undefined. #### **(2) Conditions** The above problem occurs when 0 is written to ICE in ICCR1 or 1 is written to IICRST in ICCR2 when any of conditions 1 to 4 below is satisfied. - 1. In master transmit mode (MST = 1 and TRS = 1 in ICCR1), when the IIC3 module holds access rights to the I<sup>2</sup>C bus. - 2. In master receive mode (MST = 1 and TRS = 0 in ICCR1), when the IIC3 module holds access rights to the I<sup>2</sup>C bus. - 3. In slave transmit mode (MST = 0 and TRS = 1 in ICCR1), when the IIC3 module is performing a data transmit operation. - 4. In slave receive mode (MST = 0 and TRS = 0 in ICCR1), when the IIC3 module is transmitting an acknowledge signal. #### **(3)** Workarounds The undefined state of BBSY in ICCR2 can be canceled by using one of the following workarounds. - BBSY is set to 1 when a start condition (SCL is high-level and SDA falling edge) is input. - BBSY is cleared to 0 when an end condition (SCL is high-level and SDA rising edge) is input. - In master transmit mode, write 1 to BBSY and 0 to SCP in ICCR2 while SCL and SDA are both high-level to generate a start condition. BBSY is set to 1 when a start condition (SCL is high-level and SDA falling edge) is output. - In master transmit mode or master receive mode, when SDA is low-level and there is no device other than the IIC2 or IIC3 module to drive SCL low, write 0 to BBSY and SCP in ICCR2 to generate an end condition. BBSY is cleared to 0 when an end condition (SCL is high-level and SDA rising edge) is output. - Writing 1 to FS in SAR causes BBSY to be cleared to 0. ### (4) Supplemental Description of Register Functions Using IICRST for register initialization - Writing 1 to IICRST in ICCR2 causes SDAO and SCLO in ICCR2 to be set to 1. - In master transmit mode or slave transmit mode, writing 1 to IICRST causes TDRE in ICSR to be set to 1. - During a reset interval triggered by setting IICRST to 1, write access to BBSY, SCP, and SDAO in ICCR2 is disabled. - Writing 1 to IICRST does not clear the BBSY bit in ICCR2 to 0. However, depending on the states of pins SCL and SDA, an end condition (SCL is high-level and SDA rising edge) may occur, resulting in BBSY being cleared to 0. In addition, there may be similar effects on other bits as well. - During a reset interval triggered by setting IICRST to 1, data reception and transmission halts. However, the functions that detect start conditions, end conditions, and bus arbitration lost conditions are active. This means that the states of ICCR1, ICCR2, and ICSR may be updated, depending on the signals input to SCL and SDA. # Section 20 Host Interface (HIF) This LSI incorporates a host interface (HIF) for use in high-speed transfer of data between external devices which cannot utilize the system bus. The HIF allows external devices to read from and write to 4 Kbytes (2 Kbytes × 2 banks) of the on-chip RAM exclusively for HIF use (HIFRAM) within this LSI, in 32-bit units. Interrupts issued to this LSI by an external device, interrupts sent from this LSI to the external device, and DMA transfer requests sent from this LSI to the external device are also supported. By using HIFRAM and these interrupt functions, software-based data transfer between external devices and this LSI becomes possible, and connection to external devices not releasing bus mastership is enabled. Using HIFRAM, the HIF also supports HIF boot mode allowing this LSI to be booted. #### 20.1 Features The HIF has the following features. - An external device can read from or write to HIFRAM in 32-bit units via the HIF pins (access in 8-bit or 16-bit units not allowed). The on-chip CPU can read from or write to HIFRAM in 8bit, 16-bit, or 32-bit units, via the internal peripheral bus. The HIFRAM access mode can be specified as bank mode or non-bank mode. - When an external device accesses HIFRAM via the HIF pins, automatic increment of addresses and the endian can be specified with the HIF internal registers. - By writing to specific bits in the HIF internal registers from an external device, or by accessing the end address of HIFRAM from the external device, interrupts (internal interrupts) can be issued to the on-chip CPU. Conversely, by writing to specific bits in the HIF internal registers from the on-chip CPU, interrupts (external interrupts) or DMAC transfer requests can be sent from the on-chip CPU to the external device. - There are seven interrupt source bits each for internal interrupts and external interrupts. Accordingly, software control of 128 different interrupts is possible, enabling high-speed data transfer using interrupts. - In HIF boot mode, this LSI can be booted from HIFRAM by an external device storing the instruction code in HIFRAM. Figure 20.1 shows a block diagram of the HIF. Figure 20.1 Block Diagram of HIF #### **Input/Output Pins** 20.2 Table 20.1 shows the HIF pin configuration. **Table 20.1 Pin Configuration** | Name | Abbreviation | I/O | Description | |--------------------------|------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HIF data pins | HIFD15 to HIFD00 | I/O | Address, data, or command input/output to the HIF | | HIF chip select | HIFCS | Input | Chip select input to the HIF | | HIF register select | HIFRS | Input | Switching between HIF access types | | | | | 0: Normal access (other than below) | | | | | 1: Index register write | | HIF write | HIFWR | Input | Write strobe signal. Low level is input when an external device writes data to the HIF. | | HIF read | HIFRD | Input | Read strobe signal. Low level is input when an external device reads data from the HIF. | | HIF interrupt | HIFINT | Output | Interrupt request to an external device from the HIF | | HIF mode | HIFMD | Input | Selects whether or not this LSI is started up in HIF boot mode. If a power-on reset is canceled when high level is input, this LSI is started up in HIF boot mode. | | HIFDMAC transfer request | HIFDREQ | Output | To an external device, DMAC transfer request with HIFRAM as the destination | | HIF boot ready | HIFRDY | Output | Indicates that the HIF reset is canceled in this LSI and access from an external device to the HIF can be accepted. | | | | | After 20 clock cycles (max.) of the peripheral clock following negate of the reset input pin of this LSI, this pin is asserted. | | HIF pin enable | HIFEBL | Input | All HIF pins other than this pin are asserted by high-level input. | ## 20.3 Parallel Access ## 20.3.1 Operation The HIF can be accessed by combining the HIFCS, HIFRS, HIFWR, and HIFRD pins. Table 20.2 shows the correspondence between combinations of these signals and HIF operations. **Table 20.2 HIF Operations** | HIFCS | HIFRS | HIFWR | HIFRD | Operation | |-------|-------|-------|-------|---------------------------------------------| | 1 | * | * | * | No operation (NOP) | | 0 | 1 | 0 | 1 | Write to index register (HIFIDX[7:0]) | | 0 | 0 | 0 | 1 | Write to register specified by HIFIDX[7:0] | | 0 | 0 | 1 | 0 | Read from register specified by HIFIDX[7:0] | | 0 | * | 1 | 1 | No operation (NOP) | | 0 | * | 0 | 0 | Setting prohibited | [Legend] #### 20.3.2 Connection Method When connecting the HIF to an external device, a method like that shown in figure 20.2 should be used. Figure 20.2 HIF Connection Example <sup>\*:</sup> Don't care # **20.4** Register Descriptions The HIF has the following registers. - HIF index register (HIFIDX) - HIF general status register (HIFGSR) - HIF status/control register (HIFSCR) - HIF memory control register (HIFMCR) - HIF internal interrupt control register (HIFIICR) - HIF external interrupt control register (HIFEICR) - HIF address register (HIFADR) - HIF data register (HIFDATA) - HIF boot control register (HIFBCR) - HIFDREQ trigger register (HIFDTR) - HIF bank interrupt control register (HIFBICR) ## 20.4.1 HIF Index Register (HIFIDX) HIFIDX is a 32-bit register used to specify the register read from or written to by an external device when the HIFRS pin is held low. HIFIDX can be only read by the on-chip CPU. HIFIDX can be only written to by an external device while the HIFRS pin is driven high. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|------|------|------|------|------|------|-------|-------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | | | _ | REG5 | REG4 | REG3 | REG2 | REG1 | REG0 | BYTE1 | BYTE0 | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------| | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | REG5 | 0 | R/W | HIF Internal Register Select | | 6 | REG4 | 0 | R/W | These bits specify which register among HIFGSR, | | 5 | REG3 | 0 | R/W | HIFSCR, HIFMCR, HIFIICR, HIFEICR, HIFADR, HIFDATA, and HIFBCR is accessed by an external | | 4 | REG2 | 0 | R/W | device. | | 3 | REG1 | 0 | R/W | 000000: HIFGSR | | 2 | REG0 | 0 | R/W | 000001: HIFSCR | | | | | | 000010: HIFMCR | | | | | | 000011: HIFIICR | | | | | | 000100: HIFEICR | | | | | | 000101: HIFADR | | | | | | 000110: HIFDATA | | | | | | 001111: HIFBCR | | | | | | Other than above: Setting prohibited | | <b>D</b> | D'I N | Initial | D/14/ | Post total | |----------|----------|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 1 | BYTE1 | 0 | R/W | Internal Register Byte Specification | | 0 | BYTE0 | 0 | R/W | These bits specify in advance the target word location before the external device accesses a register among HIFGSR, HIFSCR, HIFMCR, HIFIICR, HIFEICR, HIFADR, HIFDATA, and HIFBCR. See also section 20.8, Alignment Control. | | | | | | • When HIFSCR.BO = 0 | | | | | | 00: Bits 31 to 16 in register | | | | | | 01: Setting prohibited | | | | | | 10: Bits 15 to 0 in register | | | | | | 11: Setting prohibited | | | | | | • When HIFSCR.BO = 1 | | | | | | 00: Bits 15 to 0 in register | | | | | | 01: Setting prohibited | | | | | | 10: Bits 31 to 16 in register | | | | | | 11: Setting prohibited | | | | | | However, when HIFDATA is selected using bits REG5 to REG0, each time reading or writing of HIFDATA occurs, these bits change according to the following rule. | | | | | | $00 \rightarrow 10 \rightarrow 00 \rightarrow 10$ repeated | ## 20.4.2 HIF General Status Register (HIFGSR) HIFGSR is a 32-bit register, which can be freely used for handshaking between an external device connected to the HIF and the software of this LSI. HIFGSR can be read from and written to by the on-chip CPU. Access to HIFGSR by an external device should be performed with HIFGSR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|-----|-------|---------|-----|-----|-----|-----|-----|-----|-----| | | _ | _ | _ | _ | _ | - | - | - | - | _ | _ | - | - | - | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | STATU | S[15:0] | | | | | | | | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ F | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|--------------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 16 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 to 0 | STATUS[15:0] | All 0 | R/W | General Status | | | | | | This register can be read from and written to by an external device connected to the HIF, and by the on-chip CPU. These bits are initialized only at a power-on reset. | ## 20.4.3 HIF Status/Control Register (HIFSCR) HIFSCR is a 32-bit register used to control the HIFRAM access mode and endian setting. HIFSCR can be read from and written to by the on-chip CPU. Access to HIFSCR by an external device should be performed with HIFSCR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|-----|------|-----|------|----|----|-----|----|----|-------|-----|-----| | | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | | DMD | DPOL | BMD | BSEL | _ | _ | MD1 | _ | _ | WBSWP | EDN | во | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0/1 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | R | R | R | R | R | R/W | R/W | R/W | | | | Initial | | | |----------|----------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 12 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 11 | DMD | 0 | R/W | DREQ Mode | | 10 | DPOL | 0 | R/W | DREQ Polarity | | | | | | Controls the assert mode for the HIFDREQ pin. For details on the negate timing, see section 20.7, External DMAC Interface. | | | | | | 00: For a DMAC transfer request to an external device, low level is generated at the HIFDREQ pin. The default for the HIFDREQ pin is high-level output. | | | | | | 01: For a DMAC transfer request to an external device,<br>high level is generated at the HIFDREQ pin. The<br>default for the HIFDREQ pin is low-level output. | | | | | | <ol> <li>For a DMAC transfer request to an external device,<br/>falling edge is generated at the HIFDREQ pin. The<br/>default for the HIFDREQ pin is high-level output.</li> </ol> | | | | | | 11: For a DMAC transfer request to an external device,<br>rising edge is generated at the HIFDREQ pin. The<br>default for the HIFDREQ pin is low-level output. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9 | BMD | 0 | R/W | HIFRAM Bank Mode | | 8 | BSEL | 0 | R/W | HIFRAM Bank Select | | | | | | Controls the HIFRAM access mode. | | | | | | 00: Both an external device and the on-chip CPU can access bank 0. When access by both of these conflict, even though the access addresses differ, access by the external device is processed before access by the on-chip CPU. Bank 1 cannot be accessed. | | | | | | 01: Both an external device and the on-chip CPU can<br>access bank 1. When access by both of these<br>conflict, even though the access addresses differ,<br>access by the external device is processed before<br>access by the on-chip CPU. Bank 0 cannot be<br>accessed. | | | | | | 10: An external device can access only bank 0 while the on-chip CPU can access only bank 1. | | | | | | 11: An external device can access only bank 1 while the on-chip CPU can access only bank 0. | | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. The write value should always be 1. | | 5 | MD1 | 0/1 | R | HIF Mode 1 | | | | | | Indicates whether this LSI was started up in HIF boot mode or non-HIF boot mode. This bit stores the value of the HIFMD pin sampled at a power-on reset | | | | | | 0: Started up in non-HIF boot mode (booted from the memory connected to area 0) | | | | | | 1: Started up in HIF boot mode (booted from HIFRAM) | | 4, 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | WBSWP | 0 | R/W | Byte Order for Access of HIFDATA | | | | | | Specifies the byte order when an external device accesses HIFDATA. See also section 20.8, Alignment Control. | | | | | | 0: Aligned according to the BO bit. | | | | | | <ol> <li>Swapped in word units from the big endian order<br/>and then swapped in byte units within each word.</li> <li>The setting of the BO bit is ignored.</li> </ol> | | 1 | EDN | 0 | R/W | Endian for HIFRAM Access | | | | | | Specifies the byte order when HIFRAM is accessed by the on-chip CPU. | | | | | | 0: Big endian (MSB first) | | | | | | 1: Little endian (LSB first) | | 0 | ВО | 0 | R/W | Byte Order for Access of All HIF Registers Including HIFDATA | | | | | | Specifies the byte order when an external device accesses all HIF registers including HIFDATA. However, for the HIFDATA alignment, this bit is referred to only when WBSWP = 0 and ignored when WBSWP = 1. See also section 20.8, Alignment Control. | | | | | | 0: Big endian (MSB first) | | | | | | 1: Little endian (LSB first) | | | | | | | # 20.4.4 HIF Memory Control Register (HIFMCR) HIFMCR is a 32-bit register used to control HIFRAM. HIFMCR can be only read by the on-chip CPU. Access to HIFMCR by an external device should be performed with HIFMCR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|------|----|------|----|------|----|----|-------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | ı | _ | _ | _ | LOCK | _ | WT | _ | RD | _ | _ | AI/AD | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W* | R | R/W* | R | R/W* | R | R | R/W* | Note: \* Changing the HIFRAM banks accessible from an external device by setting the BMD and BSEL bits in HIFSCR does not affect the setting of this bit. | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | LOCK | 0 | R/W* | Lock | | | | | | This bit is used to lock the access direction (read or write) for consecutive access of HIFRAM by an external device via HIFDATA. When this bit is set to 1, the values of the RD and WT bits set at the same time are held until this bit is next cleared to 0. When the RD bit and this bit are simultaneously set to 1, consecutive read mode is entered. When the WT bit and this bit are simultaneously set to 1, consecutive write mode is entered. Both the RD and WT bits should not be set to 1 simultaneously. | | 6 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit Name | Initial<br>Value | R/W | Description | |----------|------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WT | 0 | R/W* | Write | | | | | When this bit is set to 1, the HIFDATA value is written to the HIFRAM position corresponding to HIFADR. | | | | | If this bit and the LOCK bit are set to 1 simultaneously, HIFRAM consecutive write mode is entered, and high-speed data transfer becomes possible. This mode is maintained until this bit is next cleared to 0, or until the LOCK bit is cleared to 0. | | | | | If the LOCK bit is not simultaneously set to 1 with this bit, writing to HIFRAM is performed only once. Thereafter, the value of this bit is automatically cleared to 0. | | _ | 0 | R | Reserved | | | | | This bit is always read as 0. The write value should always be 0. | | RD | 0 | R/W* | Read | | | | | When this bit is set to 1, the HIFRAM data corresponding to HIFADR is fetched to HIFDATA. | | | | | If this bit and the LOCK bit are set to 1 simultaneously, HIFRAM consecutive read mode is entered, and high-speed data transfer becomes possible. This mode is maintained until this bit is next cleared to 0, or until the LOCK bit is cleared to 0. | | | | | If the LOCK bit is not simultaneously set to 1 with this bit, reading of HIFRAM is performed only once. Thereafter, the value of this bit is automatically cleared to 0. | | _ | All 0 | R | Reserved | | | | | These bits are always read as 0. The write value should always be 0. | | AI/AD | 0 | R/W* | Address Auto-Increment/Decrement | | | | | This bit is valid only when the LOCK bit is 1. The value of HIFADR is automatically incremented by 4 or decremented by 4 according to the setting of this bit each time reading or writing of HIFRAM is performed. | | | | | 0: Auto-increment mode (+4) | | | | | 1: Auto-decrement mode (-4) | | | WT RD | Bit Name Value WT 0 RD 0 RD 0 All 0 | Bit Name Value R/W WT 0 R/W* — 0 R RD 0 R/W* — All 0 R | Note: \* Changing the HIFRAM banks accessible from an external device by setting the BMD and BSEL bits in HIFSCR does not affect the setting of this bit. Page 896 of 1278 ## 20.4.5 HIF Internal Interrupt Control Register (HIFIICR) HIFIICR is a 32-bit register used to issue interrupts from an external device connected to the HIF to the on-chip CPU. Access to HIFIICR by an external device should be performed with HIFIICR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|------|------|------|------|------|------|------|-----| | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | IIC6 | IIC5 | IIC4 | IIC3 | IIC2 | IIC1 | IIC0 | IIR | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|--------|-----------------------------------------------------------------------------------------------------------------------| | ы | DIL Name | value | IT/ VV | Description | | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | IIC6 | 0 | R/W | Internal Interrupt Source | | 6 | IIC5 | 0 | R/W | These bits specify the source for interrupts generated by | | 5 | IIC4 | 0 | R/W | the IIR bit. These bits can be written to from both an | | 4 | IIC3 | 0 | R/W | external device and the on-chip CPU. By using these bits, fast execution of interrupt exception handling is possible. | | 3 | IIC2 | 0 | R/W | These bits are completely under software control, and | | 2 | IIC1 | 0 | R/W | their values have no effect on the operation of this LSI. | | 1 | IIC0 | 0 | R/W | | | 0 | IIR | 0 | R/W | Internal Interrupt Request | | | | | | While this bit is 1, an interrupt request (HIFI) is issued to the on-chip CPU. | ## 20.4.6 HIF External Interrupt Control Register (HIFEICR) HIFEICR is a 32-bit register used to issue interrupts to an external device connected to the HIF from this LSI. Access to HIFEICR by an external device should be performed with HIFEICR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|------|------|------|------|------|------|------|-----| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | - | ı | 1 | - | _ | EIC6 | EIC5 | EIC4 | EIC3 | EIC2 | EIC1 | EIC0 | EIR | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | D:4 | Dit Name | Initial | DAM | Description | |---------|----------|---------|-----|--------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | EIC6 | 0 | R/W | External Interrupt Source | | 6 | EIC5 | 0 | R/W | These bits specify the source for interrupts generated by | | 5 | EIC4 | 0 | R/W | the EIR bit. These bits can be written to from both an external device and the on-chip CPU. By using these bits, | | 4 | EIC3 | 0 | R/W | fast execution of interrupt exception handling is possible. | | 3 | EIC2 | 0 | R/W | These bits are completely under software control, and | | 2 | EIC1 | 0 | R/W | their values have no effect on the operation of this LSI. | | 1 | EIC0 | 0 | R/W | | | 0 | EIR | 0 | R/W | External Interrupt Request | | | | | | While this bit is 1, the HIFINT pin is asserted to issue an interrupt request to an external device from this LSI. | ## 20.4.7 HIF Address Register (HIFADR) HIFADR is a 32-bit register which indicates the address in HIFRAM to be accessed by an external device. When using the LOCK bit setting in HIFMCR to specify consecutive access of HIFRAM, auto-increment (+4) or auto-decrement (-4) of the address, according to the AI/AD bit setting in HIFMCR, is performed automatically, and HIFADR is updated. HIFADR can be only read by the on-chip CPU. Access to HIFADR by an external device should be performed with HIFADR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|-----|-----|-----|-----|-----|------|-----|-----|-----|----|----| | | _ | _ | _ | - | - | | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | | | | | A[1 | 0:2] | | | | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R/W R | R | | | | Initial | | | |----------|----------|---------|-----|------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 to 2 | A[10:2] | All 0 | R/W | HIFRAM Address Specification | | | | | | These bits specify the address of HIFRAM to be accessed by an external device, with 32-bit boundary. | | 1, 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | #### 20.4.8 HIF Data Register (HIFDATA) HIFDATA is a 32-bit register used to hold data to be written to HIFRAM and data read from HIFRAM for external device accesses. If HIFDATA is not used when accessing HIFRAM, it can be used for data transfer between an external device connected to the HIF and the on-chip CPU. HIFDATA can be read from and written to by the on-chip CPU. Access to HIFDATA by an external device should be performed with HIFDATA specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | | | | | | | D[31 | 1:16] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | D[1 | 5:0] | | | | | | | | | Initial Value: 0<br>R/W: R/W | 0<br>R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|-------------| | 31 to 0 | D[31:0] | All 0 | R/W | 32-bit data | ## **20.4.9** HIF Boot Control Register (HIFBCR) HIFBCR is a 32-bit register for exclusive control of an external device and the on-chip CPU regarding access of HIFRAM. HIFBCR can be only read by the on-chip CPU. Access to HIFBCR by an external device should be performed with HIFBCR specified by bits REG5 to REG0 in HIFIDX and the HIFRS pin low. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----| | | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | AC | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0/1 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 to 1 | _ | All 0 | R/W | AC-Bit Writing Assistance | | | | | | These bits should be used to write the bit pattern (H'A5) needed to set the AC bit to 1. These bits are always read as 0. | | 0 | AC | 0/1 | R/W | HIFRAM Access Exclusive Control | | | | | | Controls accessing of HIFRAM by the on-chip CPU for<br>the HIFRAM bank selected by the BMD and BSEL bits<br>in HIFSCR as the bank allowed to be accessed by this<br>LSI. | | | | | | <ol><li>The on-chip CPU can perform reading/writing of<br/>HIFRAM.</li></ol> | | | | | | 1: When an HIFRAM read/write operation by the on-chip CPU occurs, the CPU enters the wait state, and execution of the instruction is halted until this bit is cleared to 0. | | | | | | When booted in non-HIF boot mode, the initial value of this bit is 0. | | | | | | When booted in HIF boot mode, the initial value of this bit is 1. After an external device writes a boot program to HIFRAM via the HIF, clearing this bit to 0 boots the onchip CPU from HIFRAM. | | | | | | When 1 is written to this bit by an external device, H'A5 should be written to bits 7 to 0 to prevent erroneous writing. | # 20.4.10 HIFDREQ Trigger Register (HIFDTR) HIFDTR is a 32-bit register. Writing to HIFDTR by the on-chip CPU asserts the HIFDREQ pin. HIFDTR cannot be accessed by an external device. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------| | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | DTRG | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | | | | Initial | | | |---------|----------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 1 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 0 | DTRG | 0 | R/W | HIFDREQ Trigger | | | | | | When 1 is written to this bit, the HIFDREQ pin is asserted according to the setting of the DMD and DPOL bits in HIFSCR. This bit is automatically cleared to 0 in synchronization with negate of the HIFDREQ pin. | | | | | | Though this bit can be set to 1 by the on-chip CPU, it cannot be cleared to 0. | | | | | | To avoid conflict between clearing of this bit by negate of the HIFDREQ pin and setting of this bit by the onchip CPU, make sure this bit is cleared to 0 before setting this bit to 1 by the on-chip CPU. | | | | | | Writing 0 is invalid. | # 20.4.11 HIF Bank Interrupt Control Register (HIFBICR) HIFBICR is a 32-bit register that controls HIF bank interrupts. HIFBICR cannot be accessed by an external device. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----| | [ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | [ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | BIE | BIF | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|---------------------------------------------------------------------------------| | 31 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | BIE | 0 | R/W | Bank Interrupt Enable | | | | | | Enables or disables a bank interrupt request (HIFBI) issued to the on-chip CPU. | | | | | | 0: HIFBI disabled | | | | | | 1: HIFBI enabled | | O BIF O R/W Bank Interrupt Request Flag While this bit is 1, a bank interrupt request (HIFBI) is issued to the on-chip CPU according to the setting of the BIE bit. In auto-increment mode (Al/AD bit in HIFMCR is 0), this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the end address of HIFRAM and the HIFCS pin has been negated. In auto-decrement mode (Al/AD bit in HIFMCR is 1), this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the start address of HIFRAM and the HIFCS pin has been negated. Though this bit can be cleared to 0 by the on-chip CPU, it cannot be set to 1. Make sure setting of this bit by HIFRAM access from an external device and clearing of this bit by the on-chip CPU do not conflict using software. Writing 1 is invalid. | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | issued to the on-chip CPU according to the setting of the BIE bit. In auto-increment mode (AI/AD bit in HIFMCR is 0), this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the end address of HIFRAM and the HIFCS pin has been negated. In auto-decrement mode (AI/AD bit in HIFMCR is 1), this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the start address of HIFRAM and the HIFCS pin has been negated. Though this bit can be cleared to 0 by the on-chip CPU, it cannot be set to 1. Make sure setting of this bit by HIFRAM access from an external device and clearing of this bit by the on-chip CPU do not conflict using software. | 0 | BIF | 0 | R/W | | | this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the end address of HIFRAM and the HIFCS pin has been negated. In auto-decrement mode (AI/AD bit in HIFMCR is 1), this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the start address of HIFRAM and the HIFCS pin has been negated. Though this bit can be cleared to 0 by the on-chip CPU, it cannot be set to 1. Make sure setting of this bit by HIFRAM access from an external device and clearing of this bit by the on-chip CPU do not conflict using software. | | | | | issued to the on-chip CPU according to the setting of | | this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the start address of HIFRAM and the HIFCS pin has been negated. Though this bit can be cleared to 0 by the on-chip CPU, it cannot be set to 1. Make sure setting of this bit by HIFRAM access from an external device and clearing of this bit by the on-chip CPU do not conflict using software. | | | | | this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the end address of HIFRAM and the HIFCS pin has been | | CPU, it cannot be set to 1. Make sure setting of this bit by HIFRAM access from an external device and clearing of this bit by the onchip CPU do not conflict using software. | | | | | this bit is automatically set to 1 when an external device has completed access to the 32-bit data in the start address of HIFRAM and the $\overline{\text{HIFCS}}$ pin has been | | an external device and clearing of this bit by the on-<br>chip CPU do not conflict using software. | | | | | · · | | Writing 1 is invalid. | | | | | an external device and clearing of this bit by the on- | | | | | | | Writing 1 is invalid. | #### 20.5 Memory Map Table 20.3 shows the memory map of HIFRAM. Table 20.3 Memory Map | Classification | Start Address | End Address | Memory Size | |----------------------------|---------------|-------------|-------------| | Map from external device*1 | H'0000 | H'07FF | 2 Kbytes | | Map from on-chip CPU*1 *2 | H'FFFF_F000 | H'FFFF_F7FF | 2 Kbytes | - Notes: 1. Map for a single HIFRAM bank. Which bank is to be accessed by an external device or the on-chip CPU depends on the BMD and BSEL bits in HIFSCR. The mapping addresses are common between the banks. - 2. In HIF boot mode, however, bank 0 is selected and the first 2 Kbytes of the first-half 32 Mbytes in the following areas are also mapped: (1) the cacheable area 0 in the H'0000\_0000 to H'0000\_07FF range and (2) the non-cacheable area 0 in the H'2000\_0000 to H'2000\_07FF range. If an external device modifies HIFRAM when HIFRAM is accessed from the cacheable area with the cache enabled, a coherency problem will occur. When the cache is enabled, accessing HIFRAM from the non-cacheable area is recommended. In HIF boot mode, among the first-half 32 Mbytes of each area 0, access to only the addresses to which HIFRAM is mapped is permitted. Even in HIF boot mode, the areas excluding the first-half 32 Mbytes of area 0 are ## 20.6 Interface #### 20.6.1 Basic Sequence Figure 20.3 shows the basic read/write sequence. HIF read is defined by the overlap period of the $\overline{\text{HIFRD}}$ low-level period and $\overline{\text{HIFCS}}$ low-level period, and HIF write is defined by the overlap period of the $\overline{\text{HIFWR}}$ low-level period and $\overline{\text{HIFCS}}$ low-level period. The HIFRS signal indicates whether this is normal access or index register access; low level indicates normal access and high level indicates index register access. Figure 20.3 Basic Timing for HIF Interface ## 20.6.2 Reading/Writing of HIF Registers other than HIFIDX and HIFIDX As shown in figure 20.4, in reading and writing of HIF internal registers other than HIFIDX and HIFIDX, first HIFRS is held high and HIFIDX is written to in order to select the register to be accessed and the byte location. Then HIFRS is held low, and reading or writing of the register selected by HIFIDX is performed. Figure 20.4 HIF Register Settings ## 20.6.3 Consecutive Data Writing to HIFRAM by External Device Figure 20.5 shows the timing chart for consecutive data transfer from an external device to HIFRAM. As shown in this timing chart, by setting the start address and the data to be written first, consecutive data transfer can subsequently be performed. Figure 20.5 Consecutive Data Writing to HIFRAM ## 20.6.4 Consecutive Data Reading from HIFRAM to External Device Figure 20.6 shows the timing chart for consecutive data reading from HIFRAM to an external device. As this timing chart indicates, by setting the start address, data can subsequently be read out consecutively. Figure 20.6 Consecutive Data Reading from HIFRAM #### **20.7** External DMAC Interface Figures 20.7 to 20.10 show the HIFDREQ output timing. The start of the HIFDREQ assert synchronizes with the DTRG bit in HIFDTR being set to 1. The HIFDREQ negate timing and assert level are determined by the DMD and DPOL bits in HIFSCR, respectively. When the external DMAC is specified to detect low level of the HIFDREQ signal, set DMD = 0 and DPOL = 0. After writing 1 to the DTRG bit, the HIFDREQ signal remains low until a read from or write to the HIFIDX-specified register is detected. Writing to the index register (HIFIDX) does not negate the signal. Figure 20.7 HIFDREQ Timing (When DMD = 0 and DPOL = 0) When the external DMAC is specified to detect high level of the HIFDREQ signal, set DMD = 0 and DPOL = 1. At the time the DPOL bit is set to 1, HIFDREQ becomes low. After this, the HIFDREQ signal remains low from when 1 is written to the DTRG bit until a read from or write to the HIFIDX-specified register is detected. Writing to the index register (HIFIDX) does not negate the signal. Figure 20.8 HIFDREQ Timing (When DMD = 0 and DPOL = 1) When the external DMAC is specified to detect the falling edge of the HIFDREQ signal, set DMD = 1 and DPOL = 0. After writing 1 to the DTRG bit, a low pulse of 32 peripheral clock cycles is generated at the HIFDREQ pin. Figure 20.9 HIFDREQ Timing (When DMD = 1 and DPOL = 0) When the external DMAC is specified to detect the rising edge of the HIFDREQ signal, set DMD = 1 and DPOL = 1. At the time the DPOL bit is set to 1, HIFDREQ becomes low. Then after writing 1 to the DTRG bit, a low pulse of 32 peripheral clock cycles is generated at the HIFDREQ pin. Figure 20.10 HIFDREQ Timing (When DMD = 1 and DPOL = 1) When the external DMAC supports intermittent operating mode (block transfer mode), efficient data transfer can be implemented by using the HIFRAM consecutive access and bank functions. Table 20.4 Consecutive Write Procedure to HIFRAM by External DMAC | | External D | evice | This LSI | | | | | | |-----|----------------------------------------------------------------|------------------------------------------------------------------------------------|---------------|---------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--| | No. | CPU | DMAC | - | HIF | | CPU | | | | 1 | HIF initial setting | | | | | HIF initial setting | | | | 2 | DMAC initial setting | | | | | | | | | 3 | Set HIFADR to<br>HIFRAM end address<br>– 8 | | | | | | | | | 4 | Select HIFDATA and<br>write dummy data (4<br>bytes) to HIFDATA | | | | | | | | | 5 | Set HIFRAM consecutive write with address increment in HIFMCR | | | | | | | | | 6 | Select HIFDATA and write dummy data (4 bytes) to HIFDATA | · | $\rightarrow$ | HIF bank interrupt occurs | $\rightarrow$ | HIFRAM bank switching<br>by HIF bank interrupt<br>handler (external device<br>accesses bank 1 and on-<br>chip CPU accesses<br>bank 0) | | | | 7 | | Activate DMAC | $\leftarrow$ | Assert<br>HIFDREQ | $\leftarrow$ | Set DTRG bit to 1 | | | | 8 | | Consecutive data write to bank 1 in HIFRAM | | | | | | | | 9 | | Write to end<br>address of bank<br>1 in HIFRAM<br>completes and<br>operation halts | $\rightarrow$ | HIF bank interrupt occurs | $\rightarrow$ | HIFRAM bank switching<br>by HIF bank interrupt<br>handler (external device<br>accesses bank 0 and on-<br>chip CPU accesses<br>bank 1) | | | | 10 | | Re-activate<br>DMAC | $\leftarrow$ | Assert<br>HIFDREQ | $\leftarrow$ | Set DTRG bit to 1 | | | | | E | xternal Device | | This LSI | |-----|-----|------------------------------------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------| | No. | CPU | DMAC | HIF | CPU | | 11 | | Consecutive<br>data write to<br>bank 0 in<br>HIFRAM | | Read data from bank 1 in<br>HIFRAM | | 12 | | Write to end address of bank 0 in HIFRAM completes and operation halts | → HIF bank interrupt occurs | → HIFRAM bank switching<br>by HIF bank interrupt<br>handler (external device<br>accesses bank 1 and on-<br>chip CPU accesses<br>bank 0) | | 13 | | Re-activate «<br>DMAC | ← Assert<br>HIFDREQ | ← Set DTRG bit to 1 | Hereafter No. 11 to 13 are repeated. When a register other than HIFDATA is accessed (except that HIFGSR read with HIFRS = low), HIFRAM consecutive write is interrupted, and No. 3 to 6 need to be done again. Table 20.5 Consecutive Read Procedure from HIFRAM by External DMAC | | External D | Device | | This LSI | |-----|-----------------------------------------------------------------------|--------|-----|--------------------------------| | No. | CPU | DMAC | HIF | CPU | | 1 | HIF initial setting | | | HIF initial setting | | 2 | DMAC initial setting | | | | | 3 | Set HIFADR to<br>HIFRAM start<br>address | | | | | 4 | Set HIFRAM<br>consecutive read with<br>address increment in<br>HIFMCR | | | | | 5 | Select HIFDATA | | | | | 6 | | | | Write data to bank 1 in HIFRAM | | | Ex | ternal Device | | This LSI | |-----|-----|---------------------------------------------------------------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | No. | CPU | DMAC | HIF | CPU | | 7 | | | | After writing data to end address of bank 1 in HIFRAM, perform HIFRAM bank switching (external device accesses bank 1 and onchip CPU accesses bank 0) | | 8 | | Activate DMAC | <ul><li>Assert</li><li>HIFDREQ</li></ul> | ← Set DTRG bit to 1 | | 9 | | Consecutive<br>data read from<br>bank 1 in<br>HIFRAM | | Write data to bank 0 in<br>HIFRAM | | 10 | | Read from end –<br>address of bank<br>1 in HIFRAM<br>completes and<br>operation halts | HIF bank interrupt occurs | → HIFRAM bank switching<br>by HIF bank interrupt<br>handler (external device<br>accesses bank 0 and on-<br>chip CPU accesses<br>bank 1) | | 11 | | Re-activate ←<br>DMAC | <ul><li>Assert</li><li>HIFDREQ</li></ul> | ← Set DTRG bit to 1 | | 12 | | Consecutive<br>data read from<br>bank 0 in<br>HIFRAM | | Write data to bank 1 in<br>HIFRAM | | 13 | | Read from end –<br>address of bank<br>0 in HIFRAM<br>completes and<br>operation halts | → HIF bank<br>interrupt<br>occurs | → HIFRAM bank switching<br>by HIF bank interrupt<br>handler (external device<br>accesses bank 1 and on-<br>chip CPU accesses<br>bank 0) | | 14 | | Re-activate ←<br>DMAC | <ul><li>Assert</li><li>HIFDREQ</li></ul> | ← Set DTRG bit to 1 | Hereafter No. 12 to 14 are repeated. When a register other than HIFDATA is accessed (except that HIFGSR read with HIFRS = low), HIFRAM consecutive read is interrupted, and No. 3 to 5 need to be done again. Jun 21, 2011 #### **Alignment Control** 20.8 Tables 20.6 and 20.7 show the alignment control when an external device accesses the HIFDATA register, and the HIF registers other than the HIFDATA register, respectively. Table 20.6 HIFDATA Register Alignment for Access by an External Device | WBSWP Bit | BO Bit | BYTE[1:0] Bits | Alignment in HIFD[15:0] Pins | |-----------|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | B'00 | H'7654 | | | | B'10 | H'3210 | | | 1 | B'00 | H'3210 | | | | B'10 | H'7654 | | 1 | 0 | B'00 | H'1032 | | | | B'10 | H'5476 | | | 1 | B'00 | H'5476 | | | | B'10 | H'1032 | | | | 0 0 1 | $ \begin{array}{c c} 0 & B'00 \\ \hline B'10 \\ 1 & B'00 \\ \hline B'10 \\ 1 & B'00 \\ \hline B'10 \\ \hline B'10 \\ \hline 1 & B'00 \\ \hline B'00 \\ \hline B'00 \\ B'00 \\ \hline B'00 \\ B'00 \\ \hline B'00 \\ \\$ | Table 20.7 HIF Registers (other than HIFDATA) Alignment for Access by an External **Device** | Data in HIFDATA | WBSWP Bit | BO Bit | BYTE[1:0] Bits | Alignment in HIFD[15:0] Pins | |-----------------|------------|--------|----------------|------------------------------| | H'76543210 | Don't care | 0 | B'00 | H'7654 | | | | | B'10 | H'3210 | | | | 1 | B'00 | H'3210 | | | | | B'10 | H'7654 | ## 20.9 Interface When External Device Power is Cut Off When the power supply of an external device interfacing with the HIF is cut off, intermediate levels may be applied to the HIF input pins or the HIF output pins may drive an external device not powered, thus causing the device to be damaged. The HIFEBL pin is provided to prevent this from happening. The system power monitor block controls this pin in synchronization with the cutoff of the external device power so that all pins of this module excluding HIFMD can be set to the high-impedance state. Figure 20.11 shows an image of high-impedance control of the HIF pins. Table 20.8 lists the input/output control for the HIF pins. Figure 20.11 Image of High-Impedance Control of HIF Pins by HIFEBL Pin Table 20.8 Input/Output Control for HIF Pins | | Q1 | | |---|----|--| | _ | 9 | | Page 916 of 1278 | Status | Reset St | ate by RE | S Pin | Reset Canceled by RES Pin | | | | | | |---------------------------------------|--------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|--|--| | HIFMD input level | put High (Boot | | Low<br>(Non-boot<br>setting) | The reset by a<br>released whil<br>signal is high<br>(boot mode e | e the HIFMD | The reset by the RES pin is released while the HIFMD signal is low (non-boot mode established) | | | | | HIFEBL<br>input<br>level | Low | High | The HIFEBL pin is a general input port and the HIF is not controlled by the signal input on this pin. | Low | High | General input port at the initial state * | | | | | HIFRDY<br>output<br>control | Output<br>buffer:<br>On<br>(Low<br>output) | Output<br>buffer:<br>On<br>(Low<br>output) | General input port | Output<br>buffer: Off | Output<br>buffer: On<br>(Sequence<br>output) | General input port at the initial state*2 | | | | | HIFINT output control | Output<br>buffer:<br>Off | Output<br>buffer:<br>Off | General input port | Output<br>buffer:<br>Off | Output<br>buffer: On<br>(Sequence<br>output) | General input port at the initial state*2 | | | | | HIFDREQ<br>output<br>control | Output<br>buffer:<br>Off | Output<br>buffer:<br>Off | General input port | Output<br>buffer:<br>Off | Output<br>buffer: On<br>(Sequence<br>output) | General input port at the initial state*2 | | | | | HIFD 15<br>to HIFD0<br>I/O<br>control | I/O<br>buffer:<br>Off | I/O<br>buffer:<br>Off | General input port | I/O buffer:<br>Off | I/O buffer<br>controlled<br>according to<br>states of<br>HIFCS,<br>HIFWR,<br>and HIFRD | General input port at the initial state*2 | | | | | HIFCS input control | Input<br>buffer:<br>Off | Input<br>buffer:<br>Off | General input port | Input buffer:<br>Off | Input buffer:<br>On | General input port at the initial state*2 | | | | | HIFRS input control | Input<br>buffer:<br>Off | Input<br>buffer:<br>Off | General input port | Input buffer:<br>Off | Input buffer:<br>On | General input port at the initial state*2 | | | | | LSI<br>Status | Reset | State by | RES Pin | Reset Canceled by RES Pin | | | | | | | |--------------------------|-------------------------|-------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------|----------------------------------------------------------|--|--|--|--| | | | • , | | High<br>(After th<br>canceled<br>setting) | e reset<br>d by boot | Low<br>(After the reset canceled by<br>non-boot setting) | | | | | | HIFEBL<br>input<br>level | Low | High | The HIFEBL pin is a general input port and the HIF is not controlled by the signal input on this pin. | Low | High | General input port at the initial state *1 | | | | | | HIFWR input control | Input<br>buffer:<br>Off | Input<br>buffer:<br>Off | General input port | Input<br>buffer:<br>Off | Input<br>buffer:<br>On | General input port at the initial state* <sup>2</sup> | | | | | | HIFRD input control | Input<br>buffer:<br>Off | Input<br>buffer:<br>Off | General input port | Input<br>buffer:<br>Off | Input<br>buffer:<br>On | General input port at the initial state*2 | | | | | Notes: 1. The pin also functions as an HIFEBL pin by setting the PFC registers. 2. The pin also functions as an HIF pin by setting the PFC registers. When the HIF pin function is selected for the HIFEBL pin and this pin by setting the PFC registers, the input and/or output buffers are controlled according to the HIFEBL pin state. When the HIF pin function is not selected for the HIFEBL pin and is selected for this pin by setting the PFC registers, the input and/or output buffers are always turned off. This setting is prohibited. ## 20.10 Usage Notes ## (1) Conflict between Access from External Device and Access from Internal Bus (from CPU or DMAC of This LSI) to HIF Registers Regarding HIF related registers which can be accessed from both an external device and the internal bus, take measures to avoid a conflict between a read/write operation from an external device and a write operation from the internal bus. When a read operation from an external device conflicts with a write operation from the internal bus, the read data at the HIFD[15:0] pins will be updated in the middle of a read cycle by the external device. When a write operation from an external device conflicts with a write operation from the internal bus, the write operation from the internal bus is ignored. In this case, the CPU or DMAC of this LSI is not notified of an error. A conflict between a read/write operation from an external device and a read operation from the internal bus will not cause any problem. ## Section 21 Compare Match Timer (CMT) This LSI has an on-chip compare match timer (CMT) consisting of a two-channel 16-bit timer. The CMT has a16-bit counter, and can generate interrupts at set intervals. #### 21.1 Features - Independent selection of four counter input clocks at two channels Any of four internal clocks (Pφ/8, Pφ/32, Pφ/128, and Pφ/512) can be selected. - Selection of DMA transfer request or interrupt request generation on compare match by DMAC setting - When not in use, the CMT can be stopped by halting its clock supply to reduce power consumption. Figure 21.1 shows a block diagram of CMT. Figure 21.1 Block Diagram of CMT ## 21.2 Register Descriptions The CMT has the following registers. **Table 21.1 Register Configuration** | Channel | Register Name | Abbreviation | R/W | Initial<br>Value | Address | Access<br>Size | |---------|---------------------------------------------------|--------------|--------|------------------|------------|----------------| | Common | Compare match timer start register | CMSTR | R/W | H'0000 | H'FFFEC000 | 16 | | 0 | Compare match timer control/<br>status register_0 | CMCSR_0 | R/(W)* | H'0000 | H'FFFEC002 | 16 | | | Compare match counter_0 | CMCNT_0 | R/W | H'0000 | H'FFFEC004 | 16 | | | Compare match constant register_0 | CMCOR_0 | R/W | H'FFFF | H'FFFEC006 | 16 | | 1 | Compare match timer control/<br>status register_1 | CMCSR_1 | R/(W)* | H'0000 | H'FFFEC008 | 16 | | | Compare match counter_1 | CMCNT_1 | R/W | H'0000 | H'FFFEC00A | 16 | | | Compare match constant register_1 | CMCOR_1 | R/W | H'FFFF | H'FFFEC00C | 16 | #### 21.2.1 **Compare Match Timer Start Register (CMSTR)** CMSTR is a 16-bit register that selects whether compare match counter (CMCNT) operates or is stopped. CMSTR is initialized to H'0000 by a power-on reset or in software standby mode, but retains its previous value in module standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------|------| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | STR1 | STR0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 1 | STR1 | 0 | R/W | Count Start 1 | | | | | | Specifies whether compare match counter_1 operates or is stopped. | | | | | | 0: CMCNT_1 count is stopped | | | | | | 1: CMCNT_1 count is started | | 0 | STR0 | 0 | R/W | Count Start 0 | | | | | | Specifies whether compare match counter_0 operates or is stopped. | | | | | | 0: CMCNT_0 count is stopped | | | | | | 1: CMCNT_0 count is started | ## 21.2.2 Compare Match Timer Control/Status Register (CMCSR) CMCSR is a 16-bit register that indicates compare match generation, enables or disables interrupts, and selects the counter input clock. CMCSR is initialized to H'0000 by a power-on reset or in software standby mode, but retains its previous value in module standby mode. Note: \* Only 0 can be written to clear the flag after 1 is read. | D: | Dia Massa | Initial | DAM | Besselville | |---------|-----------|---------|--------|-----------------------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be $0$ . | | 7 | CMF | 0 | R/(W)* | Compare Match Flag | | | | | | Indicates whether or not the values of CMCNT and CMCOR match. | | | | | | 0: CMCNT and CMCOR values do not match | | | | | | [Clearing condition] | | | | | | • When 0 is written to CMF after reading CMF = 1 | | | | | | 1: CMCNT and CMCOR values match | | 6 | CMIE | 0 | R/W | Compare Match Interrupt Enable | | | | | | Enables or disables compare match interrupt (CMI) generation when CMCNT and CMCOR values match (CMF = 1). | | | | | | 0: Compare match interrupt (CMI) disabled | | | | | | 1: Compare match interrupt (CMI) enabled | | 5 to 2 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1, 0 | CKS[1:0] | 00 | R/W | Clock Select | | | | | | These bits select the clock to be input to CMCNT from four internal clocks obtained by dividing the peripheral clock (P $\phi$ ). When the STR bit in CMSTR is set to 1, CMCNT starts counting on the clock selected with bits CKS[1:0]. | | | | | | 00: Pφ/8 | | | | | | 01: P | | | | | | 10: P | | | | | | 11: P | Note: \* Only 0 can be written to clear the flag after 1 is read. #### 21.2.3 Compare Match Counter (CMCNT) CMCNT is a 16-bit register used as an up-counter. When the counter input clock is selected with bits CKS[1:0] in CMCSR, and the STR bit in CMSTR is set to 1, CMCNT starts counting using the selected clock. When the value in CMCNT and the value in compare match constant register (CMCOR) match, CMCNT is cleared to H'0000 and the CMF flag in CMCSR is set to 1. CMCNT is initialized to H'0000 by a power-on reset or in software standby mode, but retains its previous value in module standby mode. ## 21.2.4 Compare Match Constant Register (CMCOR) CMCOR is a 16-bit register that sets the interval up to a compare match with CMCNT. CMCOR is initialized to H'FFFF by a power-on reset or in software standby mode, but retains its previous value in module standby mode. ## 21.3 Operation #### 21.3.1 Interval Count Operation When an internal clock is selected with the CKS[1:0] bits in CMCSR and the STR bit in CMSTR is set to 1, CMCNT starts incrementing using the selected clock. When the values in CMCNT and CMCOR match, CMCNT is cleared to H'0000 and the CMF flag in CMCSR is set to 1. When the CMIE bit in CMCSR is set to 1 at this time, a compare match interrupt (CMI) is requested. CMCNT then starts counting up again from H'0000. Figure 21.2 shows the operation of the compare match counter. Figure 21.2 Counter Operation ## 21.3.2 CMCNT Count Timing One of four clocks ( $P\phi/8$ , $P\phi/32$ , $P\phi/128$ , and $P\phi/512$ ) obtained by dividing the peripheral clock ( $P\phi$ ) can be selected with the CKS[1:0] bits in CMCSR. Figure 21.3 shows the timing. Figure 21.3 Count Timing ## 21.4 Interrupts #### 21.4.1 Interrupt Sources and DMA Transfer Requests The CMT has channels and each of them to which a different vector address is allocated has a compare match interrupt. When both the compare match flag (CMF) and the interrupt enable bit (CMIE) are set to 1, the corresponding interrupt request is output. When the interrupt is used to activate a CPU interrupt, the priority of channels can be changed by the interrupt controller settings. For details, see section 6, Interrupt Controller (INTC). Clear the CMF bit to 0 by the user exception handling routine. If this operation is not carried out, another interrupt will be generated. The direct memory access controller (DMAC) can be set to be activated when a compare match interrupt is requested. In this case, an interrupt is not issued to the CPU. If the setting to activate the DMAC has not been made, an interrupt request is sent to the CPU. The CMF bit is automatically cleared to 0 when data is transferred by the DMAC. ## 21.4.2 Timing of Compare Match Flag Setting When CMCOR and CMCNT match, a compare match signal is generated at the last state in which the values match (the timing when the CMCNT value is updated to H'0000) and the CMF bit in CMCSR is set to 1. That is, after a match between CMCOR and CMCNT, the compare match signal is not generated until the next CMCNT counter clock input. Figure 21.4 shows the timing of CMF bit setting. Figure 21.4 Timing of CMF Setting #### **Timing of Compare Match Flag Clearing** 21.4.3 The CMF bit in CMCSR is cleared by first, reading as 1 then writing to 0. However, in the case of the DMAC being activated, the CMF bit is automatically cleared to 0 when data is transferred by the DMAC. ## 21.5 Usage Notes ## 21.5.1 Conflict between Write and Compare-Match Processes of CMCNT When the compare match signal is generated in the T2 cycle while writing to CMCNT, clearing CMCNT has priority over writing to it. In this case, CMCNT is not written to. Figure 21.5 shows the timing to clear the CMCNT counter. Figure 21.5 Conflict between Write and Compare Match Processes of CMCNT ## 21.5.2 Conflict between Word-Write and Count-Up Processes of CMCNT Even when the count-up occurs in the T2 cycle while writing to CMCNT in words, the writing has priority over the count-up. In this case, the count-up is not performed. Figure 21.6 shows the timing to write to CMCNT in words. Figure 21.6 Conflict between Word-Write and Count-Up Processes of CMCNT #### 21.5.3 Conflict between Byte-Write and Count-Up Processes of CMCNT Even when the count-up occurs in the T2 cycle while writing to CMCNT in bytes, the writing has priority over the count-up. In this case, the count-up is not performed. The byte data on the other side, which is not written to, is also not counted and the previous contents are retained. Figure 21.7 shows the timing when the count-up occurs in the T2 cycle while writing to CMCNTH in bytes. Figure 21.7 Conflict between Byte-Write and Count-Up Processes of CMCNT ## 21.5.4 Compare Match Between CMCNT and CMCOR Do not set a same value to CMCNT and CMCOR while the count operation of CMCNT is stopped. # Section 22 Serial Communication Interface with FIFO (SCIF) This LSI has a three-channel serial communication interface with FIFO (SCIF) that supports both asynchronous and clocked synchronous serial communication. It also has 16-stage FIFO registers for both transmission and reception independently for each channel that enable this LSI to perform efficient high-speed continuous communication. #### 22.1 Features - Asynchronous serial communication: - Serial data communication is performed by start-stop in character units. The SCIF can communicate with a universal asynchronous receiver/transmitter (UART), an asynchronous communication interface adapter (ACIA), or any other communications chip that employs a standard asynchronous serial system. There are eight selectable serial data communication formats. - Data length: 7 or 8 bitsStop bit length: 1 or 2 bitsParity: Even, odd, or none - Receive error detection: Parity, framing, and overrun errors - Break detection: Break is detected when a framing error is followed by at least one frame at the space 0 level (low level). It is also detected by reading the RxD level directly from the serial port register when a framing error occurs. - Clocked synchronous serial communication: - Serial data communication is synchronized with a clock signal. The SCIF can communicate with other chips having a clocked synchronous communication function. There is one serial data communication format. - Data length: 8 bits - Receive error detection: Overrun errors - Full duplex communication: The transmitting and receiving sections are independent, so the SCIF can transmit and receive simultaneously. Both sections use 16-stage FIFO buffering, so high-speed continuous data transfer is possible in both the transmit and receive directions. - On-chip baud rate generator with selectable bit rates - Internal or external transmit/receive clock source: From either baud rate generator (internal) or SCK pin (external) - Four types of interrupts: Transmit-FIFO-data-empty interrupt, break interrupt, receive-FIFO-data-full interrupt, and receive-error interrupts are requested independently. - When the SCIF is not in use, it can be stopped by halting the clock supplied to it, saving power. - In asynchronous mode, on-chip modem control functions ( $\overline{\text{RTS}}$ and $\overline{\text{CTS}}$ ). - The quantity of data in the transmit and receive FIFO data registers and the number of receive errors of the receive data in the receive FIFO data register can be ascertained. - A time-out error (DR) can be detected when receiving in asynchronous mode. Figure 22.1 shows a block diagram of the SCIF. Figure 22.1 Block Diagram of SCIF ## 22.2 Input/Output Pins Table 22.1 shows the pin configuration of the SCIF. **Table 22.1 Pin Configuration** | Channel | Pin Name | Symbol | I/O | Function | |---------|---------------------|--------------|--------|----------------------| | 0 to 2 | Serial clock pins | SCK0 to SCK2 | I/O | Clock I/O | | | Receive data pins | RxD0 to RxD2 | Input | Receive data input | | | Transmit data pins | TxD0 to TxD2 | Output | Transmit data output | | | Request to send pin | RTS0 to RTS2 | I/O | Request to send | | | Clear to send pin | CTS0 to CTS2 | I/O | Clear to send | ## 22.3 Register Descriptions The SCIF has the following registers. **Table 22.2 Register Configuration** | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------|--------------|---------|---------------|------------|----------------| | 0 | Serial mode register_0 | SCSMR_0 | R/W | H'0000 | H'FFFE8000 | 16 | | | Bit rate register_0 | SCBRR_0 | R/W | H'FF | H'FFFE8004 | 8 | | | Serial control register_0 | SCSCR_0 | R/W | H'0000 | H'FFFE8008 | 16 | | | Transmit FIFO data register_0 | SCFTDR_0 | W | Undefined | H'FFFE800C | 8 | | | Serial status register_0 | SCFSR_0 | R/(W)*1 | H'0060 | H'FFFE8010 | 16 | | | Receive FIFO data register_0 | SCFRDR_0 | R | Undefined | H'FFFE8014 | 8 | | | FIFO control register_0 | SCFCR_0 | R/W | H'0000 | H'FFFE8018 | 16 | | | FIFO data count register_0 | SCFDR_0 | R | H'0000 | H'FFFE801C | 16 | | | Serial port register_0 | SCSPTR_0 | R/W | H'0050 | H'FFFE8020 | 16 | | | Line status register_0 | SCLSR_0 | R/(W)*2 | H'0000 | H'FFFE8024 | 16 | | 1 | Serial mode register_1 | SCSMR_1 | R/W | H'0000 | H'FFFE8800 | 16 | | | Bit rate register_1 | SCBRR_1 | R/W | H'FF | H'FFFE8804 | 8 | | | Serial control register_1 | SCSCR_1 | R/W | H'0000 | H'FFFE8808 | 16 | | | Transmit FIFO data register_1 | SCFTDR_1 | W | Undefined | H'FFFE880C | 8 | | | Serial status register_1 | SCFSR_1 | R/(W)*1 | H'0060 | H'FFFE8810 | 16 | | | Receive FIFO data register_1 | SCFRDR_1 | R | Undefined | H'FFFE8814 | 8 | | | FIFO control register_1 | SCFCR_1 | R/W | H'0000 | H'FFFE8818 | 16 | | | FIFO data count register_1 | SCFDR_1 | R | H'0000 | H'FFFE881C | 16 | | | Serial port register_1 | SCSPTR_1 | R/W | H'0050 | H'FFFE8820 | 16 | | | Line status register_1 | SCLSR_1 | R/(W)*2 | H'0000 | H'FFFE8824 | 16 | | Channel | Register Name | Abbreviation | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------|--------------|---------|---------------|------------|----------------| | 2 | Serial mode register_2 | SCSMR_2 | R/W | H'0000 | H'FFFE9000 | 16 | | | Bit rate register_2 | SCBRR_2 | R/W | H'FF | H'FFFE9004 | 8 | | | Serial control register_2 | SCSCR_2 | R/W | H'0000 | H'FFFE9008 | 16 | | | Transmit FIFO data register_2 | SCFTDR_2 | W | Undefined | H'FFFE900C | 8 | | | Serial status register_2 | SCFSR_2 | R/(W)*1 | H'0060 | H'FFFE9010 | 16 | | | Receive FIFO data register_2 | SCFRDR_2 | R | Undefined | H'FFFE9014 | 8 | | | FIFO control register_2 | SCFCR_2 | R/W | H'0000 | H'FFFE9018 | 16 | | | FIFO data count register_2 | SCFDR_2 | R | H'0000 | H'FFFE901C | 16 | | | Serial port register_2 | SCSPTR_2 | R/W | H'0050 | H'FFFE9020 | 16 | | | Line status register_2 | SCLSR_2 | R/(W)*2 | H'0000 | H'FFFE9024 | 16 | Notes: 1. Only 0 can be written to clear the flag. Bits 15 to 8, 3, and 2 are read-only bits that cannot be modified. Only 0 can be written to clear the flag. Bits 15 to 1 are read-only bits that cannot be modified. #### 22.3.1 Receive Shift Register (SCRSR) SCRSR receives serial data. Data input at the RxD pin is loaded into SCRSR in the order received, LSB (bit 0) first, converting the data to parallel form. When one byte has been received, it is automatically transferred to the receive FIFO data register (SCFRDR). The CPU cannot read or write to SCRSR directly. #### 22.3.2 Receive FIFO Data Register (SCFRDR) SCFRDR is a 16-byte FIFO register that stores serial receive data. The SCIF completes the reception of one byte of serial data by moving the received data from the receive shift register (SCRSR) into SCFRDR for storage. Continuous reception is possible until 16 bytes are stored. The CPU can read but not write to SCFRDR. If data is read when there is no receive data in the SCFRDR, the value is undefined. When SCFRDR is full of receive data, subsequent serial data is lost. SCFRDR is initialized to an undefined value by a power-on reset. #### 22.3.3 Transmit Shift Register (SCTSR) SCTSR transmits serial data. The SCIF loads transmit data from the transmit FIFO data register (SCFTDR) into SCTSR, then transmits the data serially from the TxD pin, LSB (bit 0) first. After transmitting one data byte, the SCIF automatically loads the next transmit data from SCFTDR into SCTSR and starts transmitting again. The CPU cannot read or write to SCTSR directly. #### 22.3.4 Transmit FIFO Data Register (SCFTDR) SCFTDR is a 16-byte FIFO register that stores data for serial transmission. When the SCIF detects that the transmit shift register (SCTSR) is empty, it moves transmit data written in the SCFTDR into SCTSR and starts serial transmission. Continuous serial transmission is performed until there is no transmit data left in SCFTDR. The CPU can write to SCFTDR at all times. When SCFTDR is full of transmit data (16 bytes), no more data can be written. If writing of new data is attempted, the data is ignored. SCFTDR is initialized to an undefined value by a power-on reset. ## 22.3.5 Serial Mode Register (SCSMR) SCSMR specifies the SCIF serial communication format and selects the clock source for the baud rate generator. The CPU can always read and write to SCSMR. SCSMR is initialized to H'0000 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|-----|-----|-----|-----|------|---|-----|-------| | | - | - | - | - | - | - | - | - | C/Ā | CHR | PE | O/Ē | STOP | - | CKS | [1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | R/W | R | R/W | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | C/A | 0 | R/W | Communication Mode | | | | | | Selects whether the SCIF operates in asynchronous or clocked synchronous mode. | | | | | | 0: Asynchronous mode | | | | | | 1: Clocked synchronous mode | | 6 | CHR | 0 | R/W | Character Length | | | | | | Selects 7-bit or 8-bit data length in asynchronous mode. In the clocked synchronous mode, the data length is always 8 bits, regardless of the CHR setting. | | | | | | 0: 8-bit data | | | | | | 1: 7-bit data* | | | | | | Note: * When 7-bit data is selected, the MSB (bit 7) of the transmit FIFO data register is not transmitted. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | PE | 0 | R/W | Parity Enable | | | | | | Selects whether to add a parity bit to transmit data and to check the parity of receive data, in asynchronous mode. In clocked synchronous mode, a parity bit is neither added nor checked, regardless of the PE setting. | | | | | | 0: Parity bit not added or checked | | | | | | 1: Parity bit added and checked* | | | | | | Note: * When PE is set to 1, an even or odd parity bit is added to transmit data, depending on the parity mode (O/E) setting. Receive data parity is checked according to the even/odd (O/E) mode setting. | | 4 | O/E | 0 | R/W | Parity mode | | | | | | Selects even or odd parity when parity bits are added and checked. The O/E setting is used only in asynchronous mode and only when the parity enable bit (PE) is set to 1 to enable parity addition and checking. The O/E setting is ignored in clocked synchronous mode, or in asynchronous mode when parity addition and checking is disabled. 0: Even parity*1 | | | | | | 1: Odd parity* <sup>2</sup> | | | | | | Notes:1. If even parity is selected, the parity bit is added to transmit data to make an even number of 1s in the transmitted character and parity bit combined. Receive data is checked to see if it has an even number of 1s in the received character and parity bit combined. | | | | | | <ol> <li>If odd parity is selected, the parity bit is added<br/>to transmit data to make an odd number of 1s<br/>in the transmitted character and parity bit<br/>combined. Receive data is checked to see if it<br/>has an odd number of 1s in the received<br/>character and parity bit combined.</li> </ol> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | STOP | 0 | R/W | Stop Bit Length | | | | | | Selects one or two bits as the stop bit length in asynchronous mode. This setting is used only in asynchronous mode. It is ignored in clocked synchronous mode because no stop bits are added. | | | | | | When receiving, only the first stop bit is checked, regardless of the STOP bit setting. If the second stop bit is 1, it is treated as a stop bit, but if the second stop bit is 0, it is treated as the start bit of the next incoming character. | | | | | | <ol> <li>One stop bit<br/>When transmitting, a single 1-bit is added at the end<br/>of each transmitted character.</li> </ol> | | | | | | 1: Two stop bits When transmitting, two 1 bits are added at the end of each transmitted character. | | 2 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 1, 0 | CKS[1:0] | 00 | R/W | Clock Select | | | | | | Select the internal clock source of the on-chip baud rate generator. For further information on the clock source, bit rate register settings, and baud rate, see section 22.3.8, Bit Rate Register (SCBRR). | | | | | | 00: Рф | | | | | | 01: Pø/4 | | | | | | 10: P <sub>0</sub> /16 | | | | | | 11: P <sub>\$\phi\$</sub> /64 | | | | | | Note: Pφ: Peripheral clock | ## 22.3.6 Serial Control Register (SCSCR) SCSCR operates the SCIF transmitter/receiver, enables/disables interrupt requests, and selects the transmit/receive clock source. The CPU can always read and write to SCSCR. SCSCR is initialized to H'0000 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|-----|-----|-----|-----|------|---|-----|-------| | | - | - | - | - | - | - | - | - | TIE | RIE | TE | RE | REIE | - | CKE | [1:0] | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ | R | R | R | R | R | R | R | R | R/W | R/M | R/M | R/M | R/M | R | R/M | R/M | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | TIE | 0 | R/W | Transmit Interrupt Enable | | | | | | Enables or disables the transmit-FIFO-data-empty interrupt (TXI) requested when the serial transmit data is transferred from the transmit FIFO data register (SCFTDR) to the transmit shift register (SCTSR), when the quantity of data in the transmit FIFO register becomes less than the specified number of transmission triggers, and when the TDFE flag in the serial status register (SCFSR) is set to 1. | | | | | | <ol><li>Transmit-FIFO-data-empty interrupt request (TXI) is disabled</li></ol> | | | | | | 1: Transmit-FIFO-data-empty interrupt request (TXI) is enabled* | | | | | | Note: * The TXI interrupt request can be cleared by writing a greater quantity of transmit data than the specified transmission trigger number to SCFTDR and by clearing TDFE to 0 after reading 1 from TDFE, or can be cleared by clearing TIE to 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | RIE | 0 | R/W | Receive Interrupt Enable | | | | | | Enables or disables the receive FIFO data full (RXI) interrupts requested when the RDF flag or DR flag in serial status register (SCFSR) is set to1, receive-error (ERI) interrupts requested when the ER flag in SCFSR is set to1, and break (BRI) interrupts requested when the BRK flag in SCFSR or the ORER flag in line status register (SCLSR) is set to1. | | | | | | <ol> <li>Receive FIFO data full interrupt (RXI), receive-error<br/>interrupt (ERI), and break interrupt (BRI) requests<br/>are disabled</li> </ol> | | | | | | <ol> <li>Receive FIFO data full interrupt (RXI), receive-error<br/>interrupt (ERI), and break interrupt (BRI) requests<br/>are enabled*</li> </ol> | | | | | | Note: * RXI interrupt requests can be cleared by reading the DR or RDF flag after it has been set to 1, then clearing the flag to 0, or by clearing RIE to 0. ERI or BRI interrupt requests can be cleared by reading the ER, BR or ORER flag after it has been set to 1, then clearing the flag to 0, or by clearing RIE and REIE to 0. | | 5 | TE | 0 | R/W | Transmit Enable | | | | | | Enables or disables the serial transmitter. | | | | | | 0: Transmitter disabled | | | | | | 1: Transmitter enabled* | | | | | | Note: * Serial transmission starts after writing of transmit data into SCFTDR. Select the transmit format in SCSMR and SCFCR and reset the transmit FIFO before setting TE to 1. | | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 4 | RE | 0 | R/W | Receive Enable | | | | | | | | | Enables or disables the serial receiver. | | | | | | | | | 0: Receiver disabled*1 | | | | | | | | | 1: Receiver enabled*2 | | | | | | | | | Notes:1. Clearing RE to 0 does not affect the receive flags (DR, ER, BRK, RDF, FER, PER, and ORER). These flags retain their previous values. | | | | | | | | | <ol> <li>Serial reception starts when a start bit is<br/>detected in asynchronous mode, or<br/>synchronous clock is detected in clocked<br/>synchronous mode. Select the receive format<br/>in SCSMR and SCFCR and reset the receive<br/>FIFO before setting RE to 1.</li> </ol> | | | | | 3 | REIE | 0 | R/W | Receive Error Interrupt Enable | | | | | | | | | Enables or disables the receive-error (ERI) interrupts and break (BRI) interrupts. The setting of REIE bit is valid only when RIE bit is set to 0. | | | | | | | | | Receive-error interrupt (ERI) and break interrupt (BRI) requests are disabled | | | | | | | | | Receive-error interrupt (ERI) and break interrupt (BRI) requests are enabled* | | | | | | | | | Note: * ERI or BRI interrupt requests can be cleared by reading the ER, BR or ORER flag after it has been set to 1, then clearing the flag to 0, or by clearing RIE and REIE to 0. Even if RIE is set to 0, when REIE is set to 1, ERI or BRI interrupt requests are enabled. Set so If SCIF wants to inform INTC of ERI or BRI interrupt requests during DMA transfer. | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 1, 0 | CKE[1:0] | 00 | R/W | Clock Enable | | | | | | Select the SCIF clock source and enable or disable clock output from the SCK pin. Depending on CKE[1:0], the SCK pin can be used for serial clock output or serial clock input. If serial clock output is set in clocked synchronous mode, set the $C/\overline{A}$ bit in SCSMR to 1, and then set CKE[1:0]. | | | | | | Asynchronous mode | | | | | | 00: Internal clock, SCK pin used for input pin (input signal is ignored) | | | | | | 01: Internal clock, SCK pin used for clock output (The output clock frequency is 16 times the bit rate.) | | | | | | 10: External clock, SCK pin used for clock input (The input clock frequency is 16 times the bit rate.) | | | | | | 11: Setting prohibited | | | | | | Clocked synchronous mode | | | | | | 00: Internal clock, SCK pin used for serial clock output | | | | | | 01: Internal clock, SCK pin used for serial clock output | | | | | | 10: External clock, SCK pin used for serial clock input | | - | | | | 11: Setting prohibited | ## 22.3.7 Serial Status Register (SCFSR) SCFSR is a 16-bit register. The upper 8 bits indicate the number of receive errors in the receive FIFO data register, and the lower 8 bits indicate the status flag indicating SCIF operating state. The CPU can always read and write to SCFSR, but cannot write 1 to the status flags (ER, TEND, TDFE, BRK, RDF, and DR). These flags can be cleared to 0 only if they have first been read (after being set to 1). Bits 3 (FER) and 2 (PER) are read-only bits that cannot be written. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-----|-------|----|----|-----|-------|---|--------|--------|--------|--------|-----|-----|--------|--------| | | | PER | [3:0] | | | FER | [3:0] | | ER | TEND | TDFE | BRK | FER | PER | RDF | DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R | R | R/(W)* | R/(W)* | Note: \* Only 0 can be written to clear the flag after 1 is read. | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 12 | PER[3:0] | 0000 | R | Number of Parity Errors | | | | | | Indicate the quantity of data including a parity error in the receive data stored in the receive FIFO data register (SCFRDR). The value indicated by bits 15 to 12 after the ER bit in SCFSR is set, represents the number of parity errors in SCFRDR. When parity errors have occurred in all 16-byte receive data in SCFRDR, PER[3:0] shows 0000. | | 11 to 8 | FER[3:0] | 0000 | R | Number of Framing Errors | | | | | | Indicate the quantity of data including a framing error in the receive data stored in SCFRDR. The value indicated by bits 11 to 8 after the ER bit in SCFSR is set, represents the number of framing errors in SCFRDR. When framing errors have occurred in all 16-byte receive data in SCFRDR, FER[3:0] shows 0000. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | ER | 0 | R/(W)* | Receive Error | | | | | | Indicates the occurrence of a framing error, or of a parity error when receiving data that includes parity.*1 | | | | | | 0: Receiving is in progress or has ended normally | | | | | | [Clearing conditions] | | | | | | ER is cleared to 0 a power-on reset | | | | | | <ul> <li>ER is cleared to 0 when the chip is when 0 is<br/>written after 1 is read from ER</li> </ul> | | | | | | 1: A framing error or parity error has occurred. | | | | | | [Setting conditions] | | | | | | <ul> <li>ER is set to 1 when the stop bit is 0 after checking<br/>whether or not the last stop bit of the received<br/>data is 1 at the end of one data receive<br/>operation*<sup>2</sup></li> </ul> | | | | | | • ER is set to 1 when the total number of 1s in the | | | | | | receive data plus parity bit does not match the | | | | | | even/odd parity specified by the O/E bit in SCSMR | | | | | | Notes: 1. Clearing the RE bit to 0 in SCSCR does not affect the ER bit, which retains its previous value. Even if a receive error occurs, the receive data is transferred to SCFRDR and the receive operation is continued. Whether or not the data read from SCFRDR includes a receive error can be detected by the FER and PER bits in SCFSR. | | | | | | <ol><li>In two stop bits mode, only the first stop<br/>bit is checked; the second stop bit is not<br/>checked.</li></ol> | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | TEND | 1 | R/(W)* | Transmit End | | | | | | Indicates that when the last bit of a serial character was transmitted, SCFTDR did not contain valid data, so transmission has ended. | | | | | | 0: Transmission is in progress | | | | | | [Clearing condition] | | | | | | <ul> <li>TEND is cleared to 0 when 0 is written after 1 is<br/>read from TEND after transmit data is written in<br/>SCFTDR*<sup>1</sup></li> </ul> | | | | | | 1: End of transmission | | | | | | [Setting conditions] | | | | | | <ul> <li>TEND is set to 1 when the chip is a power-on reset</li> </ul> | | | | | | TEND is set to 1 when TE is cleared to 0 in the serial control register (SCSCR) | | | | | | TEND is set to 1 when SCFTDR does not contain<br>receive data when the last bit of a one-byte serial<br>character is transmitted | | | | | | Note: 1. Do not use this bit as a transmit end flag when the DMAC writes data to SCFTDR due to a TXI interrupt request. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | TDFE | 1 | R/(W)* | Transmit FIFO Data Empty | | | | | | Indicates that data has been transferred from the transmit FIFO data register (SCFTDR) to the transmit shift register (SCTSR), the quantity of data in SCFTDR has become less than the transmission trigger number specified by the TTRG[1:0] bits in the FIFO control register (SCFCR), and writing of transmit data to SCFTDR is enabled. | | | | | | The quantity of transmit data written to SCFTDR is greater than the specified transmission trigger number | | | | | | [Clearing conditions] | | | | | | <ul> <li>TDFE is cleared to 0 when data exceeding the specified transmission trigger number is written to SCFTDR after 1 is read from TDFE and then 0 is written</li> <li>TDFE is cleared to 0 when DMAC is activated by transmit FIFO data empty interrupt (TXI) and write data exceeding the specified transmission trigger</li> </ul> | | | | | | number to SCFTDR 1: The quantity of transmit data in SCFTDR is less than or equal to the specified transmission trigger number* <sup>1</sup> | | | | | | [Setting conditions] | | | | | | TDFE is set to 1 by a power-on reset | | | | | | TDFE is set to 1 when the quantity of transmit | | | | | | data in SCFTDR becomes less than or equal to<br>the specified transmission trigger number as a<br>result of transmission | | | | | | Note: 1. Since SCFTDR is a 16-byte FIFO register, the maximum quantity of data that can be written when TDFE is 1 is "16 minus the specified transmission trigger number". If an attempt is made to write additional data, the data is ignored. The quantity of data in SCFTDR is indicated by the upper 8 bits of SCFDR. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | BRK | 0 | R/(W)* | Break Detection | | | | | | Indicates that a break signal has been detected in receive data. | | | | | | 0: No break signal received | | | | | | [Clearing conditions] | | | | | | <ul> <li>BRK is cleared to 0 when the chip is a power-on reset</li> </ul> | | | | | | BRK is cleared to 0 when software reads BRK after it has been set to 1, then writes 0 to BRK | | | | | | 1: Break signal received*1 | | | | | | [Setting condition] | | | | | | <ul> <li>BRK is set to 1 when data including a framing<br/>error is received, and a framing error occurs with<br/>space 0 in the subsequent receive data</li> </ul> | | | | | | Note: 1. When a break is detected, transfer of the receive data (H'00) to SCFRDR stops after detection. When the break ends and the receive signal becomes mark 1, the transfer of receive data resumes. | | 3 | FER | 0 | R | Framing Error Indication | | | | | | Indicates a framing error in the data read from the next receive FIFO data register (SCFRDR) in asynchronous mode. | | | | | | 0: No receive framing error occurred in the next data read from SCFRDR | | | | | | [Clearing conditions] | | | | | | <ul> <li>FER is cleared to 0 when the chip undergoes a<br/>power-on reset</li> </ul> | | | | | | <ul> <li>FER is cleared to 0 when no framing error is<br/>present in the next data read from SCFRDR</li> </ul> | | | | | | <ol> <li>A receive framing error occurred in the next data<br/>read from SCFRDR.</li> </ol> | | | | | | [Setting condition] | | | | | | FER is set to 1 when a framing error is present in<br>the next data read from SCFRDR | Jun 21, 2011 | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------------------------------------------------------| | 2 | PER | 0 | R | Parity Error Indication | | | | | | Indicates a parity error in the data read from the next receive FIFO data register (SCFRDR) in asynchronous mode. | | | | | | No receive parity error occurred in the next data read from SCFRDR | | | | | | [Clearing conditions] | | | | | | <ul> <li>PER is cleared to 0 when the chip undergoes a<br/>power-on reset</li> </ul> | | | | | | <ul> <li>PER is cleared to 0 when no parity error is present<br/>in the next data read from SCFRDR</li> </ul> | | | | | | A receive parity error occurred in the next data read from SCFRDR | | | | | | [Setting condition] | | | | | | PER is set to 1 when a parity error is present in | | | | | | the next data read from SCFRDR | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | RDF | 0 | R/(W)* | Receive FIFO Data Full | | | | | | Indicates that receive data has been transferred to the receive FIFO data register (SCFRDR), and the quantity of data in SCFRDR has become more than the receive trigger number specified by the RTRG[1:0] bits in the FIFO control register (SCFCR). | | | | | | 0: The quantity of transmit data written to SCFRDR is less than the specified receive trigger number | | | | | | [Clearing conditions] | | | | | | RDF is cleared to 0 by a power-on reset, standby mode | | | | | | <ul> <li>RDF is cleared to 0 when the SCFRDR is read<br/>until the quantity of receive data in SCFRDR<br/>becomes less than the specified receive trigger<br/>number after 1 is read from RDF and then 0 is<br/>written</li> </ul> | | | | | | RDF is cleared to 0 when DMAC is activated by receive FIFO data full interrupt (RXI) and read SCFRDR until the quantity of receive data in SCFRDR becomes less than the specified receive trigger number 1: The quantity of receive data in SCFRDR is more | | | | | | than the specified receive trigger number | | | | | | <ul><li>[Setting condition]</li><li>RDF is set to 1 when a quantity of receive data</li></ul> | | | | | | more than the specified receive trigger number is stored in SCFRDR* <sup>1</sup> | | | | | | Note: 1. As SCFTDR is a 16-byte FIFO register, the maximum quantity of data that can be read when RDF is 1 becomes the specified receive trigger number. If an attempt is made to read after all the data in SCFRDR has been read, the data is undefined. The quantity of receive data in SCFRDR is indicated by the lower 8 bits of SCFDR. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | DR | 0 | R/(W)* | Receive Data Ready | | | | | | Indicates that the quantity of data in the receive FIFO data register (SCFRDR) is less than the specified receive trigger number, and that the next data has not yet been received after the elapse of 15 ETU from the last stop bit in asynchronous mode. In clocked synchronous mode, this bit is not set to 1. | | | | | | 0: Receiving is in progress, or no receive data remains in SCFRDR after receiving ended normally | | | | | | [Clearing conditions] | | | | | | <ul> <li>DR is cleared to 0 when the chip undergoes a<br/>power-on reset</li> </ul> | | | | | | <ul> <li>DR is cleared to 0 when all receive data are read<br/>after 1 is read from DR and then 0 is written.</li> </ul> | | | | | | <ul> <li>DR is cleared to 0 when all receive data are read<br/>after DMAC is activated by receive FIFO data full<br/>interrupt (RXI).</li> </ul> | | | | | | 1: Next receive data has not been received | | | | | | [Setting condition] | | | | | | <ul> <li>DR is set to 1 when SCFRDR contains less data<br/>than the specified receive trigger number, and the<br/>next data has not yet been received after the<br/>elapse of 15 ETU from the last stop bit.*1</li> </ul> | | | | | | Note: 1. This is equivalent to 1.5 frames with the 8-bit, 1-stop-bit format. (ETU: elementary time unit) | Note: \* Only 0 can be written to clear the flag after 1 is read. ### 22.3.8 Bit Rate Register (SCBRR) SCBRR is an 8-bit register that, together with the baud rate generator clock source selected by the CKS[1:0] bits in the serial mode register (SCSMR), determines the serial transmit/receive bit rate. The CPU can always read and write to SCBRR. SCBRR is initialized to H'FF by a power-on reset. Each channel has independent baud rate generator control, so different values can be set in three channels. The SCBRR setting is calculated as follows: • Asynchronous mode: $$N = \frac{P\phi}{64 \times 2^{2n-1} \times B} \times 10^6 - 1$$ • Clocked synchronous mode: $$N = \frac{P\phi}{8 \times 2^{2n-1} \times B} \times 10^6 - 1$$ B: Bit rate (bits/s) N: SCBRR setting for baud rate generator $(0 \le N \le 255)$ (The setting must satisfy the electrical characteristics.) Pφ: Operating frequency for peripheral modules (MHz) n: Baud rate generator clock source (n = 0, 1, 2, 3) (for the clock sources and values of n, see table 22.3.) Table 22.3 SCSMR Settings | | | SCSMR Settings | | | | | | | | |---|--------------|----------------|--------|---|--|--|--|--|--| | n | Clock Source | CKS[1] | CKS[0] | | | | | | | | 0 | Рф | 0 | 0 | | | | | | | | 1 | Рф/4 | 0 | 1 | | | | | | | | 2 | Pø/16 | 1 | 0 | | | | | | | | 3 | Ph/64 | 1 | 1 | _ | | | | | | The bit rate error in asynchronous is given by the following formula: Error (%) = $$\left\{ \frac{P\phi \times 10^6}{(N+1) \times B \times 64 \times 2^{2n-1}} - 1 \right\} \times 100$$ Table 22.4 lists examples of SCBRR settings in asynchronous mode, and table 22.5 lists examples of SCBRR settings in clocked synchronous mode. D# (MH2) Table 22.4 Bit Rates and SCBRR Settings (Asynchronous Mode) | | | Pφ (MHZ) | | | | | | | | | | | | |------------------|---|----------|-----------|---|-----|-----------|-------|-----|-----------|--|--|--|--| | | | 5 | ; | | 6 | | 6.144 | | | | | | | | Bit Rate (bit/s) | n | N | Error (%) | n | N | Error (%) | n | N | Error (%) | | | | | | 110 | 2 | 88 | -0.25 | 2 | 106 | -0.44 | 2 | 108 | 0.08 | | | | | | 150 | 2 | 64 | 0.16 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | | | | | | 300 | 1 | 129 | 0.16 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | | | | | | 600 | 1 | 64 | 0.16 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | | | | | | 1200 | 0 | 129 | 0.16 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | | | | | | 2400 | 0 | 64 | 0.16 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | | | | | | 4800 | 0 | 32 | -1.36 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | | | | | | 9600 | 0 | 15 | 1.73 | 0 | 19 | -2.34 | 0 | 19 | 0.00 | | | | | | 19200 | 0 | 7 | 1.73 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | | | | | | 31250 | 0 | 4 | 0.00 | 0 | 5 | 0.00 | 0 | 5 | 2.40 | | | | | | 38400 | 0 | 3 | 1.73 | 0 | 4 | -2.34 | 0 | 4 | 0.00 | | | | | # Pφ (MHz) | | | 7.37 | 728 | | 8 | | | 9.8304 | | | | |------------------|---|------|-----------|---|-----|-----------|---|--------|-----------|--|--| | Bit Rate (bit/s) | n | N | Error (%) | n | N | Error (%) | n | N | Error (%) | | | | 110 | 2 | 130 | -0.07 | 2 | 141 | 0.03 | 2 | 174 | -0.26 | | | | 150 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | 2 | 127 | 0.00 | | | | 300 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | 1 | 255 | 0.00 | | | | 600 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | 1 | 127 | 0.00 | | | | 1200 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | 0 | 255 | 0.00 | | | | 2400 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | 0 | 127 | 0.00 | | | | 4800 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | 0 | 63 | 0.00 | | | | 9600 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | 0 | 31 | 0.00 | | | | 19200 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | 0 | 15 | 0.00 | | | | 31250 | 0 | 6 | 5.33 | 0 | 7 | 0.00 | 0 | 9 | -1.70 | | | | 38400 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | 0 | 7 | 0.00 | | | # Pφ (MHz) | | <u> </u> | | | | | | | | | | | | | |----|--------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 10 | | | | 12 | | 12.288 | | | 14.7456 | | | | | | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | | 2 | 177 | -0.25 | 2 | 212 | 0.03 | 2 | 217 | 0.08 | 3 | 64 | 0.70 | | | | 2 | 129 | 0.16 | 2 | 155 | 0.16 | 2 | 159 | 0.00 | 2 | 191 | 0.00 | | | | 2 | 64 | 0.16 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | 2 | 95 | 0.00 | | | | 1 | 129 | 0.16 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | 1 | 191 | 0.00 | | | | 1 | 64 | 0.16 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | 1 | 95 | 0.00 | | | | 0 | 129 | 0.16 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | 0 | 191 | 0.00 | | | | 0 | 64 | 0.16 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | 0 | 95 | 0.00 | | | | 0 | 32 | -1.36 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | 0 | 47 | 0.00 | | | | 0 | 15 | 1.73 | 0 | 19 | 0.16 | 0 | 19 | 0.00 | 0 | 23 | 0.00 | | | | 0 | 9 | 0.00 | 0 | 11 | 0.00 | 0 | 11 | 2.40 | 0 | 14 | -1.70 | | | | 0 | 7 | 1.73 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | 0 | 11 | 0.00 | | | | | 2<br>2<br>2<br>1<br>1<br>0<br>0<br>0 | n N 2 177 2 129 2 64 1 129 1 64 0 129 0 64 0 32 0 15 0 9 | n N (%) 2 177 -0.25 2 129 0.16 2 64 0.16 1 129 0.16 1 64 0.16 0 129 0.16 0 64 0.16 0 32 -1.36 0 15 1.73 0 9 0.00 | n N Error (%) n 2 177 -0.25 2 2 129 0.16 2 2 64 0.16 2 1 129 0.16 1 0 129 0.16 0 0 64 0.16 0 0 32 -1.36 0 0 15 1.73 0 0 9 0.00 0 | n N Error (%) n N 2 177 -0.25 2 212 2 129 0.16 2 155 2 64 0.16 2 77 1 129 0.16 1 155 1 64 0.16 1 77 0 129 0.16 0 155 0 64 0.16 0 77 0 32 -1.36 0 38 0 15 1.73 0 19 0 9 0.00 0 11 | n K Error (%) n N Error (%) 2 177 -0.25 2 212 0.03 2 129 0.16 2 155 0.16 2 64 0.16 2 77 0.16 1 129 0.16 1 155 0.16 1 64 0.16 1 77 0.16 0 129 0.16 0 155 0.16 0 64 0.16 0 77 0.16 0 32 -1.36 0 38 0.16 0 15 1.73 0 19 0.16 0 9 0.00 0 11 0.00 | n N Error (%) n N Error (%) n 2 177 -0.25 2 212 0.03 2 2 129 0.16 2 155 0.16 2 2 64 0.16 2 77 0.16 2 1 129 0.16 1 155 0.16 1 1 64 0.16 1 77 0.16 1 0 129 0.16 0 155 0.16 0 0 64 0.16 0 77 0.16 0 0 32 -1.36 0 38 0.16 0 0 15 1.73 0 19 0.16 0 0 9 0.00 0 11 0.00 0 | n N Error (%) n N Error (%) n N 2 177 -0.25 2 212 0.03 2 217 2 129 0.16 2 155 0.16 2 159 2 64 0.16 2 77 0.16 2 79 1 129 0.16 1 155 0.16 1 159 1 64 0.16 1 77 0.16 1 79 0 129 0.16 0 155 0.16 0 159 0 64 0.16 0 77 0.16 0 79 0 32 -1.36 0 38 0.16 0 39 0 15 1.73 0 19 0.16 0 19 0 9 0.00 0 11 0.00 0 11 | n N Error (%) n N Error (%) n N Error (%) 2 177 -0.25 2 212 0.03 2 217 0.08 2 129 0.16 2 155 0.16 2 159 0.00 2 64 0.16 2 77 0.16 2 79 0.00 1 129 0.16 1 155 0.16 1 159 0.00 0 129 0.16 0 155 0.16 0 159 0.00 0 64 0.16 0 77 0.16 0 79 0.00 0 32 -1.36 0 38 0.16 0 39 0.00 0 15 1.73 0 19 0.16 0 19 0.00 0 9 0.00 0 11 0.00 0 11 2.40 | n N Error (%) n N Error (%) n N Error (%) n N Error (%) n 2 177 -0.25 2 212 0.03 2 217 0.08 3 2 129 0.16 2 155 0.16 2 159 0.00 2 2 64 0.16 2 77 0.16 2 79 0.00 2 1 129 0.16 1 155 0.16 1 159 0.00 1 0 129 0.16 0 155 0.16 0 159 0.00 0 0 64 0.16 0 77 0.16 0 79 0.00 0 0 32 -1.36 0 38 0.16 0 39 0.00 0 0 15 1.73 0 19 0.16 0 19 0.0 | n N Error (%) n N Error (%) n N Error (%) n N Error (%) n N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N N 64 A A 64 A A 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 1 1 1 1 | | | # Pφ (MHz) | | 16 | | | | 19.6608 | | | 20 | | | 24 | | | |------------------|----|-----|--------------|---|---------|--------------|---|-----|--------------|---|-----|--------------|--| | Bit Rate (bit/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 3 | 70 | 0.03 | 3 | 86 | 0.31 | 3 | 88 | -0.25 | 3 | 106 | -0.44 | | | 150 | 2 | 207 | 0.16 | 2 | 255 | 0.00 | 3 | 64 | 0.16 | 3 | 77 | 0.16 | | | 300 | 2 | 103 | 0.16 | 2 | 127 | 0.00 | 2 | 129 | 0.16 | 2 | 155 | 0.16 | | | 600 | 1 | 207 | 0.16 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | 2 | 77 | 0.16 | | | 1200 | 1 | 103 | 0.16 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | 1 | 155 | 0.16 | | | 2400 | 0 | 207 | 0.16 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | 1 | 77 | 0.16 | | | 4800 | 0 | 103 | 0.16 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | 0 | 155 | 0.16 | | | 9600 | 0 | 51 | 0.16 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | 0 | 77 | 0.16 | | | 19200 | 0 | 25 | 0.16 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | 0 | 38 | 0.16 | | | 31250 | 0 | 15 | 0.00 | 0 | 19 | -1.70 | 0 | 19 | 0.00 | 0 | 23 | 0.00 | | | 38400 | 0 | 12 | 0.16 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | 0 | 19 | -2.34 | | ### Pφ (MHz) | 24.576 | | | | | 28.7 | , | | 30 | | 33 | | | |------------------|---|-----|--------------|---|------|--------------|---|-----|--------------|----|-----|--------------| | Bit Rate (bit/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 3 | 108 | 0.08 | 3 | 126 | 0.31 | 3 | 132 | 0.13 | 3 | 145 | 0.33 | | 150 | 3 | 79 | 0.00 | 3 | 92 | 0.46 | 3 | 97 | -0.35 | 3 | 106 | 0.39 | | 300 | 2 | 159 | 0.00 | 2 | 186 | -0.08 | 2 | 194 | 0.16 | 2 | 214 | -0.07 | | 600 | 2 | 79 | 0.00 | 2 | 92 | 0.46 | 2 | 97 | -0.35 | 2 | 106 | 0.39 | | 1200 | 1 | 159 | 0.00 | 1 | 186 | -0.08 | 1 | 194 | 0.16 | 1 | 214 | -0.07 | | 2400 | 1 | 79 | 0.00 | 1 | 92 | 0.46 | 1 | 97 | -0.35 | 1 | 106 | 0.39 | | 4800 | 0 | 159 | 0.00 | 0 | 186 | -0.08 | 0 | 194 | -1.36 | 0 | 214 | -0.07 | | 9600 | 0 | 79 | 0.00 | 0 | 92 | 0.46 | 0 | 97 | -0.35 | 0 | 106 | 0.39 | | 19200 | 0 | 39 | 0.00 | 0 | 46 | -0.61 | 0 | 48 | -0.35 | 0 | 53 | -0.54 | | 31250 | 0 | 24 | -1.70 | 0 | 28 | -1.03 | 0 | 29 | 0.00 | 0 | 32 | 0.00 | | 38400 | 0 | 19 | 0.00 | 0 | 22 | 1.55 | 0 | 23 | 1.73 | 0 | 26 | -0.54 | | | | Рф (МН | z) | |---------------------|---|--------|--------------| | | | 50 | | | Bit Rate<br>(bit/s) | n | N | Error<br>(%) | | 110 | 3 | 221 | -0.02 | | 150 | 3 | 162 | -0.15 | | 300 | 3 | 80 | 0.47 | | 600 | 2 | 162 | -0.15 | | 1200 | 2 | 80 | 0.47 | | 2400 | 1 | 162 | -0.15 | | 4800 | 1 | 80 | 0.47 | | 9600 | 0 | 162 | -0.15 | | 19200 | 0 | 80 | 0.47 | | 31250 | 0 | 49 | 0.00 | | 38400 | 0 | 40 | -0.76 | Note: Settings with an error of 1% or less are recommended. Table 22.5 Bit Rates and SCBRR Settings (Clocked Synchronous Mode) | Bit Rate | | | | | | | Рф | (MHz) | | | | | | | |----------|---|-----|---|-----|----|-----|------|-------|----|-----|----|-----|----|-----| | (bit/s) | 5 | | 8 | | 16 | | 28.7 | , | 30 | | 33 | | 50 | | | | n | N | n | N | n | N | n | N | n | N | n | N | n | N | | 110 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | 250 | 3 | 77 | 3 | 124 | 3 | 249 | _ | _ | _ | | _ | _ | _ | | | 500 | 3 | 38 | 2 | 249 | 3 | 124 | 3 | 223 | 3 | 233 | 3 | 255 | _ | | | 1k | 2 | 77 | 2 | 124 | 2 | 249 | 3 | 111 | 3 | 116 | 3 | 125 | 3 | 194 | | 2.5k | 1 | 124 | 1 | 199 | 2 | 99 | 2 | 178 | 2 | 187 | 2 | 200 | 3 | 77 | | 5k | 0 | 249 | 1 | 99 | 1 | 199 | 2 | 89 | 2 | 93 | 2 | 100 | 2 | 155 | | 10k | 0 | 124 | 0 | 199 | 1 | 99 | 1 | 178 | 1 | 187 | 1 | 200 | 2 | 77 | | 25k | 0 | 49 | 0 | 79 | 0 | 159 | 1 | 71 | 1 | 74 | 1 | 80 | 1 | 124 | | 50k | 0 | 24 | 0 | 39 | 0 | 79 | 0 | 143 | 0 | 149 | 0 | 160 | 0 | 249 | | 100k | _ | _ | 0 | 19 | 0 | 39 | 0 | 71 | 0 | 74 | 0 | 80 | 0 | 124 | | 250k | 0 | 4 | 0 | 7 | 0 | 15 | _ | _ | 0 | 29 | 0 | 31 | 0 | 49 | | 500k | _ | _ | 0 | 3 | 0 | 7 | _ | _ | 0 | 14 | 0 | 15 | 0 | 24 | | 1M | _ | _ | 0 | 1 | 0 | 3 | _ | _ | _ | _ | 0 | 7 | 0 | 12 | | 2M | | | 0 | 0* | 0 | 1 | _ | _ | _ | _ | _ | _ | _ | | #### [Legend] Blank: No setting possible —: Setting possible, but error occurs \*: Continuous transmission/reception not possible Table 22.6 indicates the maximum bit rates in asynchronous mode when the baud rate generator is used. Table 22.7 lists the maximum bit rates in asynchronous mode when the external clock input is used. Table 22.8 lists the maximum bit rates in clocked synchronous mode when the external clock input is used (when $t_{Seve} = 12t_{Deve}^*$ ). Note: \* Make sure that the electrical characteristics of this LSI and that of a connected LSI are satisfied. Table 22.6 Maximum Bit Rates for Various Frequencies with Baud Rate Generator (Asynchronous Mode) | | | | Settings | |----------|---------------------------|---|----------| | Pφ (MHz) | Maximum Bit Rate (bits/s) | n | N | | 5 | 156250 | 0 | 0 | | 8 | 250000 | 0 | 0 | | 9.8304 | 307200 | 0 | 0 | | 12 | 375000 | 0 | 0 | | 14.7456 | 460800 | 0 | 0 | | 16 | 500000 | 0 | 0 | | 19.6608 | 614400 | 0 | 0 | | 20 | 625000 | 0 | 0 | | 24 | 750000 | 0 | 0 | | 24.576 | 768000 | 0 | 0 | | 28.7 | 896875 | 0 | 0 | | 30 | 937500 | 0 | 0 | | 33 | 1031250 | 0 | 0 | | 50 | 1562500 | 0 | 0 | Table 22.7 Maximum Bit Rates with External Clock Input (Asynchronous Mode) | Pφ (MHz) | External Input Clock (MHz) | Maximum Bit Rate (bits/s) | |----------|----------------------------|---------------------------| | 5 | 1.2500 | 78125 | | 8 | 2.0000 | 125000 | | 9.8304 | 2.4576 | 153600 | | 12 | 3.0000 | 187500 | | 14.7456 | 3.6864 | 230400 | | 16 | 4.0000 | 250000 | | 19.6608 | 4.9152 | 307200 | | 20 | 5.0000 | 312500 | | 24 | 6.0000 | 375000 | | 24.576 | 6.1440 | 384000 | | 28.7 | 7.1750 | 448436 | | 30 | 7.5000 | 468750 | | 33 | 8.25 | 515625 | | 50 | 12.5 | 781250 | **Maximum Bit Rates with External Clock Input Table 22.8** (Clocked Synchronous Mode, $t_{Scyc} = 12t_{pcyc}$ ) | Pφ (MHz) | External Input Clock (MHz) | Maximum Bit Rate (bits/s) | |----------|----------------------------|---------------------------| | 5 | 0.4166 | 416666.6 | | 8 | 0.6666 | 666666.6 | | 16 | 1.3333 | 1333333.3 | | 24 | 2.0000 | 2000000.0 | | 28.7 | 2.3916 | 2391666.6 | | 30 | 2.5000 | 2500000.0 | | 33 | 2.7500 | 2750000.0 | | 50 | 4.1667 | 4166666.7 | ### 22.3.9 FIFO Control Register (SCFCR) SCFCR resets the quantity of data in the transmit and receive FIFO data registers, sets the trigger data quantity, and contains an enable bit for loop-back testing. SCFCR can always be read and written to by the CPU. It is initialized to H'0000 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|-----|---------|-----|-----|--------|------|--------|-----|-------|-------|------| | | - | - | - | - | - | F | STRG[2: | 0] | RTR | G[1:0] | TTRO | G[1:0] | MCE | TFRST | RFRST | LOOP | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|------------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 11 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 10 to 8 | RSTRG[2:0] | 000 | R/W | RTS Output Active Trigger | | | | | | When the quantity of receive data in receive FIFO data register (SCFRDR) becomes more than the number shown below, RTS signal is set to high. | | | | | | 000: 15 | | | | | | 001: 1 | | | | | | 010: 4 | | | | | | 011: 6 | | | | | | 100: 8 | | | | | | 101: 10 | | | | | | 110: 12 | | | | | | 111: 14 | | Bit | Bit Name | Initial<br>Value | R/W | Description | | |------|------------|------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------| | 7, 6 | RTRG[1:0] | 00 | R/W | Receive FIFO Data Trigger | | | 7,0 | TTTIG[T.0] | 00 | 1000 | Set the quantity of receive d | erial status register (SCFSR).<br>en the quantity of receive<br>IFO register (SCFRDR) is | | | | | | Asynchronous mode | Clocked synchronous mode | | | | | | 00: 1 | 00: 1 | | | | | | 01: 4 | 01: 2 | | | | | | 10: 8 | 10: 8 | | | | | | 11: 14 | 11: 14 | | | | | | ~ | MAC, set the receive trigger other than 1, CPU must | | 5, 4 | TTRG[1:0] | 00 | R/W | Transmit FIFO Data Trigger | , | | | | | | serial status register (SCFS when the quantity of transm data register (SCFTDR) bed trigger number shown below 00: 8 (8)* 01: 4 (12)* 10: 2 (14)* 11: 0 (16)* Note: * Values in parenthes | ster empty (TDFE) flag in the R). The TDFE flag is set to 1 it data in the transmit FIFO comes less than the set v. | | | | | | empty bytes in SCF<br>set to 1. | TDR when the TDFE flag is | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | MCE | 0 | R/W | Modem Control Enable | | | | | | Enables modem control signals $\overline{\text{CTS}}$ and $\overline{\text{RTS}}$ . | | | | | | In clocked synchronous mode, the MCE bit should always be 0. | | | | | | 0: Modem signal disabled* | | | | | | 1: Modem signal enabled | | | | | | Note: * $\overline{\text{CTS}}$ is fixed at active 0 regardless of the input value, and $\overline{\text{RTS}}$ is also fixed at 0. | | 2 | TFRST | 0 | R/W | Transmit FIFO Data Register Reset | | | | | | Disables the transmit data in the transmit FIFO data register and resets the data to the empty state. | | | | | | 0: Reset operation disabled* | | | | | | 1: Reset operation enabled | | | | | | Note: * Reset operation is executed by a power-on reset. | | 1 | RFRST | 0 | R/W | Receive FIFO Data Register Reset | | | | | | Disables the receive data in the receive FIFO data register and resets the data to the empty state. | | | | | | 0: Reset operation disabled* | | | | | | 1: Reset operation enabled | | | | | | Note: * Reset operation is executed by a power-on reset. | | 0 | LOOP | 0 | R/W | Loop-Back Test | | | | | | Internally connects the transmit output pin (TxD) and receive input pin (RxD) and internally connects the $\overline{\text{RTS}}$ pin and $\overline{\text{CTS}}$ pin and enables loop-back testing. | | | | | | 0: Loop back test disabled | | | | | | 1: Loop back test enabled | ### 22.3.10 FIFO Data Count Set Register (SCFDR) SCFDR is a 16-bit register which indicates the quantity of data stored in the transmit FIFO data register (SCFTDR) and the receive FIFO data register (SCFRDR). It indicates the quantity of transmit data in SCFTDR with the upper 8 bits, and the quantity of receive data in SCFRDR with the lower 8 bits. SCFDR can always be read by the CPU. SCFDR is initialized to H'0000 by a power on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|--------|---|---|---|---|---|---|---|--------|---|---| | | - | - | - | | | T[4:0] | | | - | - | - | | | R[4:0] | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 13 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 12 to 8 | T[4:0] | 00000 | R | T4 to T0 bits indicate the quantity of non-transmitted data stored in SCFTDR. H'00 means no transmit data, and H'10 means that SCFTDR is full of transmit data. | | 7 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 to 0 | R[4:0] | 00000 | R | R4 to R0 bits indicate the quantity of receive data stored in SCFRDR. H'00 means no receive data, and H'10 means that SCFRDR full of receive data. | ### 22.3.11 Serial Port Register (SCSPTR) SCSPTR controls input/output and data of pins multiplexed to SCIF function. Bits 7 and 6 can control input/output data of $\overline{RTS}$ pin. Bits 5 and 4 can control input/output data of $\overline{CTS}$ pin. Bits 3 and 2 can control input/output data of SCK pin. Bits 1 and 0 can input data from RxD pin and output data to TxD pin, so they control break of serial transmitting/receiving. The CPU can always read and write to SCSPTR. SCSPTR is initialized to H'0050 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|-------|-------|-------|-------|-------|-------|--------|--------| | | - | - | - | - | - | - | - | - | RTSIO | RTSDT | CTSIO | CTSDT | SCKIO | SCKDT | SPB2IO | SPB2DT | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | RTSIO | 0 | R/W | RTS Port Input/Output | | | | | | Indicates input or output of the serial port $\overline{\text{RTS}}$ pin. When the $\overline{\text{RTS}}$ pin is actually used as a port outputting the RTSDT bit value, the MCE bit in SCFCR should be cleared to 0. | | | | | | 0: RTSDT bit value not output to $\overline{\text{RTS}}$ pin | | | | | | 1: RTSDT bit value output to $\overline{\text{RTS}}$ pin | | 6 | RTSDT | 1 | R/W | RTS Port Data | | | | | | Indicates the input/output data of the serial port $\overline{\text{RTS}}$ pin. Input/output is specified by the RTSIO bit. For output, the RTSDT bit value is output to the $\overline{\text{RTS}}$ pin. The $\overline{\text{RTS}}$ pin status is read from the RTSDT bit regardless of the RTSIO bit setting. However, $\overline{\text{RTS}}$ input/output must be set in the PFC. | | | | | | 0: Input/output data is low level | | | | | | 1: Input/output data is high level | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | CTSIO | 0 | R/W | CTS Port Input/Output | | | | | | Indicates input or output of the serial port $\overline{\text{CTS}}$ pin. When the $\overline{\text{CTS}}$ pin is actually used as a port outputting the CTSDT bit value, the MCE bit in SCFCR should be cleared to 0. | | | | | | 0: CTSDT bit value not output to CTS pin | | | | | | 1: CTSDT bit value output to $\overline{\text{CTS}}$ pin | | 4 | CTSDT | 1 | R/W | CTS Port Data | | | | | | Indicates the input/output data of the serial port $\overline{\text{CTS}}$ pin. Input/output is specified by the CTSIO bit. For output, the CTSDT bit value is output to the $\overline{\text{CTS}}$ pin. The $\overline{\text{CTS}}$ pin status is read from the CTSDT bit regardless of the CTSIO bit setting. However, $\overline{\text{CTS}}$ input/output must be set in the PFC. | | | | | | 0: Input/output data is low level | | | | | | 1: Input/output data is high level | | 3 | SCKIO | 0 | R/W | SCK Port Input/Output | | | | | | Indicates input or output of the serial port SCK pin. When the SCK pin is actually used as a port outputting the SCKDT bit value, the CKE[1:0] bits in SCSCR should be cleared to 0. | | | | | | 0: SCKDT bit value not output to SCK pin | | | | | | 1: SCKDT bit value output to SCK pin | | 2 | SCKDT | 0 | R/W | SCK Port Data | | | | | | Indicates the input/output data of the serial port SCK pin. Input/output is specified by the SCKIO bit. For output, the SCKDT bit value is output to the SCK pin. The SCK pin status is read from the SCKDT bit regardless of the SCKIO bit setting. However, SCK input/output must be set in the PFC. | | | | | | 0: Input/output data is low level | | | | | | 1: Input/output data is high level | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | SPB2IO | 0 | R/W | Serial Port Break Input/Output | | | | | | Indicates input or output of the serial port TxD pin. When the TxD pin is actually used as a port outputting the SPB2DT bit value, the TE bit in SCSCR should be cleared to 0. | | | | | | 0: SPB2DT bit value not output to TxD pin | | | | | | 1: SPB2DT bit value output to TxD pin | | 0 | SPB2DT | 0 | R/W | Serial Port Break Data | | | | | | Indicates the input data of the RxD pin and the output data of the TxD pin used as serial ports. Input/output is specified by the SPB2IO bit. When the TxD pin is set to output, the SPB2DT bit value is output to the TxD pin. The RxD pin status is read from the SPB2DT bit regardless of the SPB2IO bit setting. However, RxD input and TxD output must be set in the PFC. | | | | | | 0: Input/output data is low level | | | | | | 1: Input/output data is high level | ### 22.3.12 Line Status Register (SCLSR) The CPU can always read or write to SCLSR, but cannot write 1 to the ORER flag. This flag can be cleared to 0 only if it has first been read (after being set to 1). SCLSR is initialized to H'0000 by a power-on reset. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------| | | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | ORER | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R/(W)* | Note: \* Only 0 can be written to clear the flag after 1 is read. | Bit | Bit Name | Initial<br>Value | R/W | Description | | | | | |---------|----------|------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | DIL Name | | | • | | | | | | 15 to 1 | _ | All 0 | R | Reserved | | | | | | | | | | These bits are always read as 0. The write value should always be 0. | | | | | | 0 | ORER | 0 | R/(W)* | Overrun Error | | | | | | | | | | Indicates the occurrence of an overrun error. | | | | | | | | | | 0: Receiving is in progress or has ended normally*1 | | | | | | | | | | [Clearing conditions] | | | | | | | | | | ORER is cleared to 0 when the chip is a power-on reset | | | | | | | | | | <ul> <li>ORER is cleared to 0 when 0 is written after 1 is<br/>read from ORER.</li> </ul> | | | | | | | | | | 1: An overrun error has occurred*2 | | | | | | | | | | [Setting condition] | | | | | | | | | | <ul> <li>ORER is set to 1 when the next serial receiving is<br/>finished while the receive FIFO is full of 16-byte<br/>receive data.</li> </ul> | | | | | | | | | | Notes: 1. Clearing the RE bit to 0 in SCSCR does not affect the ORER bit, which retains its previous value. | | | | | | | | | | <ol> <li>The receive FIFO data register (SCFRDR) retains the data before an overrun error has occurred, and the next received data is discarded. When the ORER bit is set to 1, the SCIF cannot continue the next</li> </ol> | | | | | serial reception. ### 22.4 Operation #### 22.4.1 Overview For serial communication, the SCIF has an asynchronous mode in which characters are synchronized individually, and a clocked synchronous mode in which communication is synchronized with clock pulses. The SCIF has a 16-stage FIFO buffer for both transmission and receptions, reducing the overhead of the CPU, and enabling continuous high-speed communication. Furthermore, RTS and CTS signals are provided as modem control signals. Furthermore, RTS and CTS signals are provided as modem control signals. The transmission format is selected in the serial mode register (SCSMR), as shown in table 22.9. The SCIF clock source is selected by the combination of the CKE[1:0] bits in the serial control register (SCSCR), as shown in table 22.10. ### (1) Asynchronous Mode - Data length is selectable: 7 or 8 bits - Parity bit is selectable. So is the stop bit length (1 or 2 bits). The combination of the preceding selections constitutes the communication format and character length. - In receiving, it is possible to detect framing errors, parity errors, receive FIFO data full, overrun errors, receive data ready, and breaks. - The number of stored data bytes is indicated for both the transmit and receive FIFO registers. - An internal or external clock can be selected as the SCIF clock source. - When an internal clock is selected, the SCIF operates using the clock of on-chip baud rate generator. - When an external clock is selected, the external clock input must have a frequency 16 times the bit rate. (The on-chip baud rate generator is not used.) #### **Clocked Synchronous Mode (2)** - The transmission/reception format has a fixed 8-bit data length. - In receiving, it is possible to detect overrun errors (ORER). - An internal or external clock can be selected as the SCIF clock source. - When an internal clock is selected, the SCIF operates using the clock of the on-chip baud rate generator, and outputs this clock to external devices as the synchronous clock. - When an external clock is selected, the SCIF operates on the input external synchronous clock not using the on-chip baud rate generator. **Table 22.9 SCSMR Settings and SCIF Communication Formats** | 9 | SCSMR | Settin | gs | | SCIF Communication Format | | | | | | | |--------------|--------------|-------------|---------------|---------------------|---------------------------|------------|-----------------|--|--|--|--| | Bit 7<br>C/Ā | Bit 6<br>CHR | Bit 5<br>PE | Bit 3<br>STOP | Mode | Data Length | Parity Bit | Stop Bit Length | | | | | | 0 | 0 | 0 | 0 | Asynchronous | 8 bits | Not set | 1 bit | | | | | | | | | 1 | _ | | | 2 bits | | | | | | | | 1 | 0 | _ | | Set | 1 bit | | | | | | | | | 1 | _ | | | 2 bits | | | | | | | 1 | 0 | 0 | _ | 7 bits | Not set | 1 bit | | | | | | | | | 1 | _ | | | 2 bits | | | | | | | | 1 | 0 | _ | | Set | 1 bit | | | | | | | | | 1 | _ | | | 2 bits | | | | | | 1 | х | х | х | Clocked synchronous | 8 bits | Not set | None | | | | | [Legend] Don't care x: Table 22.10 SCSMR and SCSCR Settings and SCIF Clock Source Selection | SCSMR | SCSCR | | | SCIF Transmit/Receive Clock | | | | | |-----------|----------------------|--------------|--------------------|--------------------------------------------------------|--|--|--|--| | Bit 7 C/Ā | Bit 1, 0<br>CKE[1:0] | -<br>Mode | Clock<br>Source | SCK Pin Function | | | | | | 0 | 00 | Asynchronous | Internal | SCIF does not use the SCK pin | | | | | | | 01 | _ | | Outputs a clock with a frequency 16 times the bit rate | | | | | | | 10 | _ | External | Inputs a clock with frequency 16 times the bit rate | | | | | | | 11 | _ | Setting pr | rohibited | | | | | | 1 | 0x | Clocked | Internal | Outputs the serial clock | | | | | | | 10 | synchronous | External | Inputs the serial clock | | | | | | | 11 | | Setting prohibited | | | | | | [Legend] x: Don't care #### 22.4.2 Operation in Asynchronous Mode In asynchronous mode, each transmitted or received character begins with a start bit and ends with a stop bit. Serial communication is synchronized one character at a time. The transmitting and receiving sections of the SCIF are independent, so full duplex communication is possible. The transmitter and receiver are 16-byte FIFO buffered, so data can be written and read while transmitting and receiving are in progress, enabling continuous transmitting and receiving. Figure 22.2 shows the general format of asynchronous serial communication. In asynchronous serial communication, the communication line is normally held in the mark (high) state. The SCIF monitors the line and starts serial communication when the line goes to the space (low) state, indicating a start bit. One serial character consists of a start bit (low), data (LSB first), parity bit (high or low), and stop bit (high), in that order. When receiving in asynchronous mode, the SCIF synchronizes at the falling edge of the start bit. The SCIF samples each data bit on the eighth pulse of a clock with a frequency 16 times the bit rate. Receive data is latched at the center of each bit. Figure 22.2 Example of Data Format in Asynchronous Communication (8-Bit Data with Parity and Two Stop Bits) ### (1) Transmit/Receive Formats Table 22.11 lists the eight communication formats that can be selected in asynchronous mode. The format is selected by settings in the serial mode register (SCSMR). **Table 22.11 Serial Communication Formats (Asynchronous Mode)** | SCSMR setting | | | | | Serial | transmit | tion/rece <sub>l</sub> | otion for | rmat and | d frame | length | | | | |---------------|----|------|-------|-----------------------|--------|----------|------------------------|-----------|----------|---------|--------|------|------|------| | CHR | PE | STOP | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | | 0 | 0 | 0 | START | | | 8 | 8-bit data | l | | | | STOP | | | | | | 1 | START | START 8-bit data | | | | | | | | | STOP | | | | 1 | 0 | START | START 8- bit data | | | | | | | | | STOP | | | | | 1 | START | ART 8-bit data | | | | | | | | Р | STOP | STOP | | 1 | 0 | 0 | START | START 7-bit data STOP | | | | | | | | ] | | | | | | 1 | START | ART 7-bit data STOP | | | | | | | | STOP | | | | | 1 | 0 | START | | | - | 7-bit data | l | | | Р | STOP | | | | | | 1 | START | | | - | 7-bit data | l | | | Р | STOP | STOP | | [Legend] START: Start bit STOP: Stop bit P: Parity bit ### (2) Clock An internal clock generated by the on-chip baud rate generator or an external clock input from the SCK pin can be selected as the SCIF transmit/receive clock. The clock source is selected by the C/A bit in the serial mode register (SCSMR) and bits CKE[1:0] in the serial control register (SCSCR). For clock source selection, refer to table 22.10, SCSMR and SCSCR Settings and SCIF Clock Source Selection. When an external clock is input at the SCK pin, it must have a frequency equal to 16 times the desired bit rate. When the SCIF operates on an internal clock, it can output a clock signal on the SCK pin. The frequency of this output clock is 16 times the desired bit rate. #### (3) Transmitting and Receiving Data #### • SCIF Initialization (Asynchronous Mode) Before transmitting or receiving, clear the TE and RE bits to 0 in the serial control register (SCSCR), then initialize the SCIF as follows. When changing the operation mode or the communication format, always clear the TE and RE bits to 0 before following the procedure given below. Clearing TE to 0 initializes the transmit shift register (SCTSR). Clearing TE and RE to 0, however, does not initialize the serial status register (SCFSR), transmit FIFO data register (SCFTDR), or receive FIFO data register (SCFRDR), which retain their previous contents. Clear TE to 0 after all transmit data has been transmitted and the TEND flag in the SCFSR is set. The TE bit can be cleared to 0 during transmission, but the transmit data goes to the Mark state after the bit is cleared to 0. Set the TFRST bit in SCFCR to 1 and reset SCFTDR before TE is set again to start transmission. When an external clock is used, the clock should not be stopped during initialization or subsequent operation. SCIF operation becomes unreliable if the clock is stopped. Figure 22.3 shows a sample flowchart for initializing the SCIF. Figure 22.3 Sample Flowchart for SCIF Initialization #### • Transmitting Serial Data (Asynchronous Mode) Figure 22.4 shows a sample flowchart for serial transmission. Use the following procedure for serial data transmission after enabling the SCIF for transmission. Figure 22.4 Sample Flowchart for Transmitting Serial Data In serial transmission, the SCIF operates as described below. - 1. When data is written into the transmit FIFO data register (SCFTDR), the SCIF transfers the data from SCFTDR to the transmit shift register (SCTSR) and starts transmitting. Confirm that the TDFE flag in the serial status register (SCFSR) is set to 1 before writing transmit data to SCFTDR. The number of data bytes that can be written is (16 transmit trigger setting). - 2. When data is transferred from SCFTDR to SCTSR and transmission is started, consecutive transmit operations are performed until there is no transmit data left in SCFTDR. When the number of transmit data bytes in SCFTDR falls below the transmit trigger number set in the FIFO control register (SCFCR), the TDFE flag is set. If the TIE bit in the serial control register (SCSR) is set to 1 at this time, a transmit-FIFO-data-empty interrupt (TXI) request is generated. The serial transmit data is sent from the TxD pin in the following order. - A. Start bit: One-bit 0 is output. - B. Transmit data: 8-bit or 7-bit data is output in LSB-first order. - C. Parity bit: One parity bit (even or odd parity) is output. (A format in which a parity bit is not output can also be selected.) - D. Stop bit(s): One or two 1 bits (stop bits) are output. - E. Mark state: 1 is output continuously until the start bit that starts the next transmission is sent. - 3. The SCIF checks the SCFTDR transmit data at the timing for sending the stop bit. If data is present, the data is transferred from SCFTDR to SCTSR, the stop bit is sent, and then serial transmission of the next frame is started. Figure 22.5 shows an example of the operation for transmission. Figure 22.5 Example of Transmit Operation (8-Bit Data, Parity, 1 Stop Bit) 4. When modem control is enabled, transmission can be stopped and restarted in accordance with the CTS input value. When CTS is set to 1, if transmission is in progress, the line goes to the mark state after transmission of one frame. When CTS is set to 0, the next transmit data is output starting from the start bit. Figure 22.6 shows an example of the operation when modem control is used. Figure 22.6 Example of Operation Using Modem Control (CTS) #### • Receiving Serial Data (Asynchronous Mode) Figures 22.7 and 22.8 show sample flowcharts for serial reception. Use the following procedure for serial data reception after enabling the SCIF for reception. Figure 22.7 Sample Flowchart for Receiving Serial Data - Whether a framing error or parity error has occurred in the receive data that is to be read from the receive FIFO data register (SCFRDR) can be ascertained from the FER and PER bits in the serial status register (SCFSR). - When a break signal is received, receive data is not transferred to SCFRDR while the BRK flag is set. However, note that the last data in SCFRDR is H'00, and the break data in which a framing error occurred is stored. Figure 22.8 Sample Flowchart for Receiving Serial Data (cont) In serial reception, the SCIF operates as described below. - 1. The SCIF monitors the transmission line, and if a 0 start bit is detected, performs internal synchronization and starts reception. - 2. The received data is stored in SCRSR in LSB-to-MSB order. - 3. The parity bit and stop bit are received. - After receiving these bits, the SCIF carries out the following checks. - A. Stop bit check: The SCIF checks whether the stop bit is 1. If there are two stop bits, only the first is checked. - B. The SCIF checks whether receive data can be transferred from the receive shift register (SCRSR) to SCFRDR. - C. Overrun check: The SCIF checks that the ORER flag is 0, indicating that the overrun error has not occurred. - D. Break check: The SCIF checks that the BRK flag is 0, indicating that the break state is not set. If all the above checks are passed, the receive data is stored in SCFRDR. Note: When a parity error or a framing error occurs, reception is not suspended. 4. If the RIE bit in SCSCR is set to 1 when the RDF or DR flag changes to 1, a receive-FIFO-data-full interrupt (RXI) request is generated. If the RIE bit or the REIE bit in SCSCR is set to 1 when the ER flag changes to 1, a receive-error interrupt (ERI) request is generated. If the RIE bit or the REIE bit in SCSCR is set to 1 when the BRK or ORER flag changes to 1, a break reception interrupt (BRI) request is generated. Figure 22.9 shows an example of the operation for reception. Figure 22.9 Example of SCIF Receive Operation (8-Bit Data, Parity, 1 Stop Bit) 5. When modem control is enabled, the RTS signal is output when SCFRDR is empty. When RTS is 0, reception is possible. When RTS is 1, this indicates that SCFRDR exceeds the number set for the RTS output active trigger. Figure 22.10 shows an example of the operation when modem control is used. Figure 22.10 Example of Operation Using Modem Control (RTS) #### 22.4.3 Operation in Clocked Synchronous Mode In clocked synchronous mode, the SCIF transmits and receives data in synchronization with clock pulses. This mode is suitable for high-speed serial communication. The SCIF transmitter and receiver are independent, so full-duplex communication is possible while sharing the same clock. The transmitter and receiver are also 16-byte FIFO buffered, so continuous transmitting or receiving is possible by reading or writing data while transmitting or receiving is in progress. Figure 22.11 shows the general format in clocked synchronous serial communication. Figure 22.11 Data Format in Clocked Synchronous Communication In clocked synchronous serial communication, each data bit is output on the communication line from one falling edge of the serial clock to the next. Data is guaranteed valid at the rising edge of the serial clock. In each character, the serial data bits are transmitted in order from the LSB (first) to the MSB (last). After output of the MSB, the communication line remains in the state of the MSB. In clocked synchronous mode, the SCIF receives data by synchronizing with the rising edge of the serial clock. #### **Transmit/Receive Formats (1)** The data length is fixed at eight bits. No parity bit can be added. #### **(2)** Clock An internal clock generated by the on-chip baud rate generator by the setting of the C/A bit in SCSMR and CKE[1:0] in SCSCR, or an external clock input from the SCK pin can be selected as the SCIF transmit/receive clock. When the SCIF operates on an internal clock, it outputs the clock signal at the SCK pin. Eight clock pulses are output per transmitted or received character. When the SCIF is not transmitting or receiving, the clock signal remains in the high state. When only receiving, the clock signal outputs while the RE bit of SCSCR is 1 and the number of data in receive FIFO is more than the receive FIFO data trigger number. In this case, a synchronizing clock consisting of 136 pulses, $8 \times (16 +$ 1) = 136, is output. When receiving n characters, the clock source should be changed to an external clock. When the internal clock is used, set RE = 1 and TE = 1 to enable a procedure for sending dummy data consisting of n characters and receiving n characters. #### **Transmitting and Receiving Data** (3) ## **SCIF Initialization (Clocked Synchronous Mode)** Before transmitting, receiving, or changing the mode or communication format, the software must clear the TE and RE bits to 0 in the serial control register (SCSCR), then initialize the SCIF. Clearing TE to 0 initializes the transmit shift register (SCTSR). Clearing RE to 0, however, does not initialize the RDF, PER, FER, and ORER flags and receive data register (SCRDR), which retain their previous contents. Figure 22.12 shows a sample flowchart for initializing the SCIF. Figure 22.12 Sample Flowchart for SCIF Initialization # Transmitting Serial Data (Clocked Synchronous Mode) Figure 22.13 shows a sample flowchart for transmitting serial data. Use the following procedure for serial data transmission after enabling the SCIF for transmission. Figure 22.13 Sample Flowchart for Transmitting Serial Data In serial transmission, the SCIF operates as described below. - 1. When data is written into the transmit FIFO data register (SCFTDR), the SCIF transfers the data from SCFTDR to the transmit shift register (SCTSR) and starts transmitting. Confirm that the TDFE flag in the serial status register (SCFSR) is set to 1 before writing transmit data to SCFTDR. The number of data bytes that can be written is (16 transmit trigger setting). - 2. When data is transferred from SCFTDR to SCTSR and transmission is started, consecutive transmit operations are performed until there is no transmit data left in SCFTDR. When the number of transmit data bytes in SCFTDR falls below the transmit trigger number set in the FIFO control register (SCFCR), the TDFE flag is set. If the TIE bit in the serial control register (SCSR) is set to 1 at this time, a transmit-FIFO-data-empty interrupt (TXI) request is generated. - If clock output mode is selected, the SCIF outputs eight synchronous clock pulses. If an external clock source is selected, the SCIF outputs data in synchronization with the input clock. Data is output from the TxD pin in order from the LSB (bit 0) to the MSB (bit 7). - 3. The SCIF checks the SCFTDR transmit data at the timing for sending the MSB (bit 7). If data is present, the data is transferred from SCFTDR to SCTSR, and then serial transmission of the next frame is started. If there is no data, the TxD pin holds the state after the TEND flag in SCFSR is set to 1 and the MSB (bit 7) is sent. - 4. After the end of serial transmission, the SCK pin is held in the high state. Figure 22.14 shows an example of SCIF transmit operation. Figure 22.14 Example of SCIF Transmit Operation ### • Receiving Serial Data (Clocked Synchronous Mode) Figures 22.15 and 22.16 show sample flowcharts for receiving serial data. When switching from asynchronous mode to clocked synchronous mode without SCIF initialization, make sure that ORER, PER, and FER are cleared to 0. Figure 22.15 Sample Flowchart for Receiving Serial Data (1) Figure 22.16 Sample Flowchart for Receiving Serial Data (2) In serial reception, the SCIF operates as described below. - 1. The SCIF synchronizes with serial clock input or output and starts the reception. - 2. Receive data is shifted into SCRSR in order from the LSB to the MSB. After receiving the data, the SCIF checks the receive data can be loaded from SCRSR into SCFRDR or not. If this check is passed, the RDF flag is set to 1 and the SCIF stores the received data in SCFRDR. If the check is not passed (overrun error is detected), further reception is prevented. - 3. After setting RDF to 1, if the receive FIFO data full interrupt enable bit (RIE) is set to 1 in SCSCR, the SCIF requests a receive-data-full interrupt (RXI). If the ORER bit is set to 1 and the receive-data-full interrupt enable bit (RIE) or the receive error interrupt enable bit (REIE) in SCSCR is also set to 1, the SCIF requests a break interrupt (BRI). Figure 22.17 shows an example of SCIF receive operation. Figure 22.17 Example of SCIF Receive Operation ### Transmitting and Receiving Serial Data Simultaneously (Clocked Synchronous Mode) Figure 22.18 shows a sample flowchart for transmitting and receiving serial data simultaneously. Use the following procedure for the simultaneous transmission/reception of serial data, after enabling the SCIF for transmission/reception. Figure 22.18 Sample Flowchart for Transmitting/Receiving Serial Data # **22.5** SCIF Interrupts The SCIF has four interrupt sources: transmit-FIFO-data-empty (TXI), receive-error (ERI), receive FIFO data full (RXI), and break (BRI). Table 22.12 shows the interrupt sources and their order of priority. The interrupt sources are enabled or disabled by means of the TIE, RIE, and REIE bits in SCSCR. A separate interrupt request is sent to the interrupt controller for each of these interrupt sources. When a TXI request is enabled by the TIE bit and the TDFE flag in the serial status register (SCFSR) is set to 1, a TXI interrupt request is generated. The DMAC can be activated and data transfer performed by this TXI interrupt request. At this time, an interrupt request is not sent to the CPU. When an RXI request is enabled by the RIE bit and the RDF flag or the DR flag in SCFSR is set to 1, an RXI interrupt request is generated. The DMAC can be activated and data transfer performed by this RXI interrupt request. At this time, an interrupt request is not sent to the CPU. The RXI interrupt request caused by the DR flag is generated only in asynchronous mode. When the RIE bit is set to 0 and the REIE bit is set to 1, the SCIF requests only an ERI interrupt without requesting an RXI interrupt. The TXI indicates that transmit data can be written, and the RXI indicates that there is receive data in SCFRDR. **Table 22.12 SCIF Interrupt Sources** | Interrupt<br>Source | Description | DMAC<br>Activation | Priority on<br>Reset Release | |---------------------|------------------------------------------------------------------------|--------------------|------------------------------| | BRI | Interrupt initiated by break (BRK) or overrun error (ORER) | Not possible | High | | ERI | Interrupt initiated by receive error (ER) | Not possible | _ | | RXI | Interrupt initiated by receive FIFO data full (RDF) or data ready (DR) | Possible | _ | | TXI | Interrupt initiated by transmit FIFO data empty (TDFE) | Possible | Low | # 22.6 Usage Notes Note the following when using the SCIF. ### 22.6.1 SCFTDR Writing and TDFE Flag The TDFE flag in the serial status register (SCFSR) is set when the number of transmit data bytes written in the transmit FIFO data register (SCFTDR) has fallen below the transmit trigger number set by bits TTRG[1:0] in the FIFO control register (SCFCR). After the TDFE flag is set, transmit data up to the number of empty bytes in SCFTDR can be written, allowing efficient continuous transmission. However, if the number of data bytes written in SCFTDR is equal to or less than the transmit trigger number, the TDFE flag will be set to 1 again after being read as 1 and cleared to 0. TDFE flag clearing should therefore be carried out when SCFTDR contains more than the transmit trigger number of transmit data bytes. The number of transmit data bytes in SCFTDR can be found from the upper 8 bits of the FIFO data count register (SCFDR). # 22.6.2 SCFRDR Reading and RDF Flag The RDF flag in the serial status register (SCFSR) is set when the number of receive data bytes in the receive FIFO data register (SCFRDR) has become equal to or greater than the receive trigger number set by bits RTRG[1:0] in the FIFO control register (SCFCR). After RDF flag is set, receive data equivalent to the trigger number can be read from SCFRDR, allowing efficient continuous reception. However, if the number of data bytes in SCFRDR exceeds the trigger number, the RDF flag will be set to 1 again if it is cleared to 0. The RDF flag should therefore be cleared to 0 after being read as 1 after reading the number of the received data in the receive FIFO data register (SCFRDR) which is less than the trigger number. The number of receive data bytes in SCFRDR can be found from the lower 8 bits of the FIFO data count register (SCFDR). #### 22.6.3 **Break Detection and Processing** Break signals can be detected by reading the RxD pin directly when a framing error (FER) is detected. In the break state the input from the RxD pin consists of all 0s, so the FER flag is set and the parity error flag (PER) may also be set. Note that, although transfer of receive data to SCFRDR is halted in the break state, the SCIF receiver continues to operate. #### 22.6.4 Sending a Break Signal The I/O condition and level of the TxD pin are determined by the SPB2IO and SPB2DT bits in the serial port register (SCSPTR). This feature can be used to send a break signal. Until TE bit is set to 1 (enabling transmission) after initializing, the TxD pin does not work. During the period, mark status is performed by the SPB2DT bit. Therefore, the SPB2IO and SPB2DT bits should be set to 1 (high level output). To send a break signal during serial transmission, clear the SPB2DT bit to 0 (designating low level), then clear the TE bit to 0 (halting transmission). When the TE bit is cleared to 0, the transmitter is initialized regardless of the current transmission state, and 0 is output from the TxD pin. #### 22.6.5 Receive Data Sampling Timing and Receive Margin (Asynchronous Mode) The SCIF operates on a base clock with a frequency of 16 times the transfer rate. In reception, the SCIF synchronizes internally with the fall of the start bit, which it samples on the base clock. Receive data is latched at the rising edge of the eighth base clock pulse. The timing is shown in figure 22.19. Figure 22.19 Receive Data Sampling Timing in Asynchronous Mode The receive margin in asynchronous mode can therefore be expressed as shown in equation 1. ## **Equation 1:** $$M = \ \{ \ (0.5 - \frac{1}{2N} \ ) - (L - 0.5) \ F - \frac{|D - 0.5|}{N} \ (1 + F) \ \} \ \times 100 \ \%$$ Where: M: Receive margin (%) N: Ratio of clock frequency to bit rate (N = 16) D: Clock duty (D = 0 to 1.0) L: Frame length (L = 9 to 12) F: Absolute deviation of clock frequency From equation 1, if F = 0 and D = 0.5, the receive margin is 46.875%, as given by equation 2. # **Equation 2:** When D = 0.5 and F = 0: $$M = (0.5 - 1/(2 \times 16)) \times 100\%$$ $$= 46.875\%$$ This is a theoretical value. A reasonable margin to allow in system designs is 20% to 30%. # Section 23 Pin Function Controller (PFC) The pin function controller (PFC) consists of registers that select the functions of the multiplexed pins and their I/O directions. Tables 23.1 to 23.7 list the multiplexed pins of this LSI. Table 23.8 lists pin functions for each operating mode. **Table 23.1** List of Multiplexed Pins (Port A) | Port | Function 1<br>(Related modules) | Function 2<br>(Related modules) | Function 3 (Related modules) | Function 4<br>(Related modules) | Function 5 (Related modules) | |------|---------------------------------|---------------------------------|------------------------------|---------------------------------|------------------------------| | Α | PA25 I/O (port) | A25 output (BSC) | _ | _ | HIFMD input (HIF) | | | PA24 I/O (port) | A24 output (BSC) | _ | _ | _ | | | PA23 I/O (port) | A23 output (BSC) | _ | _ | _ | | | PA22 I/O (port) | A22 output (BSC) | — | _ | _ | | | PA21 I/O (port) | A21 output (BSC) | _ | _ | _ | | | PA20 I/O (port) | A20 output (BSC) | _ | _ | _ | | | PA19 I/O (port) | A19 output (BSC) | _ | _ | _ | | | PA18 I/O (port) | A18 output (BSC) | _ | _ | _ | | | PA17 I/O (port) | A17 output (BSC) | _ | _ | _ | Table 23.2 List of Multiplexed Pins (Port B) | Port | Function 1<br>(Related modules) | Function 2<br>(Related modules | ) | Function 3 (Related modules) | Function 4<br>(Related modules) | |------|---------------------------------|--------------------------------|--------------------|------------------------------|---------------------------------| | В | PB07 I/O (port) | BS output (BSC) | | _ | _ | | | PB06 input (port) | CS4 output (BSC) | | _ | _ | | | PB05 I/O (port) | CS5 output (BSC) | CE1A output (BSC) | IRQ3 input (INTC) | TEND1 output (DMAC) | | | PB04 I/O (port) | | CE2A output (BSC) | IRQ2 input (INTC) | DACK1 output<br>(DMAC) | | | PB03 input (port) | CS6 output (BSC) | CE1B output (BSC) | IRQ1 input (INTC) | DREQ1 input<br>(DMAC) | | | PB02 input (port) | | CE2B output (BSC) | IRQ0 input (INTC) | _ | | | PB01 input (port) | | IOIS16 input (BSC) | SCL I/O (IIC) | _ | | | PB00 input (port) | WAIT input (BSC) | | SDA I/O (IIC) | _ | **Table 23.3** List of Multiplexed Pins (Port C) | Port | Function 1 (Related modules) | Function 2<br>(Related modules) | Function 3<br>(Related modules) | Function 4 (Related modules) | |------|------------------------------|---------------------------------|---------------------------------|------------------------------| | С | PC20 I/O (port) | WOL output (EtherC) | _ | _ | | | PC19 I/O (port) | EXOUT output (EtherC) | _ | _ | | | PC18 I/O (port) | LNKSTA input (EtherC) | _ | _ | | | PC17 I/O (port) | MDC output (EtherC) | _ | _ | | | PC16 I/O (port) | MDIO I/O (EtherC) | _ | _ | | | PC15 I/O (port) | CRS input (EtherC) | _ | _ | | | PC14 I/O (port) | COL input (EtherC) | _ | _ | | | PC13 I/O (port) | TX_CLK input (EtherC) | _ | _ | | | PC12 I/O (port) | TX_EN output (EtherC) | _ | _ | | | PC11 I/O (port) | TX_ER output (EtherC) | _ | _ | | | PC10 I/O (port) | RX_CLK input (EtherC) | _ | _ | | | PC09 I/O (port) | RX_ER input (EtherC) | _ | _ | | | PC08 I/O (port) | RX_DV input (EtherC) | _ | _ | | | PC07 I/O (port) | MII_TXD3 output (EtherC) | _ | _ | | | PC06 I/O (port) | MII_TXD2 output<br>(EtherC) | _ | _ | | | PC05 I/O (port) | MII_TXD1 output<br>(EtherC) | _ | _ | | | PC04 I/O (port) | MII_TXD0 output<br>(EtherC) | _ | _ | | | PC03 I/O (port) | MII_RXD3 input (EtherC) | _ | _ | | | PC02 I/O (port) | MII_RXD2 input (EtherC) | _ | _ | | | PC01 I/O (port) | MII_RXD1 input (EtherC) | _ | _ | | | PC00 input (port) | MII_RXD0 input (EtherC) | _ | _ | **Table 23.4** List of Multiplexed Pins (Port D) | Port | Function 1 (Related modules) | Function 2 (Related modules) | Function 3 (Related modules) | Function 4 (Related modules) | |------|------------------------------|------------------------------|------------------------------|------------------------------| | D | PD07 I/O (port) | IRQ7 input (INTC) | SDCLK output (SDHI) | _ | | | PD06 I/O (port) | IRQ6 input (INTC) | SDCMD I/O (SDHI) | _ | | | PD05 input (port) | IRQ5 input (INTC) | SDCD input (SDHI) | _ | | | PD04 input (port) | IRQ4 input (INTC) | SDWP input (SDHI) | _ | | | PD03 I/O (port) | IRQ3 input (INTC) | SDDAT3 I/O (SDHI) | _ | | | PD02 I/O (port) | IRQ2 input (INTC) | SDDAT2 I/O (SDHI) | _ | | | PD01 I/O (port) | IRQ1 input (INTC) | SDDAT1 I/O (SDHI) | _ | | | PD00 I/O (port) | IRQ0 input (INTC) | SDDAT0 I/O (SDHI) | _ | Table 23.5 List of Multiplexed Pins (Port E) | Port | Function 1<br>(Related modules) | Function 2<br>(Related modules) | Function 3<br>(Related modules) | Function 4<br>(Related modules) | |------|---------------------------------|---------------------------------|---------------------------------|---------------------------------| | E | _ | ST1_CLKIN input (STIF) | SSISCK1 I/O (SSI) | _ | | | _ | ST1_VCO_CLKIN input (STIF) | AUDIO_CLK input (SSI) | _ | | | PE11 I/O (port) | ST1_PWM output (STIF) | RTS2 I/O (SCIF) | _ | | | PE10 I/O (port) | ST1_SYC I/O (STIF) | CTS2 I/O (SCIF) | _ | | | PE09 I/O (port) | ST1_VLD I/O (STIF) | SCK2 I/O (SCIF) | _ | | | PE08 I/O (port) | ST1_REQ I/O (STIF) | TxD2 output (SCIF) | _ | | | PE07 I/O (port) | ST1_D7 I/O (STIF) | SSIWS1 I/O (SSI) | _ | | | PE06 I/O (port) | ST1_D6 I/O (STIF) | SSIDATA1 I/O (SSI) | _ | | | PE05 I/O (port) | ST1_D5 I/O (STIF) | RTS1 I/O (SCIF) | _ | | | PE04 I/O (port) | ST1_D4 I/O (STIF) | CTS1 I/O (SCIF) | _ | | | PE03 I/O (port) | ST1_D3 I/O (STIF) | SCK1 I/O (SCIF) | _ | | | PE02 I/O (port) | ST1_D2 I/O (STIF) | RxD1 input (SCIF) | _ | | | PE01 I/O (port) | ST1_D1 I/O (STIF) | TxD1 output (SCIF) | | | | PE00 I/O (port) | ST1_D0 I/O (STIF) | RxD2 input (SCIF) | _ | **Table 23.6** List of Multiplexed Pins (Port F) | Port | Function 1<br>(Related modules) | Function 2<br>(Related modules) | Function 3<br>(Related modules) | Function 4<br>(Related modules) | |------|---------------------------------|---------------------------------|---------------------------------|---------------------------------| | F | _ | ST_CLKOUT output<br>(STIF) | _ | _ | | | _ | ST0_CLKIN input (STIF) | SSISCK0 I/O (SSI) | _ | | | _ | ST0_VCO_CLKIN input (STIF) | _ | _ | | | PF11 I/O (port) | ST0_PWM output (STIF) | TEND0 output (DMAC) | _ | | | PF10 I/O (port) | ST0_SYC I/O (STIF) | DACK0 output (DMAC) | _ | | | PF09 I/O (port) | ST0_VLD I/O (STIF) | DREQ0 input (DMAC) | _ | | | PF08 I/O (port) | ST0_REQ I/O (STIF) | _ | _ | | | PF07 I/O (port) | ST0_D7 I/O (STIF) | SSIWS0 I/O (SSI) | _ | | | PF06 I/O (port) | ST0_D6 I/O (STIF) | SSIDATA0 I/O (SSI) | _ | | | PF05 I/O (port) | ST0_D5 I/O (STIF) | RTS0 I/O (SCIF) | _ | | | PF04 I/O (port) | ST0_D4 I/O (STIF) | CTS0 I/O (SCIF) | _ | | | PF03 I/O (port) | ST0_D3 I/O (STIF) | SCK0 I/O (SCIF) | _ | | | PF02 I/O (port) | ST0_D2 I/O (STIF) | RxD0 input (SCIF) | _ | | | PF01 I/O (port) | ST0_D1 I/O (STIF) | TxD0 output (SCIF) | _ | | | PF00 I/O (port) | ST0_D0 I/O (STIF) | _ | _ | **Table 23.7 List of Multiplexed Pins (Port G)** | Port | Function 1<br>(Related modules) | Function 2<br>(Related modules) | Function 3 (Related modules) | Function 4<br>(Related modules) | |------|---------------------------------|---------------------------------|------------------------------|---------------------------------| | G | PG23 I/O (port) | HIFCS input (HIF) | _ | _ | | | PG22 I/O (port) | HIFRS input (HIF) | _ | _ | | | PG21 I/O (port) | HIFWR input (HIF) | _ | _ | | | PG20 I/O (port) | HIFRD input (HIF) | _ | _ | | | PG19 I/O (port) | HIFINT output (HIF) | _ | _ | | | PG18 I/O (port) | HIFDREQ output (HIF) | _ | _ | | | PG17 I/O (port) | HIFRDY output (HIF) | _ | _ | | | PG16 I/O (port) | HIFEBL input (HIF) | _ | _ | | | PG15 I/O (port) | HIFD15 I/O (HIF) | _ | _ | | | PG14 I/O (port) | HIFD14 I/O (HIF) | _ | _ | | | PG13 I/O (port) | HIFD13 I/O (HIF) | _ | _ | | | PG12 I/O (port) | HIFD12 I/O (HIF) | _ | _ | | | PG11 I/O (port) | HIFD11 I/O (HIF) | _ | _ | | | PG10 I/O (port) | HIFD10 I/O (HIF) | _ | _ | | | PG09 I/O (port) | HIFD09 I/O (HIF) | _ | _ | | | PG08 I/O (port) | HIFD08 I/O (HIF) | _ | _ | | | PG07 I/O (port) | HIFD07 I/O (HIF) | _ | _ | | | PG06 I/O (port) | HIFD06 I/O (HIF) | _ | _ | | | PG05 I/O (port) | HIFD05 I/O (HIF) | _ | _ | | | PG04 I/O (port) | HIFD04 I/O (HIF) | _ | _ | | | PG03 I/O (port) | HIFD03 I/O (HIF) | _ | _ | | | PG02 I/O (port) | HIFD02 I/O (HIF) | _ | _ | | | PG01 I/O (port) | HIFD01 I/O (HIF) | _ | _ | | | PG00 I/O (port) | HIFD00 I/O (HIF) | | _ | Table 23.8 List of Pins for Each Operating Mode (1) | No. Initial Function Settable Function Initial Function Settable Function A2 A00 — A00 — A17 A01 — A01 — B17 A02 — A02 — C17 A03 — A03 — A16 A04 — A04 — B16 A05 — A05 — C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A11 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — <th>Pin</th> <th>Non-HIF Boot Mode</th> <th></th> <th>HIF Boot Mode</th> <th></th> | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------|-------------------|------------------|-------------------| | A17 A01 — A02 — C17 A03 — A03 — A16 A04 — A04 — B16 A05 — A05 — C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A16 — A12 A16 — — A1 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C2 PA21 | No. | Initial Function | Settable Function | Initial Function | Settable Function | | B17 A02 — A03 — C17 A03 — A04 — A16 A04 — A04 — B16 A05 — A05 — C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A16 — A12 A16 — A16 — A1 PA17/A17 PA17/A17 PA17/A17 PA18 PA18/A18 B1 PA19 PA19/A19 | A2 | A00 | _ | A00 | _ | | C17 A03 — A03 — A16 A04 — A04 — B16 A05 — A05 — C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C4 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA | A17 | A01 | _ | A01 | _ | | A16 A04 — A04 — B16 A05 — A05 — C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C4 PA21 PA21/A21 PA21 PA2 | B17 | A02 | _ | A02 | _ | | B16 A05 — A06 — C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C4 PA21 P | C17 | A03 | _ | A03 | _ | | C16 A06 — A06 — A15 A07 — A07 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 | A16 | A04 | _ | A04 | _ | | A15 A07 — A08 — B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A16 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19/A19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 <t< td=""><td>B16</td><td>A05</td><td>_</td><td>A05</td><td>_</td></t<> | B16 | A05 | _ | A05 | _ | | B15 A08 — A08 — C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 <td>C16</td> <td>A06</td> <td>_</td> <td>A06</td> <td>_</td> | C16 | A06 | _ | A06 | _ | | C15 A09 — A09 — A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 | A15 | A07 | _ | A07 | _ | | A14 A10 — A10 — B14 A11 — A11 — C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — | B15 | A08 | _ | A08 | _ | | B14 A11 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | C15 | A09 | _ | A09 | _ | | C14 A12 — A12 — A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | A14 | A10 | _ | A10 | _ | | A13 A13 — A13 — B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | B14 | A11 | _ | A11 | _ | | B13 A14 — A14 — C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | C14 | A12 | _ | A12 | _ | | C13 A15 — A15 — A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19/A19 PA19/A19 C3 PA20 PA20/A20 PA20/A20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | A13 | A13 | _ | A13 | _ | | A12 A16 — A16 — A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20/A20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | B13 | A14 | _ | A14 | _ | | A1 PA17 PA17/A17 PA17 PA17/A17 B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | C13 | A15 | _ | A15 | _ | | B2 PA18 PA18/A18 PA18 PA18/A18 B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | A12 | A16 | _ | A16 | _ | | B1 PA19 PA19/A19 PA19 PA19/A19 C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | A1 | PA17 | PA17/A17 | PA17 | PA17/A17 | | C3 PA20 PA20/A20 PA20 PA20/A20 C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | B2 | PA18 | PA18/A18 | PA18 | PA18/A18 | | C2 PA21 PA21/A21 PA21 PA21/A21 C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23/A23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | B1 | PA19 | PA19/A19 | PA19 | PA19/A19 | | C1 PA22 PA22/A22 PA22 PA22/A22 D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | СЗ | PA20 | PA20/A20 | PA20 | PA20/A20 | | D3 PA23 PA23/A23 PA23 PA23/A23 D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | C2 | PA21 | PA21/A21 | PA21 | PA21/A21 | | D2 PA24 PA24/A24 PA24 PA24/A24 D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | C1 | PA22 | PA22/A22 | PA22 | PA22/A22 | | D1 HIFMD/PA25* PA25/A25 HIFMD/PA25* PA25/A25 B12 D00 — D00 — C12 D01 — D01 — | D3 | PA23 | PA23/A23 | PA23 | PA23/A23 | | B12 D00 — D00 — C12 D01 — D01 — | D2 | PA24 | PA24/A24 | PA24 | PA24/A24 | | C12 D01 — D01 — | D1 | HIFMD/PA25* | PA25/A25 | HIFMD/PA25* | PA25/A25 | | | B12 | D00 | _ | D00 | _ | | A44 D00 | C12 | D01 | _ | D01 | _ | | A11 D02 — D02 — | A11 | D02 | _ | D02 | _ | | B11 D03 — D03 — | B11 | D03 | _ | D03 | _ | | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | |-----|-------------------|-------------------|------------------|-------------------|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | C11 | D04 | _ | D04 | _ | | | A10 | D05 | _ | D05 | _ | | | B10 | D06 | _ | D06 | _ | | | C10 | D07 | _ | D07 | _ | | | B7 | D08 | _ | D08 | _ | | **Table 23.8** List of Pins for Each Operating Mode (2) | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | |-----|-------------------|-------------------|------------------|-------------------| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | A7 | D09 | _ | D09 | _ | | B8 | D10 | _ | D10 | _ | | C8 | D11 | _ | D11 | _ | | A8 | D12 | _ | D12 | _ | | C9 | D13 | _ | D13 | _ | | В9 | D14 | _ | D14 | _ | | A9 | D15 | _ | D15 | _ | | K20 | D16 | _ | D16 | _ | | K19 | D17 | _ | D17 | _ | | J20 | D18 | _ | D18 | _ | | J19 | D19 | _ | D19 | _ | | H20 | D20 | _ | D20 | _ | | H19 | D21 | _ | D21 | _ | | G20 | D22 | _ | D22 | _ | | G19 | D23 | _ | D23 | _ | | E18 | D24 | _ | D24 | _ | | D20 | D25 | _ | D25 | _ | | E19 | D26 | _ | D26 | _ | | F18 | D27 | _ | D27 | _ | | E20 | D28 | _ | D28 | _ | | F19 | D29 | _ | D29 | _ | | F20 | D30 | _ | D30 | _ | | G18 | D31 | _ | D31 | _ | | A4 | PB00 | PB00/WAIT/SDA | PB00 | PB00/WAIT/SDA | | C5 | PB01 | PB01/IOIS16/SCL | PB01 | PB01/IOIS16/SCL | | B20 | CKE | _ | CKE | _ | | A19 | CAS | _ | CAS | _ | | A18 | RAS | _ | RAS | _ | | C7 | (WEO/DQMLL) | _ | (WE0/DQMLL) | _ | | A6 | (WE1/DQMLU/WE) | _ | (WE1/DQMLU/WE) | _ | | | | | | | | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | |-----|--------------------|-------------------|--------------------|-------------------| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | D19 | (WE2/DQMUL/ICIORD) | _ | (WE2/DQMUL/ICIORD) | _ | | D18 | (WE3/DQMUU/ICIOWR) | _ | (WE3/DQMUU/ICIOWR) | _ | | B5 | RD | _ | RD | _ | | C19 | RDWR | _ | RDWR | _ | | B4 | PB02 | PB02/CE2B/IRQ0 | PB02 | PB02/CE2B/IRQ0 | **Table 23.8** List of Pins for Each Operating Mode (3) | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | | | |------------|-------------------|------------------------------|------------------|------------------------------|--|--|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | | | C4 | PB03 | PB03/CS6/CE1B/IRQ1/<br>DREQ1 | PB03 | PB03/CS6/CE1B/IRQ1/<br>DREQ1 | | | | | А3 | PB04 | PB04/CE2A/IRQ2/DACK1 | PB04 | PB04/CE2A/IRQ2/DACK1 | | | | | В3 | PB05 | PB05/CS5/CE1A/IRQ3/<br>TEND1 | PB05 | PB05/CS5/CE1A/IRQ3/<br>TEND1 | | | | | <b>A</b> 5 | PB06 | PB06/CS4 | PB06 | PB06/CS4 | | | | | B18 | CS3 | _ | CS3 | _ | | | | | C6 | CS0 | _ | CS0 | _ | | | | | В6 | PB07 | PB07/BS | PB07 | PB07/BS | | | | | L1 | PC00 | PC00/MII_RXD0 | PC00 | PC00/MII_RXD0 | | | | | L2 | PC01 | PC01/MII_RXD1 | PC01 | PC01/MII_RXD1 | | | | | L3 | PC02 | PC02/MII_RXD2 | PC02 | PC02/MII_RXD2 | | | | | K1 | PC03 | PC03/MII_RXD3 | PC03 | PC03/MII_RXD3 | | | | | H1 | PC04 | PC04/MII_TXD0 | PC04 | PC04/MII_TXD0 | | | | | H2 | PC05 | PC05/MII_TXD1 | PC05 | PC05/MII_TXD1 | | | | | НЗ | PC06 | PC06/MII_TXD2 | PC06 | PC06/MII_TXD2 | | | | | G1 | PC07 | PC07/MII_TXD3 | PC07 | PC07/MII_TXD3 | | | | | K2 | PC08 | PC08/RX_DV | PC08 | PC08/RX_DV | | | | | K3 | PC09 | PC09/RX_ER | PC09 | PC09/RX_ER | | | | | J1 | PC10 | PC10/RX_CLK | PC10 | PC10/RX_CLK | | | | | G2 | PC11 | PC11/TX_ER | PC11 | PC11/TX_ER | | | | | G3 | PC12 | PC12/TX_EN | PC12 | PC12/TX_EN | | | | | F1 | PC13 | PC13/TX_CLK | PC13 | PC13/TX_CLK | | | | | J2 | PC14 | PC14/COL | PC14 | PC14/COL | | | | | J3 | PC15 | PC15/CRS | PC15 | PC15/CRS | | | | | F2 | PC16 | PC16/MDIO | PC16 | PC16/MDIO | | | | | F3 | PC17 | PC17/MDC | PC17 | PC17/MDC | | | | | E1 | PC18 | PC18/LNKSTA | PC18 | PC18/LNKSTA | | | | | E2 | PC19 | PC19/EXOUT | PC19 | PC19/EXOUT | | | | | E3 | PC20 | PC20/WOL | PC20 | PC20/WOL | | | | | R3 | PD00 | PD00/IRQ0/SDATA0 | PD00 | PD00/IRQ0/SDATA0 | | | | | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | | | |-----|-------------------|-------------------|------------------|-------------------|--|--|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | | | P1 | PD01 | PD01/IRQ1/SDATA1 | PD01 | PD01/IRQ1/SDATA1 | | | | | P2 | PD02 | PD02/IRQ2/SDATA2 | PD02 | PD02/IRQ2/SDATA2 | | | | | P3 | PD03 | PD03/IRQ3/SDATA3 | PD03 | PD03/IRQ3/SDATA3 | | | | **Table 23.8** List of Pins for Each Operating Mode (4) | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | | | |-----|-------------------|-----------------------------|------------------|-----------------------------|--|--|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | | | N1 | PD04 | PD04/IRQ4/SDWP | PD04 | PD04/IRQ4/SDWP | | | | | N2 | PD05 | PD05/IRQ5/SDCD | PD05 | PD05/IRQ5/SDCD | | | | | N3 | PD06 | PD06/IRQ6/SDCMD | PD06 | PD06/IRQ6/SDCMD | | | | | МЗ | PD07 | PD07/IRQ7/SDCLK | PD07 | PD07/IRQ7/SDCLK | | | | | Y15 | PE00 | PE00/ST1_D0/RxD2 | PE00 | PE00/ST1_D0/RxD2 | | | | | V14 | PE01 | PE01/ST1_D1/TxD1 | PE01 | PE01/ST1_D1/TxD1 | | | | | W14 | PE02 | PE02/ST1_D2/RxD1 | PE02 | PE02/ST1_D2/RxD1 | | | | | V15 | PE03 | PE03/ST1_D3/SCK1 | PE03 | PE03/ST1_D3/SCK1 | | | | | Y13 | PE04 | PE04/ST1_D4/CTS1 | PE04 | PE04/ST1_D4/CTS1 | | | | | W13 | PE05 | PE05/ST1_D5/RTS1 | PE05 | PE05/ST1_D5/RTS1 | | | | | V13 | PE06 | PE06/ST1_D6/SSIDATA1 | PE06 | PE06/ST1_D6/SSIDATA1 | | | | | V12 | PE07 | PE07/ST1_D7/SSIWS1 | PE07 | PE07/ST1_D7/SSIWS1 | | | | | Y16 | PE08 | PE08/ST1_REQ/TxD2 | PE08 | PE08/ST1_REQ/TxD2 | | | | | Y14 | PE09 | PE09/ST1_VLD/SCK2 | PE09 | PE09/ST1_VLD/SCK2 | | | | | W15 | PE10 | PE10/ST1_SYC/CTS2 | PE10 | PE10/ST1_SYC/CTS2 | | | | | W16 | ST1_PWM | PE11/ST1_PWM/RTS2 | ST1_PWM | PE11/ST1_PWM/RTS2 | | | | | V16 | _ | ST1_VCO_CLKIN/<br>AUDIO_CLK | _ | ST1_VCO_CLKIN/<br>AUDIO_CLK | | | | | W17 | _ | ST1_CLKIN/SSISCK1 | _ | ST1_CLKIN/SSISCK1 | | | | | N20 | PF00 | PF00/ST0_D0 | PF00 | PF00/ST0_D0 | | | | | N18 | PF01 | PF01/ST0_D1/TxD0 | PF01 | PF01/ST0_D1/TxD0 | | | | | M18 | PF02 | PF02/ST0_D2/RxD0 | PF02 | PF02/ST0_D2/RxD0 | | | | | M19 | PF03 | PF03/ST0_D3/SCK0 | PF03 | PF03/ST0_D3/SCK0 | | | | | M20 | PF04 | PF04/ST0_D4/CTS0 | PF04 | PF04/ST0_D4/CTS0 | | | | | L18 | PF05 | PF05/ST0_D5/RTS0 | PF05 | PF05/ST0_D5/RTS0 | | | | | L19 | PF06 | PF06/ST0_D6/SSIDATA0 | PF06 | PF06/ST0_D6/SSIDATA0 | | | | | L20 | PF07 | PF07/ST0_D7/SSIWS0 | PF07 | PF07/ST0_D7/SSIWS0 | | | | | P19 | PF08 | PF08/ST0_REQ | PF08 | PF08/ST0_REQ | | | | | P20 | PF09 | PF09/ST0_VLD/DREQ0 | PF09 | PF09/ST0_VLD/DREQ0 | | | | | N19 | PF10 | PF10/ST0_SYC/DACK0 | PF10 | PF10/ST0_SYC/DACK0 | | | | | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | | | |-----|-------------------|--------------------|------------------|--------------------|--|--|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | | | P18 | ST0_PWM | PF11/ST0_PWM/TEND0 | ST0_PWM | PF11/ST0_PWM/TEND0 | | | | | R20 | ST0_VCO_CLKIN | _ | ST0_VCO_CLKIN | _ | | | | | R19 | _ | ST0_CLKIN/SSISCK0 | _ | ST0_CLKIN/SSISCK0 | | | | | Y17 | ST_CLKOUT | _ | ST_CLKOUT | _ | | | | **Table 23.8** List of Pins for Each Operating Mode (5) | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | |-----|-------------------|-------------------|------------------|-------------------| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | W4 | PG00 | PG00/HIFD00 | HIFD00 | PG00/HIFD00 | | V4 | PG01 | PG01/HIFD01 | HIFD01 | PG01/HIFD01 | | Y3 | PG02 | PG02/HIFD02 | HIFD02 | PG02/HIFD02 | | W3 | PG03 | PG03/HIFD03 | HIFD03 | PG03/HIFD03 | | V3 | PG04 | PG04/HIFD04 | HIFD04 | PG04/HIFD04 | | Y2 | PG05 | PG05/HIFD05 | HIFD05 | PG05/HIFD05 | | W2 | PG06 | PG06/HIFD06 | HIFD06 | PG06/HIFD06 | | V1 | PG07 | PG07/HIFD07 | HIFD07 | PG07/HIFD07 | | Y1 | PG08 | PG08/HIFD08 | HIFD08 | PG08/HIFD08 | | U1 | PG09 | PG09/HIFD09 | HIFD09 | PG09/HIFD09 | | U2 | PG10 | PG10/HIFD10 | HIFD10 | PG10/HIFD10 | | T1 | PG11 | PG11/HIFD11 | HIFD11 | PG11/HIFD11 | | T2 | PG12 | PG12/HIFD12 | HIFD12 | PG12/HIFD12 | | T3 | PG13 | PG13/HIFD13 | HIFD13 | PG13/HIFD13 | | R1 | PG14 | PG14/HIFD14 | HIFD14 | PG14/HIFD14 | | R2 | PG15 | PG15/HIFD15 | HIFD15 | PG15/HIFD15 | | W7 | PG16 | PG16/HIFEBL | HIFEBL | PG16/HIFEBL | | V6 | PG17 | PG17/HIFRDY | HIFRDY | PG17/HIFRDY | | W6 | PG18 | PG18/HIFDREQ | HIFDREQ | PG18/HIFDREQ | | Y6 | PG19 | PG19/HIFINT | HIFINT | PG19/HIFINT | | Y5 | PG20 | PG20/HIFRD | HIFRD | PG20/HIFRD | | W5 | PG21 | PG21/HIFWR | HIFWR | PG21/HIFWR | | V5 | PG22 | PG22/HIFRS | HIFRS | PG22/HIFRS | | Y4 | PG23 | PG23/HIFCS | HIFCS | PG23/HIFCS | | Y9 | DP | _ | DP | _ | | Y8 | DM | _ | DM | _ | | W9 | VBUS | _ | VBUS | _ | | Y11 | REFRIN | _ | REFRIN | _ | | W12 | USB_X1 | _ | USB_X1 | _ | | Y12 | USB_X2 | _ | USB_X2 | _ | | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | | |-----|-------------------|-------------------|------------------|-------------------|--|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | | Y18 | TRST | _ | TRST | _ | | | | W19 | TDO | _ | TDO | _ | | | | V18 | TDI | _ | TDI | _ | | | | Y19 | TMS | _ | TMS | _ | | | Table 23.8 List of Pins for Each Operating Mode (6) | Pin | Non-HIF Boot Mode | | HIF Boot Mode | | | | | | |-----|-------------------|-------------------|------------------|-------------------|--|--|--|--| | No. | Initial Function | Settable Function | Initial Function | Settable Function | | | | | | V17 | TCK | _ | TCK | _ | | | | | | T20 | ASEBRK/ASEBRKAK | _ | ASEBRK/ASEBRKAK | _ | | | | | | U8 | DG12 | _ | DG12 | _ | | | | | | U9 | DV12 | _ | DV12 | _ | | | | | | U10 | UV12 | _ | UV12 | _ | | | | | | U11 | AV12 | _ | AV12 | _ | | | | | | V10 | UG12 | _ | UG12 | _ | | | | | | V11 | AG12 | _ | AG12 | _ | | | | | | W8 | DG33 | _ | DG33 | _ | | | | | | W10 | AG33 | _ | AG33 | _ | | | | | | Y10 | AV33 | _ | AV33 | _ | | | | | | V20 | EXTAL | _ | EXTAL | _ | | | | | | W20 | XTAL | _ | XTAL | _ | | | | | | C20 | CKIO | _ | CKIO | _ | | | | | | M2 | ASEMD | _ | ASEMD | _ | | | | | | M1 | TESTMD | _ | TESTMD | _ | | | | | | T19 | MD_BW | _ | MD_BW | _ | | | | | | U18 | MD_CK1 | _ | MD_CK1 | _ | | | | | | V19 | MD_CK0 | _ | MD_CK0 | _ | | | | | | W18 | RES | _ | RES | _ | | | | | | U19 | NMI | _ | NMI | _ | | | | | | R18 | WDTOVF | _ | WDTOVF | _ | | | | | | | | | | | | | | | Note: \* This pin functions as HIFMD during a power-on reset that is output from the RES pin. # 23.1 Register Descriptions The PFC has the following registers. For the address and status at each processing state of these registers, see section 28, List of Registers. Port A I/O register H (PAIORH) Port A control register H2 (PACRH2) Port A control register H1 (PACRH1) Port B I/O register L (PBIORL) Port B control register L1 (PBCRL1) Port C I/O register H (PCIORH) Port C I/O register L (PCIORL) Port C control register H1 (PCCRH1) Port C control register L2 (PCCRL2) Port C control register L1 (PCCRL1) Port D I/O register L (PDIORL) Port D control register L1 (PDCRL1) Port E I/O register L (PEIORL) Port E control register L2 (PECRL2) Port E control register L1 (PECRL1) Port F I/O register L (PFIORL) Port F control register L2 (PFCRL2) Port F control register L1 (PFCRL1) Port G I/O register H (PGIORH) Port G I/O register L (PGIORL) Port G control register H1 (PGCRH1) Port G control register L1 (PGCRL1) Port G control register L2 (PGCRL2) ### 23.1.1 Port A I/O Register H (PAIORH) PAIORH is a 16-bit readable/writable register that selects the input/output direction for the port A pins. Bits PA25IOR to PA17IOR correspond to pins PA25 to PA17 (multiplexed pin names other than port names are omitted), respectively. PAIORH is enabled when the function of the port A pins is set to general-purpose I/O (PA25 to PA17), and is disabled in other cases. When a bit in PAIORH is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 10 and 0 in PAIORH are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PAIORH is H'0000. # 23.1.2 Port A Control Registers H2 and H1 (PACRH2, PACRH1) PACRH1 and PACRH2 are 16-bit readable/writable registers that select the functions of the multiplexed port A pins. ### PACRH2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|---|-------------| | [ | - | - | - | - | - | - | - | - | - | - | - | - | - | PA25<br>MD0 | - | PA24<br>MD0 | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | R | R | R | R | R | R | R | R | R | R | R | R | R | R/W | R | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 to 3 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 2 | PA25MD0 | 0 | R/W | PA25 Mode | | | | | | This bit selects the function of the HIFMD/PA25/A25 pin. This pin functions as HIFMD (HIF) only during a power-on reset that is output from the $\overline{\text{RES}}$ pin. | | | | | | 0: PA25 I/O (port) | | | | | | 1: A25 output (BSC) | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PA24MD0 | 0 | R/W | PA24 Mode | | | | | | This bit selects the function of the PA24/A24 pin. | | | | | | 0: PA24 I/O (port) | | | | | | 1: A24 output (BSC) | ## • PACRH1 | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|-------------|----|-------------|----|-------------|---|-------------|---|-------------|---|-------------|---|-------------|---|---| | [ | - | PA23<br>MD0 | - | PA22<br>MD0 | - | PA21<br>MD0 | - | PA20<br>MD0 | - | PA19<br>MD0 | - | PA18<br>MD0 | - | PA17<br>MD0 | - | - | | Initial value: | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | - R | Reserved | | | | · | | This bit is always read as 0. The write value should always be 0. | | 14 | PA23MD0 | 0 | R/W | PA23 Mode | | | | | | This bit selects the function of the PA23/A23 pin. | | | | | | 0: PA23 I/O (port) | | | | | | 1: A23 output (BSC) | | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | PA22MD0 | 0 | R/W | PA22 Mode | | | | | | This bit selects the function of the PA22/A22 pin. | | | | | | 0: PA22 I/O (port) | | | | | | 1: A22 output (BSC) | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 10 | PA21MD0 | 0 | R/W | PA21 Mode | | | | | | This bit selects the function of the PA21/A21 pin. | | | | | | 0: PA21 I/O (port) | | | | | | 1: A21 output (BSC) | | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 8 | PA20MD0 | 0 | R/W | PA20 Mode | | | | | | This bit selects the function of the PA20/A20 pin. | | | | | | 0: PA20 I/O (port) | | | | | | 1: A20 output (BSC) | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|----------------------------------------------------------------------| | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PA19MD0 | 0 | R/W | PA19 Mode | | | | | | This bit selects the function of the PA19/A19 pin. | | | | | | 0: PA19 I/O (port) | | | | | | 1: A19 output (BSC) | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PA18MD0 | 0 | R/W | PA18 Mode | | | | | | This bit selects the function of the PA18/A18 pin. | | | | | | 0: PA18 I/O (port) | | | | | | 1: A18 output (BSC) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | PA17MD0 | 0 | R/W | PA17 Mode | | | | | | This bit selects the function of the PA17/A17 pin. | | | | | | 0: PA17 I/O (port) | | | | | | 1: A17 output (BSC) | | 1, 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | ### 23.1.3 Port B I/O Register L (PBIORL) PBIORL is a 16-bit readable/writable register that selects the input/output direction for the port B pins. Bits PB7IOR to PB0IOR correspond to pins PB07 to PB00 (multiplexed pin names other than port names are omitted), respectively. PBIORL is enabled when the function of the port B pins is set to general-purpose I/O (PB07 to PB00), and is disabled in other cases. When a bit in PBIORL is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 8 in PBIORL are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PBIORL is H'0000. # 23.1.4 Port B Control Register L1 (PBCRL1) PBCRL1 is a 16-bit readable/writable register that selects the functions of the multiplexed port B pins. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|------------|----|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------| | | - | PB7<br>MD0 | - | PB6<br>MD0 | PB5<br>MD1 | PB5<br>MD0 | PB4<br>MD1 | PB4<br>MD0 | PB3<br>MD1 | PB3<br>MD0 | PB2<br>MD1 | PB2<br>MD0 | PB1<br>MD1 | PB1<br>MD0 | PB0<br>MD1 | PB0<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W⋅ | R | D/M | R | D/M | | | Initial | | | | |-----|----------|---------|-----|---------------------------------------------------------------------|--| | Bit | Bit Name | Value | R/W | Description | | | 15 | _ | 0 | R | Reserved | | | | | | | This bit is always read as 0. The write value should always be 0. | | | 14 | PB7MD0 | 0 | R/W | PB7 Mode | | | | | | | This bit selects the function of the PB07/BS pin. | | | | | | | 0: PB07 I/O (port) | | | | | | | 1: BS output (BSC) | | | 13 | _ | 0 | R | Reserved | | | | | | | This bit is always read as 0. The write value should always be 0. | | | 12 | PB6MD0 | 0 | R/W | PB6 Mode | | | | | | | This bit selects the function of the PB06/CS4 pin. | | | | | | | 0: PB06 input (port) | | | | | | | 1: CS4 output (BSC) | | | 11 | PB5MD1 | 0 | R/W | PB5 Mode | | | 10 | PB5MD0 | 0 | R/W | These bits select the function of the PB05/CS5/CE1A/IRQ3/TEND1 pin. | | | | | | | 00: PB05 I/O (port) | | | | | | | 01: CS5/CE1A output (BSC) | | | | | | | 10: IRQ3 input (INTC) | | | | | | | 11: TEND1 output (DMAC) | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------| | 9 | PB4MD1 | 0 | R/W | PB4 Mode | | 8 | PB4MD0 | 0 | R/W | These bits select the function of the PB04/CE2A/IRQ2/DACK1 pin. | | | | | | 00: PB04 I/O (port) | | | | | | 01: CE2A output (BSC) | | | | | | 10: IRQ2 input (INTC) | | | | | | 11: DACK1 output (DMAC) | | 7 | PB3MD1 | 0 | R/W | PB3 Mode | | 6 | PB3MD0 | 0 | R/W | These bits select the function of the PB03/CS6/CE1B/DREQ1 pin. | | | | | | 00: PB03 input (port) | | | | | | 01: CS6/CE1B output (BSC) | | | | | | 10: IRQ1 input (INTC) | | | | | | 11: DREQ1 input (DMAC) | | 5 | PB2MD1 | 0 | R/W | PB2 Mode | | 4 | PB2MD0 | 0 | R/W | These bits select the function of the PB02/CE2B/IRQ0 pin. | | | | | | 00: PB02 input (port) | | | | | | 01: CE2B output (BSC) | | | | | | 10: IRQ0 input (INTC) | | | | | | 11: Setting prohibited | | 3 | PB1MD1 | 0 | R/W | PB1 Mode | | 2 | PB1MD0 | 0 | R/W | These bits select the function of the PB01/IOIS16/SCL pin. | | | | | | 00: PB01 input (port) | | | | | | 01: IOIS16 input (BSC) | | | | | | 10: SCL I/O (IIC) | | | | | | 11: Setting prohibited | | 1 | PB0MD1 | 0 | R/W | PB0 Mode | | 0 | PB0MD0 | 0 | R/W | These bits select the function of the PB00/WAIT/SDA pin. | | | | | | 00: PB00 input (port) | | | | | | 01: WAIT input (BSC) | | | | | | 10: SDA I/O (IIC) | | | | | | 11: Setting prohibited | ### 23.1.5 Port C I/O Registers H and L (PCIORH, PCIORL) PCIORH and PCIORL are 16-bit readable/writable registers that select the input/output direction for the port C pins. Bits PC20IOR to PC0IOR correspond to pins PC20 to PC00 (multiplexed pin names other than port names are omitted), respectively. PCIORH is enabled when the function of the port C pins is set to general-purpose I/O (PC20 to PC16), and is disabled in other cases. PCIORL is enabled when the function of the port C pins is set to general-purpose I/O (PC15 to PC00), and is disabled in other cases. When a bit in PCIORH and PCIORL is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 5 in PCIORH are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PCIORH and PCIORL is H'0000. # 23.1.6 Port C Control Registers H1, L2, and L1 (PCCRH1, PCCRL2, PCCRL1) PCCRH1, PCCRL2, and PCCRL1 are 16-bit readable/writable registers that select the functions of the multiplexed port C pins. ### PCCRH1 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|-------------|---|-------------|---|-------------|---|-------------|---|-------------| | | - | - | - | - | - | - | - | PC20<br>MD0 | - | PC19<br>MD0 | - | PC18<br>MD0 | - | PC17<br>MD0 | - | PC16<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W | R | R/W | R | R/W | R | R/W | R | R/W | | | | Initial | | | |---------|----------|---------|-----|----------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to 9 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 8 | PC20MD0 | 0 | R/W | PC20 Mode | | | | | | This bit selects the function of the PC20/WOL pin. | | | | | | 0: PC20 I/O (port) | | | | | | 1: WOL output (EtherC) | | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PC19MD0 | 0 | R/W | PC19 Mode | | | | | | This bit selects the function of the PC19/EXOUT pin. | | | | | | 0: PC19 I/O (port) | | | | | | 1: EXOUT output (EtherC) | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PC18MD0 | 0 | R/W | PC18 Mode | | | | | | This bit selects the function of the PC18/LNKSTA pin. | | | | | | 0: PC18 I/O (port) | | | | | | 1: LNKSTA input (EtherC) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | - | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 2 | PC17MD0 | 0 | R/W | PC17 Mode | | | | | | This bit selects the function of the PC17/MDC pin. | | | | | | 0: PC17 I/O (port) | | | | | | 1: MDC output (EtherC) | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PC16MD0 | 0 | R/W | PC16 Mode | | | | | | This bit selects the function of the PC16/MDIO pin. | | | | | | 0: PC16 I/O (port) | | | | | | 1: MDIO I/O (EtherC) | ## • PCCRL2 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-------------|----|-------------|----|-------------|---|-------------|---|-------------|---|-------------|---|------------|---|------------| | [ | - | PC15<br>MD0 | - | PC14<br>MD0 | - | PC13<br>MD0 | - | PC12<br>MD0 | - | PC11<br>MD0 | - | PC10<br>MD0 | - | PC9<br>MD0 | - | PC8<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R/W | value should always | |---------------------| | | | 5/CRS pin. | | | | | | | | value should always | | | | 4/COL pin. | | | | | | | | value should always | | | | 3/TX_CLK pin. | | | | | | | | value should always | | | | 2/TX_EN pin. | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PC11MD0 | 0 | R/W | PC11 Mode | | | | | | This bit selects the function of the PC11/TX_ER pin. | | | | | | 0: PC11 I/O (port) | | | | | | 1: TX_ER output (EtherC) | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PC10MD0 | 0 | R/W | PC10 Mode | | | | | | This bit selects the function of the PC10/RX_CLK pin. | | | | | | 0: PC10 I/O (port) | | | | | | 1: RX_CLK input (EtherC) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | PC9MD0 | 0 | R/W | PC9 Mode | | | | | | This bit selects the function of the PC09/RX_ER pin. | | | | | | 0: PC09 I/O (port) | | | | | | 1: RX_ER input (EtherC) | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PC8MD0 | 0 | R/W | PC8 Mode | | | | | | This bit selects the function of the PC08/RX_DV pin. | | | | | | 0: PC08 I/O (port) | | | | | | 1: RX_DV input (EtherC) | ## PCCRL1 | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|------------|----|------------|----|------------|---|------------|---|------------|---|------------|---|------------|---|------------| | [ | - | PF7<br>MD0 | - | PF6<br>MD0 | - | PF5<br>MD0 | - | PF4<br>MD0 | - | PF3<br>MD0 | - | PF2<br>MD0 | - | PF1<br>MD0 | - | PF0<br>MD0 | | Initial value: | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 | PC7MD0 | 0 | R/W | PC7 Mode | | | | | | This bit selects the function of the PC07/MII_TXD3 pin. | | | | | | 0: PC07 I/O (port) | | | | | | 1: MII_TXD3 output (EtherC) | | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | PC6MD0 | 0 | R/W | PC6 Mode | | | | | | This bit selects the function of the PC06/MII_TXD2 pin. | | | | | | 0: PC06 I/O (port) | | | | | | 1: MII_TXD2 output (EtherC) | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 10 | PC5MD0 | 0 | R/W | PC5 Mode | | | | | | This bit selects the function of the PC05/MII_TXD1 pin. | | | | | | 0: PC05 I/O (port) | | | | | | 1: MII_TXD1 output (EtherC) | | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 8 | PC4MD0 | 0 | R/W | PC4 Mode | | | | | | This bit selects the function of the PC04/MII_TXD0 pin. | | | | | | 0: PC04 I/O (port) | | | | | | 1: MII_TXD0 output (EtherC) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------------| | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PC3MD0 | 0 | R/W | PC3 Mode | | | | | | This bit selects the function of the PC03/MII_RXD3 pin. | | | | | | 0: PC03 I/O (port) | | | | | | 1: MII_RXD3 input (EtherC) | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PC2MD0 | 0 | R/W | PC2 Mode | | | | | | This bit selects the function of the PC02/MII_RXD2 pin. | | | | | | 0: PC02 I/O (port) | | | | | | 1: MII_RXD2 input (EtherC) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | PC1MD0 | 0 | R/W | PC1 Mode | | | | | | This bit selects the function of the PC01/MII_RXD1 pin. | | | | | | 0: PC01 I/O (port) | | | | | | 1: MII_RXD1 input (EtherC) | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PC0MD0 | 0 | R/W | PC0 Mode | | | | | | This bit selects the function of the PC00/MII_RXD0 pin. | | | | | | 0: PC00 input (port) | | | | | | 1: MII_RXD0 input (EtherC) | # 23.1.7 Port D I/O Register L (PDIORL) PDIORL is a 16-bit readable/writable register that selects the input/output direction for the port D pins. Bits PD7IOR to PD0IOR correspond to pins PD07 to PD00 (multiplexed pin names other than port names are omitted), respectively. PDIORL is enabled when the function of the port D pins is set to general-purpose I/O (PD07 to PD00), and is disabled in other cases. When a bit in PDIORL is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 8 in PDIORL are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PDIORL is H'0000. # 23.1.8 Port D Control Register L1 (PDCRL1) PDCRL1 is a 16-bit readable/writable register that selects the functions of the multiplexed port D pins. | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------| | PD7<br>MD1 | PD7<br>MD0 | PD6<br>MD1 | PD6<br>MD0 | PD5<br>MD1 | PD5<br>MD0 | PD4<br>MD1 | PD4<br>MD0 | PD3<br>MD1 | PD3<br>MD0 | PD2<br>MD1 | PD2<br>MD0 | PD1<br>MD1 | PD1<br>MD0 | PD0<br>MD1 | PD0<br>MD0 | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: R/W | | D:4 | Dit Name | Initial | DAM | Describition | |-----|----------|---------|-----|------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 | PD7MD1 | 0 | R/W | PD7 Mode | | 14 | PD7MD0 | 0 | R/W | These bits select the function of the PD07/IRQ7/SDCLK pin. | | | | | | 00: PD07 I/O (port) | | | | | | 01: IRQ7 input (INTC) | | | | | | 10: SDCLK output (SDHI) | | | | | | 11: Setting prohibited | | 13 | PD6MD1 | 0 | R/W | PD6 Mode | | 12 | PD6MD0 | 0 | R/W | These bits select the function of the PD06/IRQ6/SDCMD pin. | | | | | | 00: PD06 I/O (port) | | | | | | 01: IRQ6 input (INTC) | | | | | | 10: SDCMD I/O (SDHI) | | | | | | 11: Setting prohibited | | 11 | PD5MD1 | 0 | R/W | PD5 Mode | | 10 | PD5MD0 | 0 | R/W | These bits select the function of the PD05/IRQ5/SDCD pin. | | | | | | 00: PD05 input (port) | | | | | | 01: IRQ5 input (INTC) | | | | | | 10: SDCD input (SDHI) | | | | | | 11: Setting prohibited | | PD4MD1 | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|------------------|-----|------------------------| | Discription | 9 | PD4MD1 | 0 | R/W | PD4 Mode | | 01: IRQ4 input (INTC) 10: SDWP input (SDHI) 11: Setting prohibited 7 | 8 | PD4MD0 | 0 | R/W | | | 10: SDWP input (SDHI) 11: Setting prohibited 7 | | | | | 00: PD04 input (port) | | 11: Setting prohibited | | | | | 01: IRQ4 input (INTC) | | PD3MD1 | | | | | 10: SDWP input (SDHI) | | 6 PD3MD0 0 R/W These bits select the function of the PD03/IRQ3/SDDATA3 pin. 00: PD03 I/O (port) 01: IRQ3 input (INTC) 10: SDDATA3 I/O (SDHI) 11: Setting prohibited 5 PD2MD1 0 R/W PD2 Mode 4 PD2MD0 0 R/W These bits select the function of the PD02/IRQ2/SDDATA2 pin. 00: PD02 I/O (port) 01: IRQ2 input (INTC) 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 PD1MD1 0 R/W PD1 Mode 2 PD1MD0 0 R/W These bits select the function of the PD01/IRQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 1 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited | | | | | 11: Setting prohibited | | PD03//RQ3/SDDATA3 pin. 00: PD03 I/O (port) 01: IRQ3 input (INTC) 10: SDDATA3 I/O (SDHI) 11: Setting prohibited 5 PD2MD1 0 R/W PD2 Mode 4 PD2MD0 0 R/W These bits select the function of the PD02//RQ2/SDDATA2 pin. 00: PD02 I/O (port) 01: IRQ2 input (INTC) 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 PD1MD1 0 R/W PD1 Mode 2 PD1MD0 0 R/W These bits select the function of the PD01//RQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 1 PD0MD0 0 R/W These bits select the function of the PD00//RQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited | 7 | PD3MD1 | 0 | R/W | PD3 Mode | | 01: IRQ3 input (INTC) 10: SDDATA3 I/O (SDHI) 11: Setting prohibited 5 | 6 | PD3MD0 | 0 | R/W | | | 10: SDDATA3 I/O (SDHI) 11: Setting prohibited 5 | | | | | 00: PD03 I/O (port) | | 11: Setting prohibited 5 | | | | | 01: IRQ3 input (INTC) | | 5 PD2MD1 0 R/W PD2 Mode 4 PD2MD0 0 R/W These bits select the function of the PD02/IRQ2/SDDATA2 pin. 00: PD02 I/O (port) 00: PD02 I/O (port) 01: IRQ2 input (INTC) 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 PD1MD1 0 R/W PD1 Mode 2 PD1MD0 0 R/W These bits select the function of the PD01/IRQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 1 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 10: SDDATA3 I/O (SDHI) | | 4 PD2MD0 0 R/W These bits select the function of the PD02/IRQ2/SDDATA2 pin. 00: PD02 I/O (port) 01: IRQ2 input (INTC) 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 PD1MD1 0 R/W PD1 Mode 2 PD1MD0 0 R/W These bits select the function of the PD01/IRQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 11: Setting prohibited | | PD02/IRQ2/SDDATA2 pin. 00: PD02 I/O (port) 01: IRQ2 input (INTC) 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 PD1MD1 0 R/W PD1 Mode 2 PD1MD0 0 R/W These bits select the function of the PD01/IRQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | 5 | PD2MD1 | 0 | R/W | PD2 Mode | | 01: IRQ2 input (INTC) 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 | 4 | PD2MD0 | 0 | R/W | | | 10: SDDATA2 I/O (SDHI) 11: Setting prohibited 3 | | | | | 00: PD02 I/O (port) | | 11: Setting prohibited 3 | | | | | 01: IRQ2 input (INTC) | | 3 PD1MD1 | | | | | 10: SDDATA2 I/O (SDHI) | | PD1MD0 0 R/W These bits select the function of the PD01/IRQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 11: Setting prohibited | | PD01/IRQ1/SDDATA1 pin. 00: PD01 I/O (port) 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | 3 | PD1MD1 | 0 | R/W | PD1 Mode | | 01: IRQ1 input (INTC) 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | 2 | PD1MD0 | 0 | R/W | | | 10: SDDATA1 I/O (SDHI) 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 00: PD01 I/O (port) | | 11: Setting prohibited 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 01: IRQ1 input (INTC) | | 1 PD0MD1 0 R/W PD0 Mode 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 10: SDDATA1 I/O (SDHI) | | 0 PD0MD0 0 R/W These bits select the function of the PD00/IRQ0/SDDATA0 pin. 00: PD00 I/O (port) 01: IRQ0 input (INTC) | | | | | 11: Setting prohibited | | PD00/IRQ0/SDDATA0 pin.<br>00: PD00 I/O (port)<br>01: IRQ0 input (INTC) | 1 | PD0MD1 | 0 | R/W | PD0 Mode | | 01: IRQ0 input (INTC) | 0 | PD0MD0 | 0 | R/W | | | | | | | | 00: PD00 I/O (port) | | 10: SDDATA0 I/O (SDHI) | | | | | 01: IRQ0 input (INTC) | | | | | | | 10: SDDATA0 I/O (SDHI) | | 11: Setting prohibited | | | | | 11: Setting prohibited | #### 23.1.9 Port E I/O Register L (PEIORL) PEIORL is a 16-bit readable/writable register that selects the input/output direction for the port E pins. Bits PE11IOR to PE0IOR correspond to pins PE11 to PE00 (multiplexed pin names other than port names are omitted), respectively. PEIORL is enabled when the function of the port E pins is set to general-purpose I/O (PE11 to PE00), and is disabled in other cases. When a bit in PEIORL is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 12 in PEIORL are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PEIORL is H'0000. # 23.1.10 Port E Control Registers L2 and L1 (PECRL2, PECRL1) PECRL2 and PECRL1 are 16-bit readable/writable registers that select the functions of the multiplexed port E pins. ### • PECRL2 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | [ | - | - | - | - | PE13<br>MD1 | PE13<br>MD0 | PE12<br>MD1 | PE12<br>MD0 | PE11<br>MD1 | PE11<br>MD0 | PE10<br>MD1 | PE10<br>MD0 | PE09<br>MD1 | PE09<br>MD0 | PE08<br>MD1 | PE08<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | | | Initial | | | |-------|----------|---------|-----|----------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 to | _ | All 0 | R | Reserved | | 12 | | | | These bits are always read as 0. The write value should always be 0. | | 11 | PE13MD1 | 0 | R/W | PE13 Mode | | 10 | PE13MD0 | 0 | R/W | These bits select the function of the ST1_CLKIN/SSISCK1 pin. | | | | | | 00: Setting prohibited | | | | | | 01: ST1_CLKIN Input (STIF) | | | | | | 10: SSISCK1 I/O (SSI) | | | | | | 11: Setting prohibited | | 9 | PE12MD1 | 0 | R/W | PE12 Mode | | 8 | PE12MD0 | 0 | R/W | These bits select the function of the ST1_VCO_CLKIN/AUDIO_CLK pin. | | | | | | 00: Setting prohibited | | | | | | 01: ST1_VCO_CLKIN input (STIF) | | | | | | 10: AUDIO_CLK input (SSI) | | | | | | 11: Setting prohibited | | 7 | PE11MD1 | 0 | R/W | PE11 Mode | | 6 | PE11MD0 | 1 | R/W | These bits select the function of the PE11/ST1_PWM/RTS2 pin. | | | | | | 00: PE11 I/O (port) | | | | | | 01: ST1_PWM output (STIF) | | | | | | 10: RTS2 I/O (SCIF) | | | | | | 11: Setting prohibited | | | | | | | | | | Initial | | | |-----|----------|---------|-----|--------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 5 | PE10MD1 | 0 | R/W | PE10 Mode | | 4 | PE10MD0 | 0 | R/W | These bits select the function of the PE10/ST1_SYC/CTS2 pin. | | | | | | 00: PE10 I/O (port) | | | | | | 01: ST1_SYC I/O (STIF) | | | | | | 10: CTS2 I/O (SCIF) | | | | | | 11: Setting prohibited | | 3 | PE09MD1 | 0 | R/W | PE09 Mode | | 2 | PE09MD0 | 0 | R/W | These bits select the function of the PE09/ST1_VLD/SCK2 pin. | | | | | | 00: PE09 I/O (port) | | | | | | 01: ST1_VLD I/O (STIF) | | | | | | 10: SCK2 I/O (SCIF) | | | | | | 11: Setting prohibited | | 1 | PE08MD1 | 0 | R/W | PE08 Mode | | 0 | PE08MD0 | 0 | R/W | These bits select the function of the PE08/ST1_REQ pin. | | | | | | 00: PE08 I/O (port) | | | | | | 01: ST1_REQ I/O (STIF) | | | | | | 10: TxD2 output (SCIF) | | | | | | 11: Setting prohibited | # PECRL1 | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | | PE07<br>MD1 | PE07<br>MD0 | PE06<br>MD1 | PE06<br>MD0 | PE05<br>MD1 | PE05<br>MD0 | PE04<br>MD1 | PE04<br>MD0 | PE03<br>MD1 | PE03<br>MD0 | PE02<br>MD1 | PE02<br>MD0 | PE01<br>MD1 | PE01<br>MD0 | PE00<br>MD1 | PE00<br>MD0 | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R/W | | | | Initial | | | |-----|----------|---------|-----|-----------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 15 | PE07MD1 | 0 | R/W | PE07 Mode | | 14 | PE07MD0 | 0 | R/W | These bits select the function of the PE07/ST1_D7/SSIWS1 pin. | | | | | | 00: PE07 I/O (port) | | | | | | 01: TS2_D7 I/O (STIF) | | | | | | 10: SSIWS1 I/O (SSI) | | | | | | 11: Setting prohibited | | 13 | PE06MD1 | 0 | R/W | PE06 Mode | | 12 | PE06MD0 | 0 | R/W | These bits select the function of the PE06/ST1_D6/SSIDATA1 pin. | | | | | | 00: PE06 I/O (port) | | | | | | 01: ST1_D6 I/O (STIF) | | | | | | 10: SSIDATA1 I/O (SSI) | | | | | | 11: Setting prohibited | | 11 | PE05MD1 | 0 | R/W | PE05 Mode | | 10 | PE05MD0 | 0 | R/W | These bits select the function of the PE05/ST1_D5/RTS1 pin. | | | | | | 00: PE05 I/O (port) | | | | | | 01: ST1_D5 I/O (STIF) | | | | | | 10: RTS1 I/O (SCIF) | | | | | | 11: Setting prohibited | | 9 | PE04MD1 | 0 | R/W | PE04 Mode | | 8 | PE04MD0 | 0 | R/W | These bits select the function of the PE04/ST1_D4/CTS1 pin. | | | | | | 00: PE04 I/O (port) | | | | | | 01: ST1_D4 I/O (STIF) | | | | | | 10: CTS1 I/O (SCIF) | | | | | | 11: Setting prohibited | | | | | | | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-------------------------------------------------------------| | 7 | PE03MD0 | 0 | R/W | PE03 Mode | | 6 | PE03MD0 | 0 | R/W | These bits select the function of the PE03/ST1_D3/SCK1 pin. | | | | | | 00: PE03 I/O (port) | | | | | | 01: ST1_D3 I/O (STIF) | | | | | | 10: SCK1 I/O (SCIF) | | | | | | 11: Setting prohibited | | 5 | PE02MD1 | 0 | R/W | PE02 Mode | | 4 | PE02MD0 | 0 | R/W | These bits select the function of the PE02/ST1_D2/RxD1 pin. | | | | | | 00: PE02 I/O (port) | | | | | | 01: ST1_D2 I/O (STIF) | | | | | | 10: RxD1 input (SCIF) | | | | | | 11: Setting prohibited | | 3 | PE01MD1 | 0 | R/W | PE01 Mode | | 2 | PE01MD0 | 0 | R/W | These bits select the function of the PE01/ST1_D1/TxD1 pin. | | | | | | 00: PE01 I/O (port) | | | | | | 01: ST1_D1 I/O (STIF) | | | | | | 10: TxD1 output (SCIF) | | | | | | 11: Setting prohibited | | 1 | PE00MD1 | 0 | R/W | PE00 Mode | | 0 | PE00MD0 | 0 | R/W | These bits select the function of the PE00/ST1_D0 pin. | | | | | | 00: PE00 I/O (port) | | | | | | 01: ST1_D0 I/O (STIF) | | | | | | 10: RxD2 input (SCIF) | | | | | | 11: Setting prohibited | ### 23.1.11 Port F I/O Register L (PFIORL) PFIORL is a 16-bit readable/writable register that selects the input/output direction for the port F pins. Bits PF11IOR to PF0IOR correspond to pins PF11 to PF00 (multiplexed pin names other than port names are omitted), respectively. PFIORL is enabled when the function of the port F pins is set to general-purpose I/O (PF11 to PF00), and is disabled in other cases. When a bit in PFIORL is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 12 in PFIORL are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PFIORL is H'0000. # 23.1.12 Port F Control Registers L2 and L1 (PFCRL2, PFCRL1) PFCRL2 and PFCRL1 are 16-bit readable/writable registers that select the functions of the multiplexed port F pins. ### • PFCRL2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|-------------|-------------|---|---|-------------|-------------|-------------|-------------|-------------|-------------|---|-------------| | [ | - | - | - | - | PF13<br>MD1 | PF13<br>MD0 | - | - | PF11<br>MD1 | PF11<br>MD0 | PF10<br>MD1 | PF10<br>MD0 | PF09<br>MD1 | PF09<br>MD0 | - | PF08<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/W | R | R | R/W | R/W | R/W | R/W | R/W | R/W | R | R/W | | Dit Name | Initial | DAV | Describition | |----------|--------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit Name | value | H/W | Description | | _ | All 0 | R | Reserved | | | | | These bits are always read as 0. The write value should always be 0. | | PF13MD1 | 0 | R/W | PF13 Mode | | PF13MD0 | 0 | R/W | These bits select the function of the ST0_CLKIN/SSISCK0 pin. | | | | | 00: Setting prohibited | | | | | 01: ST1_CLKIN Input (STIF) | | | | | 10: SSISCK0 I/O (SSI) | | | | | 11: Setting prohibited | | _ | All 0 | R | Reserved | | | | | These bits are always read as 0. The write value should always be 0. | | PF11MD1 | 0 | R/W | PF11 Mode | | PF11MD0 | 1 | R/W | These bits select the function of the PF11/ST0_PWM/TEND0 pin. | | | | | 00: PE11 I/O (port) | | | | | 01: ST0_PWM output (STIF) | | | | | 10: TEND0 output (DMAC) | | | | | 11: Setting prohibited | | | PF13MD0 — PF11MD1 | Bit Name Value All 0 PF13MD1 0 PF13MD0 0 All 0 PF11MD1 0 | Bit Name Value R/W — All 0 R PF13MD1 0 R/W PF13MD0 0 R/W — All 0 R PF11MD1 0 R/W | | | | Initial | | | |-----|----------|---------|-----|-------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 5 | PF10MD1 | 0 | R/W | PF10 Mode | | 4 | PF10MD0 | 0 | R/W | These bits select the function of the PF10/ST0_SYC/DACK0 pin. | | | | | | 00: PF10 I/O (port) | | | | | | 01: ST0_SYC I/O (STIF) | | | | | | 10: DACK0 output (DMAC) | | | | | | 11: Setting prohibited | | 3 | PF09MD1 | 0 | R/W | PF09 Mode | | 2 | PF09MD0 | 0 | R/W | These bits select the function of the PF09/ST0_VLD/DREQ0 pin. | | | | | | 00: PF09 I/O (port) | | | | | | 01: ST0_VLD I/O (STIF) | | | | | | 10: DREQ0 input (DMAC) | | | | | | 11: Setting prohibited | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PF08MD0 | 0 | R/W | PF08 Mode | | | | | | This bit selects the function of the PF08/ST0_REQ pin. | | | | | | 0: PF08 I/O (port) | | | | | | 1: ST0_REQ I/O (STIF) | ## • PFCRL1 | Bit: 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|---|-------------| | PF07<br>MD1 | PF07<br>MD0 | PF06<br>MD1 | PF06<br>MD0 | PF05<br>MD1 | PF05<br>MD0 | PF04<br>MD1 | PF04<br>MD0 | PF03<br>MD1 | PF03<br>MD0 | PF02<br>MD1 | PF02<br>MD0 | PF01<br>MD1 | PF01<br>MD0 | - | PF00<br>MD0 | | Initial value: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: R/W | R | R/W | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------|-----|-----------------------------------------------------------------| | | | | | Description | | 15 | PF07MD1 | 0 | R/W | PF07 Mode | | 14 | PF07MD0 | 0 | R/W | These bits select the function of the PF07/ST0_D7/SSIWS0 pin. | | | | | | 00: PF07 I/O (port) | | | | | | 01: ST0_D7 I/O (STIF) | | | | | | 10: SSIWS0 I/O (SSI) | | | | | | 11: Setting prohibited | | 13 | PF06MD1 | 0 | R/W | PF06 Mode | | 12 | PF06MD0 | 0 | R/W | These bits select the function of the PF06/ST0_D6/SSIDATA0 pin. | | | | | | 00: PF06 I/O (port) | | | | | | 01: ST0_D6 I/O (STIF) | | | | | | 10: SSIDATA0 I/O (SSI) | | | | | | 11: Setting prohibited | | 11 | PF05MD1 | 0 | R/W | PF05 Mode | | 10 | PF05MD0 | 0 | R/W | These bits select the function of the PF05/ST0_D5/RTS0 pin. | | | | | | 00: PF05 I/O (port) | | | | | | 11: ST0_D5 I/O (STIF) | | | | | | 10: RTS0 I/O (SCIF) | | | | | | 11: Setting prohibited | | 9 | PF04MD1 | 0 | R/W | PF04 Mode | | 8 | PF04MD0 | 0 | R/W | These bits select the function of the PF04/ST0_D4/CTS0 pin. | | | | | | 00: PF04 I/O (port) | | | | | | 01: ST0_D4 I/O (STIF) | | | | | | 10: CTSO I/O (SCIF) | | | | | | 11: Setting prohibited | | | | Initial | | | |-----|----------|---------|-----|-------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 7 | PF03MD1 | 0 | R/W | PF03 Mode | | 6 | PF03MD0 | 0 | R/W | These bits select the function of the PF03/ST0_D3/SCK0 pin. | | | | | | 00: PF03 I/O (port) | | | | | | 01: ST0_D3 I/O (STIF) | | | | | | 10: SCK0 I/O (SCIF) | | | | | | 11: Setting prohibited | | 5 | PF02MD1 | 0 | R/W | PF02 Mode | | 4 | PF02MD0 | 0 | R/W | These bits select the function of the PF02/ST0_D2/RxD0 pin. | | | | | | 00: PF02 I/O (port) | | | | | | 01: ST0_D2 I/O (STIF) | | | | | | 10: RxD0 input (SCIF) | | | | | | 11: Setting prohibited | | 3 | PF01MD1 | 0 | R/W | PF01 Mode | | 2 | PF01MD0 | 0 | R/W | These bits select the function of the PF01/ST0_D1/TxD0 pin. | | | | | | 00: PF01 I/O (port) | | | | | | 01: ST0_D1 I/O (STIF) | | | | | | 10: TxD0 output (SCIF) | | | | | | 11: Setting prohibited | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PF00MD0 | 0 | R/W | PF00 Mode | | | | | | This bit selects the function of the PF00/ST0_D0 pin. | | | | | | 0: PF00 I/O (port) | | | | | | 1: ST0_D0 I/O (STIF) | | | • | | | | ### 23.1.13 Port G I/O Registers H and L (PGIORH, PGIORL) PGIORH and PGIORL are 16-bit readable/writable registers that select the input/output direction for the port G pins. Bits PG23IOR to PG0IOR correspond to pins PG23 to PG00 (multiplexed pin names other than port names are omitted), respectively. PGIORH is enabled when the function of the port G pins is set to general-purpose I/O (PG23 to PG16), and is disabled in other cases. PGIORL is enabled when the function of the port G pins is set to general-purpose I/O (PG15 to PG00), and is disabled in other cases. When a bit in PGIORH and PGIORL is set to 1, the corresponding pin is set to output, and when set to 0, the pin is set to input. Bits 15 to 8 in PGIORH are reserved. These bits are always read as 0. The write value should always be 0. The initial value of PGIORH and PGIORL is H'0000. # 23.1.14 Port G Control Registers H2, L2, and L1 (PGCRH2, PGCRL2, PGCRL1) PGCRH2, PGCRL1, and PGCRL2 are 16-bit readable/writable registers that select the functions of the multiplexed port G pins. #### PGCRH2 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-------------|----|-------------|----|-------------|---|-------------|---|-------------|---|-------------|---|-------------|---|-------------| | | - | PG23<br>MD0 | - | PG22<br>MD0 | - | PG21<br>MD0 | - | PG20<br>MD0 | - | PG19<br>MD0 | - | PG18<br>MD0 | - | PG17<br>MD0 | - | PG16<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|------------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 | PG23MD0 | 0 | R/W | PG23 Mode | | | | (Non-HIF<br>boot mode) | | This bit selects the function of the PG23/HIFCS pin. | | | | 1 | | 0: PG23 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFCS input (HIF) | | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | PG22MD0 | 0 | R/W | PG22 Mode | | | | (Non-HIF<br>boot mode) | | This bit selects the function of the PG22/HIFRS pin. | | | | 1 | | 0: PG22 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFRS input (HIF) | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 10 | PG21MD0 | 0 | R/W | PG21 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG21/HIFWR pin. | | | | 1 | | 0: PG22 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFWR input (HIF) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------------------| | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 8 | PG20MD0 | 0 | R/W | PG20 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG20/HIFRD pin. | | | | 1 | | 0: PG20 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFRD input (HIF) | | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PG19MD0 | 0 | R/W | PG19 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG19/HIFINT pin. | | | | 1 | | 0: PG19 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFINT output (HIF) | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PG18MD0 | 0 | R/W | PG18 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG18/HIFDREQ pin. | | | | 1 | | 0: PG18 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFDREQ output (HIF) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | PG17MD0 | 0 | R/W | PG17 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG17/HIFRDY pin. | | | | 1 | | 0: PG17 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFRDY output (HIF) | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|-------------------------|-----|-------------------------------------------------------------------| | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 0 | PG16MD0 | 0 | R/W | PG16 Mode | | | | (Non-HIF | | This bit selects the function of the PG16/HIFEBL pin. | | | | boot mode) | | 0: PG16 I/O (port) | | | | 1<br>(HIF boot<br>mode) | | 1: HIFEBL input (HIF) | ## • PGCRL2 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-------------|----|-------------|----|-------------|---|-------------|---|-------------|---|-------------|---|------------|---|------------| | | - | PG15<br>MD0 | - | PG14<br>MD0 | - | PG13<br>MD0 | - | PG12<br>MD0 | - | PG11<br>MD0 | - | PG10<br>MD0 | - | PG9<br>MD0 | - | PG8<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 14 | PG15MD0 | 0 | R/W | PG15 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG15/HIFD15 pin. | | | | 1 | | 0: PG15 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD15 I/O (HIF) | | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | PG14MD0 | 0 | R/W | PG14 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG14/HIFD14 pin. | | | | 1 | | 0: PG14 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD14 I/O (HIF) | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 10 | PG13MD0 | 0 | R/W | PG13 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG13/HIFD13 pin. | | | | 1 | | 0: PG13 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD13 I/O (HIF) | | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------------------| | 8 | PG12MD0 | 0 | R/W | PG12 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG12/HIFD12 pin. | | | | 1 | | 0: PG12 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD12 I/O (HIF) | | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PG11MD0 | 0 | R/W | PG11 Mode | | | | (Non-HIF | | This bit selects the function of the PG11/HIFD11 pin. | | | | boot mode) 1 | | 0: PG11 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD11 I/O (HIF) | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PG10MD0 | 0 | R/W | PG10 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG10/HIFD10 pin. | | | | 1 | | 0: PG10 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD10 I/O (HIF) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | PG09MD0 | 0 | R/W | PG09 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG09/HIFD09 pin. | | | | 1 | | 0: PG09 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD09 I/O (HIF) | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------| | 0 | PG08MD0 | 0 | R/W | PG08 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG08/HIFD08 pin. | | | | 1 | 1 | 0: PG08 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD08 I/O (HIF) | ## PGCRL1 | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|-------------|----|-------------|----|-------------|---|-------------|---|-------------|---|-------------|---|-------------|---|-------------| | | - | PG07<br>MD0 | - | PG06<br>MD0 | - | PG05<br>MD0 | - | PG04<br>MD0 | - | PG03<br>MD0 | - | PG02<br>MD0 | - | PG01<br>MD0 | - | PG00<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------------------| | 15 | _ | 0 | R | Reserved | | 10 | | v | | This bit is always read as 0. The write value should always be 0. | | 14 | PG07MD0 | 0 | R/W | PG07 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG07/HIFD07 pin. | | | | 1 | | 0: PG07 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD07 I/O (HIF) | | 13 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 12 | PG06MD0 | 0 | R/W | PG06 Mode | | | , | (Non-HIF boot mode) | | This bit selects the function of the PG06/HIFD06 pin. | | | | 1 | | 0: PG06 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD06 I/O (HIF) | | 11 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 10 | PG05MD0 | 0 | R/W | PG05 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG05/HIFD05 pin. | | | | 1 | | 0: PG05 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD05 I/O (HIF) | | 9 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------------------| | 8 | PG04MD0 | 0 | R/W | PG04 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG04/HIFD04 pin. | | | | 1 | | 0: PG04 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD04 I/O (HIF) | | 7 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 6 | PG03MD0 | 0 | R/W | PG03 Mode | | | | (Non-HIF | | This bit selects the function of the PG03/HIFD03 pin. | | | | boot mode) | | 0: PG03 I/O (port) | | | | (HIF boot | | 1: HIFD03 I/O (HIF) | | | | mode) | | | | 5 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 4 | PG02MD0 | 0 | R/W | PG02 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG02/HIFD02 pin. | | | | 1 | | 0: PG02 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD02 I/O (HIF) | | 3 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | 2 | PG01MD0 | 0 | R/W | PG01 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG01/HIFD01 pin. | | | | 1 | | 0: PG01 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD01 I/O (HIF) | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. The write value should always be 0. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |-----|----------|---------------------|-----|-------------------------------------------------------| | 0 | PG00MD0 | 0 | R/W | PG00 Mode | | | | (Non-HIF boot mode) | | This bit selects the function of the PG00/HIFD00 pin. | | | | 1 | | 0: PG00 I/O (port) | | | | (HIF boot<br>mode) | | 1: HIFD00 I/O (HIF) | SH7670 Group Section 24 I/O Ports # Section 24 I/O Ports This LSI has seven general I/O ports: A to G. Port A is an 9-bit I/O port, port B an 8-bit I/O port, port C a 21-bit I/O port, port D an 8-bit I/O port, port E a 12-bit I/O port, port F a 12-bit I/O port and port G a 24-bit I/O port. All port pins are multiplexed with other pin functions. The functions of the multiplexed pins are selected using the pin function controller (PFC). Each port is provided with a data register for storing the pin data. #### Port A 24.1 Port A is an I/O port with 9 pins shown in figure 24.1. Figure 24.1 Port A #### 24.1.1 **Register Descriptions** Port A is a 9-bit I/O port. Port A has the following register. Refer to section 28, List of Registers, for more details on the addresses and states of this register in each operating mode. Port A Data Register H (PADRH) Section 24 I/O Ports SH7670 Group ### 24.1.2 Port A Data Register H (PADRH) PADRH is a 16-bit readable/writable register that stores port A data. Bits PA25DR to PA17DR correspond to pins PA25 to PA17, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PADRH, and the register value is read from PADRH regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PADRH is read. Also, if a value is written to PADRH, although the value will actually be written, it will have no influence on the state of the pin. Table 24.1 summarizes the PADRH read/write operations. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|---|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | [ | - | - | - | - | - | - | - | - | PB7<br>DR | PB6<br>DR | PB5<br>DR | PB4<br>DR | PB3<br>DR | PB2<br>DR | PB1<br>DR | PB0<br>DR | | Initial value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R/W | Bit | Bit Name | Initial Value | R/W | Description | |-------|----------|---------------|-----|----------------------------------------------------------------------| | 15 to | _ | All 0 | R | Reserved | | 10 | | | | These bits are always read as 0. The write value should always be 0. | | 9 | PA25DR | 0 | R/W | See table 24.1. | | 8 | PA24DR | 0 | R/W | | | 7 | PA23DR | 0 | R/W | - | | 6 | PA22DR | 0 | R/W | - | | 5 | PA21DR | 0 | R/W | | | 4 | PA20DR | 0 | R/W | | | 3 | PA19DR | 0 | R/W | - | | 2 | PA18DR | 0 | R/W | - | | 1 | PA17DR | 0 | R/W | - | | 0 | _ | 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | SH7670 Group Section 24 I/O Ports # Table 24.1 Port A Data Registers H (PADRH) Read/Write Operations # Bits 9 to 1 of PADRH | Pin Function | PAIORH | Read | Write | |-----------------|--------|-------------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PADRH but there is no effect on the pin state. | | General output | 1 | Value of<br>PADRH | The value written is output from the pin. | | Other functions | * | Value of<br>PADRH | The value is written to PADRH but there is no effect on the pin state. | Section 24 I/O Ports SH7670 Group ### 24.2 Port B Port B is an I/O port with 8 pins shown in figure 24.2. Figure 24.2 Port B #### 24.2.1 Register Descriptions Port B is an 8-bit I/O port. Port B has the following register. Refer to section 28, List of Registers, for more details on the addresses and states of this register in each operating mode. Port B Data Register L (PBDRL) SH7670 Group Section 24 I/O Ports ## 24.2.2 Port B Data Register L (PBDRL) PBDRL is a 16-bit readable/writable register that stores port B data. Bits PB7DR to PB0DR correspond to pins PB07 to PB00, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PBDRL, and the register value is read from PBDRL regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PBDRL is read. Also, if a value is written to PBDRL, although the value will actually be written, it will have no influence on the state of the pin. Table 24.2 summarizes the PBDRL read/write operations. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|----|---|---|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | - | - | - | - | - | - | - | - | PB7<br>DR | PB6<br>DR | PB5<br>DR | PB4<br>DR | PB3<br>DR | PB2<br>DR | PB1<br>DR | PB0<br>DR | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R | R | R | R | R | R | R | R | R/W | Bit | Bit<br>Name | Initial<br>Value | R/W | Description | |----------|-------------|------------------|---------------|----------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | PB7DR | 0 | R/W | See table 24.2. | | 6 | PB6DR | 0 | R/W | _ | | 5 | PB5DR | 0 | R/W | _ | | 4 | PB4DR | 0 | R/W | _ | | 3 | PB3DR | 0 | R/W | _ | | 2 | PB2DR | 0 | R/W | - | | 1 | PB1DR | 0 | R/W | - | | 0 | PB0DR | 0 | R/W | _ | | <u> </u> | FBUDH | U | □/ <b>V</b> V | | Section 24 I/O Ports SH7670 Group # Table 24.2 Port B Data Registers L (PBDRL) Read/Write Operations Bits 7, 5 and 4 of PBDRL | Pin Function | PBIORL | Read | Write | |-----------------|--------|----------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PBDRL but there is no effect on the pin state. | | General output | 1 | Value of PBDRL | The value written is output from the pin. | | Other functions | * | Value of PBDRL | The value is written to PBDRL but there is no effect on the pin state. | ## Bits 6 and 3 to 0 of PBDRL | Pin Function | PBIORL | Read | Write | |--------------------|--------|----------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PBDRL but there is no effect on the pin state. | | Setting prohibited | 1 | _ | _ | | Other functions | * | Value of PBDRL | The value is written to PBDRL but there is no effect on the pin state. | ### 24.3 Port C Port C is an I/O port with 21 pins shown in figure 24.3. Figure 24.3 Port C # 24.3.1 Register Descriptions Port C is a 21-bit I/O port. Port C has the following registers. Refer to section 28, List of Registers, for more details on the addresses and states of these registers in each operating mode. Port C Data Register H (PCDRH) Port C Data Register L (PCDRL) #### 24.3.2 Port C Data Registers H and L (PCDRH and PCDRL) PCDRH and PCDRL are 16-bit readable/writable registers that store port C data. Bits PC20DR to PC0DR correspond to pins PC20 to PC00, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PCDRH or PCDRL, and the register value is read from PCDRH or PCDRL regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PCDRH or PCDRL is read. Also, if a value is written to PCDRH or PCDRL, although the value will actually be written, it will have no influence on the state of the pin. Table 24.3 summarizes the PCDRH and PCDRL read/write operations. ### **PCDRH** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|----|----|---|---|---|---|---|------------|------------|------------|------------|------------| | | - | - | - | - | - | - | - | - | - | - | - | PC20<br>DR | PC19<br>DR | PC18<br>DR | PC17<br>DR | PC16<br>DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R/W | R/W | R/W | R/W | R/W | | Bit | Bit<br>Name | Initial<br>Value | R/W | Description | |---------|-------------|------------------|-----|----------------------------------------------------------------------| | 15 to 5 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 4 | PC20DR | 0 | R/W | See table 24.3. | | 3 | PC19DR | 0 | R/W | - | | 2 | PC18DR | 0 | R/W | - | | 1 | PC17DR | 0 | R/W | - | | 0 | PC16DR | 0 | R/W | - | # PCDRL | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | PC15 | PC14 | PC13 | PC12 | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | | | DR | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R/W | | | Bit | Initial | | D | |-----|--------|---------|-----|---| | Bit | Name | Value | R/W | | | 15 | PC15DR | 0 | R/W | | | 14 | PC14DR | 0 | R/W | | | 13 | PC13DR | 0 | R/W | | | 12 | PC12DR | 0 | R/W | | | 11 | PC11DR | 0 | R/W | | | 10 | PC10DR | 0 | R/W | | | 9 | PC9DR | 0 | R/W | | | 8 | PC8DR | 0 | R/W | | | 7 | PC7DR | 0 | R/W | | | 6 | PC6DR | 0 | R/W | | | 5 | PC5DR | 0 | R/W | | | 4 | PC4DR | 0 | R/W | | | 3 | PC3DR | 0 | R/W | | | 2 | PC2DR | 0 | R/W | | | 1 | PC1DR | 0 | R/W | | | 0 | PC0DR | 0 | R/W | | # Table 24.3 Port C Data Registers H and L (PCDRH and PCDRL) Read/Write Operations Bits 4 to 0 of PCDRH and bits 15 to 1 of PCDRL | Pin Function | PCIORH, L | Read | Write | |-----------------|-----------|-------------------------------|---------------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PCDRH or PCDRL but there is no effect on the pin state. | | General output | 1 | Value of<br>PCDRH or<br>PCDRL | The value written is output from the pin. | | Other functions | * | Value of<br>PCDRH or<br>PCDRL | The value is written to PCDRH or PCDRL but there is no effect on the pin state. | # Bit 0 of PCDRL | Pin Function | PCIORL | Read | Write | |--------------------|--------|----------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PCDRL but there is no effect on the pin state. | | Setting prohibited | 1 | _ | _ | | Other functions | * | Value of PCDRL | The value is written to PCDRL but there is no effect on the pin state. | # 24.4 Port D Port D is an I/O port with 8 pins shown in figure 24.4. Figure 24.4 Port D ### 24.4.1 Register Descriptions Port D is an 8-bit I/O port. Port D has the following register. Refer to section 28, List of Registers, for more details on the addresses and states of this register in each operating mode. Port D Data Register L (PDDRL) ### 24.4.2 Port D Data Register L (PDDRL) PDDRL is a 16-bit readable/writable register that stores port D data. Bits PD7DR to PD0DR correspond to pins PD7 to PD0, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PDDRL, and the register value is read from PDDRL regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PDDRL is read. Also, if a value is written to PDDRL, although the value will actually be written, it will have no influence on the state of the pin. Table 24.4 summarizes the PDDRL read/write operations. | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|----|---|---|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | - | - | - | - | - | - | - | - | PD7<br>DR | PD6<br>DR | PD5<br>DR | PD4<br>DR | PD3<br>DR | PD2<br>DR | PD1<br>DR | PD0<br>DR | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | : R | R | R | R | R | R | R | R | R/W | Bit | Bit<br>Name | Initial<br>Value | R/W | Description | |---------|-------------|------------------|-----|----------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | PD7DR | 0 | R/W | See table 24.4. | | 6 | PD6DR | 0 | R/W | - | | 5 | PD5DR | 0 | R/W | - | | 4 | PD4DR | 0 | R/W | - | | 3 | PD3DR | 0 | R/W | - | | 2 | PD2DR | 0 | R/W | - | | 1 | PD1DR | 0 | R/W | - | | 0 | PD0DR | 0 | R/W | - | # Table 24.4 Port D Data Registers L (PDDRL) Read/Write Operations Bits 7, 6, and 3 to 0 of PDDRL | Pin Function | PDIORL | Read | Write | |-----------------|--------|----------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PDDRL but there is no effect on the pin state. | | General output | 1 | Value of PDDRL | The value written is output from the pin. | | Other functions | * | Value of PDDRL | The value is written to PDDRL but there is no effect on the pin state. | ### Bits 5 and 4 of PDDRL | Pin Function | PDIORL | Read | Write | |--------------------|--------|----------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PDDRL but there is no effect on the pin state. | | Setting prohibited | 1 | _ | _ | | Other functions | * | Value of PDDRL | The value is written to PDDRL but there is no effect on the pin state. | ### 24.5 Port E Port E is an I/O port with 12 pins shown in figure 24.5. Figure 24.5 Port E # 24.5.1 Register Descriptions Port E is a 12-bit I/O port. Port E has the following register. Refer to section 28, List of Registers, for more details on the addresses and states of this register in each operating mode. Port E Data Register L (PEDRL) # 24.5.2 Port E Data Register L (PEDRL) PEDRL is a 16-bit readable/writable register that stores port E data. Bits PE11DR to PE0DR correspond to pins PE11 to PE00, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PEDRL, and the register value is read from PEDRL regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PEDRL is read. Also, if a value is written to PEDRL, although the value will actually be written, it will have no influence on the state of the pin. Table 24.5 summarizes the PEDRL read/write operations. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | - | - | - | - | PE11<br>DR | PE10<br>DR | PE9<br>DR | PE8<br>DR | PE7<br>DR | PE6<br>DR | PE5<br>DR | PE4<br>DR | PE3<br>DR | PE2<br>DR | PE1<br>DR | PE0<br>DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to | _ | All 0 | R | Reserved | | 12 | | | | These bits are always read as 0. The write value should always be 0. | | 11 | PE11DR | 0 | R/W | See table 24.5. | | 10 | PE10DR | 0 | R/W | _ | | 9 | PE9DR | 0 | R/W | _ | | 8 | PE8DR | 0 | R/W | _ | | 7 | PE7DR | 0 | R/W | _ | | 6 | PE6DR | 0 | R/W | _ | | 5 | PE5DR | 0 | R/W | _ | | 4 | PE4DR | 0 | R/W | _ | | 3 | PE3DR | 0 | R/W | _ | | 2 | PE2DR | 0 | R/W | _ | | 1 | PE1DR | 0 | R/W | _ | | 0 | PE0DR | 0 | R/W | _ | # Table 24.5 Port E Data Registers L (PEDRL) Read/Write Operations Bits 11 and 0 of PEDRL | Pin Function | PEIORL | Read | Write | |-----------------|--------|-------------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PEDRL but there is no effect on the pin state. | | General output | 1 | Value of<br>PEDRL | The value written is output from the pin. | | Other functions | * | Value of<br>PEDRL | The value is written to PEDRL but there is no effect on the pin state. | #### 24.6 Port F Port F is an I/O port with 12 pins shown in figure 24.6. Figure 24.6 Port F ### 24.6.1 **Register Descriptions** Port F is an 12-bit I/O port. Port F has the following register. Refer to section 28, List of Registers, for more details on the addresses and states of this register in each operating mode. Port F Data Register L (PFDRL) # 24.6.2 Port F Data Register L (PFDRL) PFDRL is a 16-bit readable/writable register that stores port F data. Bits PF11DR to PF0DR correspond to pins PF11 to PF00, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PFDRL, and the register value is read from PFDRL regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PFDRL is read. Also, if a value is written to PFDRL, although the value will actually be written, it will have no influence on the state of the pin. Table 24.6 summarizes the PFDRL read/write operations. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|----|----|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | [ | - | - | - | - | PF11<br>DR | PF10<br>DR | PF9<br>DR | PF8<br>DR | PF7<br>DR | PF6<br>DR | PF5<br>DR | PF4<br>DR | PF3<br>DR | PF2<br>DR | PF1<br>DR | PF0<br>DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |-------|----------|------------------|-----|----------------------------------------------------------------------| | 15 to | _ | All 0 | R | Reserved | | 12 | | | | These bits are always read as 0. The write value should always be 0. | | 11 | PF11DR | 0 | R/W | See table 24.6. | | 10 | PF10DR | 0 | R/W | _ | | 9 | PF9DR | 0 | R/W | _ | | 8 | PF8DR | 0 | R/W | _ | | 7 | PF7DR | 0 | R/W | _ | | 6 | PF6DR | 0 | R/W | _ | | 5 | PF5DR | 0 | R/W | _ | | 4 | PF4DR | 0 | R/W | _ | | 3 | PF3DR | 0 | R/W | _ | | 2 | PF2DR | 0 | R/W | _ | | 1 | PF1DR | 0 | R/W | _ | | 0 | PF0DR | 0 | R/W | _ | | 0 | PF0DR | 0 | R/W | _ | # Table 24.6 Port F Data Registers L (PFDRL) Read/Write Operations Bits 11 and 0 of PFDRL | Pin Function | PFIORL | Read | Write | |-----------------|--------|-------------------|------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PFDRL but there is no effect on the pin state. | | General output | 1 | Value of<br>PFDRL | The value written is output from the pin. | | Other functions | * | Value of<br>PFDRL | The value is written to PFDRL but there is no effect on the pin state. | ### 24.7 Port G Page 1068 of 1278 Port G is an I/O port with 24 pins shown in figure 24.7. Figure 24.7 Port G # 24.7.1 Register Descriptions Port G is a 24-bit I/O port. Port G has the following registers. Refer to section 28, List of Registers, for more details on the addresses and states of these registers in each operating mode. Port G Data Register H (PGDRH) Port G Data Register L (PGDRL) # 24.7.2 Port G Data Registers H and L (PGDRH and PGDRL) PGDRH and PGDRL are 16-bit readable/writable registers that store port G data. Bits PG23DR to PG0DR correspond to pins PG23 to PG00, respectively (description of the other functions are omitted). If a pin is set to the general output function, the pin will output the value written to the corresponding bit in PGDRH or PGDRL, and the register value is read from PGDRH or PGDRL regardless of the state of the pin. If a pin is set to the general input function, the pin state, not the register value, will be returned if PGDRH or PGDRL is read. Also, if a value is written to PGDRH or PGDRL, although the value will actually be written, it will have no influence on the state of the pin. Table 24.7 summarizes the PGDRH and PGDRL read/write operations. # PGDRH | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----|----|----|----|----|---|---|------------|------------|------------|------------|------------|------------|------------|------------| | | - | - | - | - | - | - | - | - | PG23<br>DR | PG22<br>DR | PG21<br>DR | PG20<br>DR | PG19<br>DR | PG18<br>DR | PG17<br>DR | PG16<br>DR | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | . в | R | B | R | B | B | B | B | D/M | D/M | D/M | R/W | R/M | D/\/ | D/M | D/M | | Bit | Bit Name | Initial Value | R/W | Description | |---------|----------|---------------|-----|----------------------------------------------------------------------| | 15 to 8 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 7 | PG23DR | 0 | R/W | See table 24.7. | | 6 | PG22DR | 0 | R/W | - | | 5 | PG21DR | 0 | R/W | - | | 4 | PG20DR | 0 | R/W | - | | 3 | PG19DR | 0 | R/W | - | | 2 | PG18DR | 0 | R/W | - | | 1 | PG17DR | 0 | R/W | - | | 0 | PG16DR | 0 | R/W | - | # PGDRL | Bit | : 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------------|------------|------------|------------|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | PG15<br>DR | PG14<br>DR | PG13<br>DR | PG12<br>DR | PG11<br>DR | PG10<br>DR | PG9<br>DR | PG8<br>DR | PG7<br>DR | PG6<br>DR | PG5<br>DR | PG4<br>DR | PG3<br>DR | PG2<br>DR | PG1<br>DR | PG0<br>DR | | Initial value | : 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W | ': R/W | | | | Initial | | | |-----|----------|---------|-----|-----------------| | Bit | Bit Name | Value | R/W | Description | | 15 | PG15DR | 0 | R/W | See table 24.7. | | 14 | PG14DR | 0 | R/W | _ | | 13 | PG13DR | 0 | R/W | _ | | 12 | PG12DR | 0 | R/W | _ | | 11 | PG11DR | 0 | R/W | _ | | 10 | PG10DR | 0 | R/W | _ | | 9 | PG9DR | 0 | R/W | _ | | 8 | PG8DR | 0 | R/W | _ | | 7 | PG7DR | 0 | R/W | _ | | 6 | PG6DR | 0 | R/W | <del>-</del> | | 5 | PG5DR | 0 | R/W | <del>-</del> | | 4 | PG4DR | 0 | R/W | <del>-</del> | | 3 | PG3DR | 0 | R/W | <del>-</del> | | 2 | PG2DR | 0 | R/W | _ | | 1 | PG1DR | 0 | R/W | _ | | 0 | PG0DR | 0 | R/W | _ | # Table 24.7 Port G Data Registers L (PGDRL) Read/Write Operations Bits 7 to 0 of PGDRH and bits 15 to 0 of PGDRL | Pin Function | PGIORL | Read | Write | |-----------------|--------|-------------------------------|---------------------------------------------------------------------------------| | General input | 0 | Pin state | The value is written to PGDRH or PGDRL but there is no effect on the pin state. | | General output | 1 | Value of<br>PGDRH or<br>PGDRL | The value written is output from the pin. | | Other functions | * | Value of<br>PGDRH or<br>PGDRL | The value is written to PGDRH or PGDRL but there is no effect on the pin state. | # Section 25 User Break Controller (UBC) The user break controller (UBC) provides functions that simplify program debugging. These functions make it easy to design an effective self-monitoring debugger, enabling the chip to debug programs without using an in-circuit emulator. Instruction fetch or data read/write (bus master (CPU or DMAC) selection in the case of data read/write), data size, data contents, address value, and stop timing in the case of instruction fetch are break conditions that can be set in the UBC. Since this LSI uses a Harvard architecture, instruction fetch on the CPU bus (C bus) is performed by issuing bus cycles on the instruction fetch bus (F bus), and data access on the C bus is performed by issuing bus cycles on the memory access bus (M bus). The UBC monitors the C bus and internal bus (I bus). ### 25.1 Features 1. The following break comparison conditions can be set. Number of break channels: two channels (channels 0 and 1) User break can be requested as the independent condition on channels 0 and 1. Address Comparison of the 32-bit address is maskable in 1-bit units. One of the three address buses (F address bus (FAB), M address bus (MAB), and I address bus (IAB)) can be selected. Data Comparison of the 32-bit data is maskable in 1-bit units. One of the two data buses (M data bus (MDB) and I data bus (IDB)) can be selected. • Bus master when I bus is selected Selection of CPU cycles, DMAC cycles, A-DMAC (including F-DMAC) cycles, or E-DMAC cycles • Bus cycle Instruction fetch (only when C bus is selected) or data access - Read/write - Operand size Byte, word, and longword 2. In an instruction fetch cycle, it can be selected whether the start of user break interrupt exception processing is set before or after an instruction is executed. Figure 25.1 shows a block diagram of the UBC. Figure 25.1 Block Diagram of UBC # 25.2 Register Descriptions The UBC has the following registers. Five control registers for each channel and one common control register for channel 0 and channel 1 are available. A register for each channel is described as BAR\_0 for the BAR register in channel 0. **Table 25.1 Register Configuration** | Channel | Register Name | Abbrevia-<br>tion | R/W | Initial Value | Address | Access<br>Size | |---------|-------------------------------|-------------------|-----|---------------|------------|----------------| | 0 | Break address register_0 | BAR_0 | R/W | H'00000000 | H'FFFC0400 | 32 | | | Break address mask register_0 | BAMR_0 | R/W | H'00000000 | H'FFFC0404 | 32 | | | Break bus cycle register_0 | BBR_0 | R/W | H'0000 | H'FFFC04A0 | 16 | | | Break data register_0 | BDR_0 | R/W | H'00000000 | H'FFFC0408 | 32 | | | Break data mask register_0 | BDMR_0 | R/W | H'00000000 | H'FFFC040C | 32 | | 1 | Break address register_1 | BAR_1 | R/W | H'00000000 | H'FFFC0410 | 32 | | | Break address mask register_1 | BAMR_1 | R/W | H'00000000 | H'FFFC0414 | 32 | | | Break bus cycle register_1 | BBR_1 | R/W | H'0000 | H'FFFC04B0 | 16 | | | Break data register_1 | BDR_1 | R/W | H'00000000 | H'FFFC0418 | 32 | | | Break data mask register_1 | BDMR_1 | R/W | H'00000000 | H'FFFC041C | 32 | | Common | Break control register | BRCR | R/W | H'00000000 | H'FFFC04C0 | 32 | # 25.2.1 Break Address Register (BAR) BAR is a 32-bit readable/writable register. BAR specifies the address used as a break condition in each channel. The control bits CD[1:0] in the break bus cycle register (BBR) select one of the three address buses for a break condition. BAR is initialized to H'00000000 by a power-on reset, but retains its previous value by a manual reset or in software standby mode or sleep mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | BA31 | BA30 | BA29 | BA28 | BA27 | BA26 | BA25 | BA24 | BA23 | BA22 | BA21 | BA20 | BA19 | BA18 | BA17 | BA16 | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BA15 | BA14 | BA13 | BA12 | BA11 | BA10 | BA9 | BA8 | BA7 | BA6 | BA5 | BA4 | BA3 | BA2 | BA1 | BA0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|-------------|------------------|-----|-------------------------------------------------------------------------------------------------------------| | 31 to 0 | BA31 to BA0 | All 0 | R/W | Break Address | | | | | | Store an address on the CPU address bus (FAB or MAB) or IAB specifying break conditions. | | | | | | When the C bus and instruction fetch cycle are selected by BBR, specify an FAB address in bits BA31 to BA0. | | | | | | When the C bus and data access cycle are selected by BBR, specify an MAB address in bits BA31 to BA0. | Note: When setting the instruction fetch cycle as a break condition, clear the LSB in BAR to 0. # 25.2.2 Break Address Mask Register (BAMR) BAMR is a 32-bit readable/writable register. BAMR specifies bits masked in the break address bits specified by BAR. BAMR is initialized to H'00000000 by a power-on reset, but retains its previous value by a manual reset or in software standby mode or sleep mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | | BAM31 | ВАМ30 | BAM29 | BAM28 | BAM27 | BAM26 | BAM25 | BAM24 | BAM23 | BAM22 | BAM21 | BAM20 | BAM19 | BAM18 | BAM17 | BAM16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BAM15 | BAM14 | BAM13 | BAM12 | BAM11 | BAM10 | BAM9 | BAM8 | BAM7 | BAM6 | BAM5 | BAM4 | вамз | BAM2 | BAM1 | BAM0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|-------------------------------------------------------------------------------| | 31 to 0 | BAM31 to | All 0 | R/W | Break Address Mask | | | BAM0 | | | Specify bits masked in the break address bits specified by BAR (BA31 to BA0). | | | | | | Break address bit BAn is included in the break condition | | | | | | Break address bit BAn is masked and not included in the break condition | | | | | | Note: n = 31 to 0 | Page 1078 of 1278 ### 25.2.3 Break Data Register (BDR) BDR is a 32-bit readable/writable register. The control bits CD[1:0]in the break bus cycle register (BBR) select one of the two data buses for a break condition. BDR is initialized to H'00000000 by a power-on reset, but retains its previous value by a manual reset or in software standby mode or sleep mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | BD31 | BD30 | BD29 | BD28 | BD27 | BD26 | BD25 | BD24 | BD23 | BD22 | BD21 | BD20 | BD19 | BD18 | BD17 | BD16 | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BD15 | BD14 | BD13 | BD12 | BD11 | BD10 | BD9 | BD8 | BD7 | BD6 | BD5 | BD4 | BD3 | BD2 | BD1 | BD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | Initial | | | |---------|-------------|---------|-----|--------------------------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 0 | BD31 to BD0 | All 0 | R/W | Break Data Bits | | | | | | Store data which specifies a break condition. | | | | | | If the I bus is selected in BBR, specify the break data on IDB in bits BD31 to BD0. | | | | | | If the C bus is selected in BBR, specify the break data on MDB is set in bits BD31 to BD0. | Notes: 1. Set the operand size when specifying a value on a data bus as the break condition. 2. When the byte size is selected as a break condition, the same byte data must be set in bits 31 to 24, 23 to 16, 15 to 8, and 7 to 0 in BDR as the break data. Similarly, when the word size is selected, the same word data must be set in bits 31 to 16 and 15 to 0. # 25.2.4 Break Data Mask Register (BDMR) BDMR is a 32-bit readable/writable register. BDMR specifies bits masked in the break data bits specified by BDR. BDMR is initialized to H'00000000 by a power-on reset, but retains its previous value by a manual reset or in software standby mode or sleep mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | | BDM31 | BDM30 | BDM29 | BDM28 | BDM27 | BDM26 | BDM25 | BDM24 | BDM23 | BDM22 | BDM21 | BDM20 | BDM19 | BDM18 | BDM17 | BDM16 | | Initial value:<br>R/W: | 0<br>R/W | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BDM15 | BDM14 | BDM13 | BDM12 | BDM11 | BDM10 | BDM9 | BDM8 | BDM7 | BDM6 | BDM5 | BDM4 | BDM3 | BDM2 | BDM1 | BDM0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | Initial | | | |---------|----------|---------|-----|----------------------------------------------------------------------------| | Bit | Bit Name | Value | R/W | Description | | 31 to 0 | BDM31 to | All 0 | R/W | Break Data Mask | | | BDM0 | | | Specify bits masked in the break data bits specified by BDR (BD31 to BD0). | | | | | | 0: Break data bit BDn is included in the break condition | | | | | | Break data bit BDn is masked and not included in the break condition | | | | | | Note: n = 31 to 0 | Notes: 1. Set the operand size when specifying a value on a data bus as the break condition. When the byte size is selected as a break condition, the same byte data must be set in bits 31 to 24, 23 to 16, 15 to 8, and 7 to 0 in BDMR as the break mask data. Similarly, when the word size is selected, the same word data must be set in bits 31 to 16 and 15 to 0. Page 1080 of 1278 # 25.2.5 Break Bus Cycle Register (BBR) BBR is a 16-bit readable/writable register, which specifies (1) disabling or enabling of user break interrupt requests, (2) including or excluding of the data bus value, (3) bus master of the I bus, (4) C bus cycle or I bus cycle, (5) instruction fetch or data access, (6) read or write, and (7) operand size as the break conditions. BBR is initialized to H'0000 by a power-on reset, but retains its previous value by a manual reset or in software standby mode or sleep mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----|----|------|-----|-----|-----|-------|-----|-----|-------|-----|------|-----|-------|-----|------| | [ | _ | _ | UBID | DBE | | CP[ | [3:0] | | CD | [1:0] | ID[ | 1:0] | RW | [1:0] | SZ[ | 1:0] | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W· | R | R | R/W | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15, 14 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 13 | UBID | 0 | R/W | User Break Interrupt Disable | | | | | | Disables or enables user break interrupt requests when a break condition is satisfied. | | | | | | 0: User break interrupt requests enabled | | | | | | 1: User break interrupt requests disabled | | 12 | DBE | 0 | R/W | Data Break Enable | | | | | | Selects whether the data bus condition is included in the break conditions. | | | | | | Data bus condition is not included in break conditions | | | | | | 1: Data bus condition is included in break conditions | | 11 to 8 | CP[3:0] | 00 | R/W | I-Bus Bus Master Select | | | | | | Select the bus master when the bus cycle of the break condition is the I bus cycle. However, when the C bus cycle is selected, this bit is invalidated (only the CPU cycle). | | | | | | xxx1: CPU cycle is included in break conditions. | | | | | | xx1x: DMAC cycle is included in break conditions. | | | | | | x1xx: A-DMAC (including F-DMAC) cycle is included in break conditions. | | | | | | 1xxx: E-DMAC cycle is included in break conditions. | | Bit | Bit Name | Initial<br>Value | R/W | Description | |------|----------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7, 6 | CD[1:0] | 00 | R/W | C Bus Cycle/I Bus Cycle Select | | | | | | Select the C bus cycle or I bus cycle as the bus cycle of the break condition. | | | | | | 00: Condition comparison is not performed | | | | | | 01: Break condition is the C bus (F bus or M bus) cycle | | | | | | 10: Break condition is the I bus cycle | | | | | | 11: Break condition is the C bus (F bus or M bus) cycle | | 5, 4 | ID[1:0] | 00 | R/W | Instruction Fetch/Data Access Select | | | | | | Select the instruction fetch cycle or data access cycle as the bus cycle of the break condition. If the instruction fetch cycle is selected, select the C bus cycle. | | | | | | 00: Condition comparison is not performed | | | | | | 01: Break condition is the instruction fetch cycle | | | | | | 10: Break condition is the data access cycle | | | | | | <ol> <li>Break condition is the instruction fetch cycle or<br/>data access cycle</li> </ol> | | 3, 2 | RW[1:0] | 00 | R/W | Read/Write Select | | | | | | Select the read cycle or write cycle as the bus cycle of the break condition. | | | | | | 00: Condition comparison is not performed | | | | | | 01: Break condition is the read cycle | | | | | | 10: Break condition is the write cycle | | | | | | 11: Break condition is the read cycle or write cycle | | 1, 0 | SZ[1:0] | 00 | R/W | Operand Size Select | | | | | | Select the operand size of the bus cycle for the break condition. | | | | | | 00: Break condition does not include operand size | | | | | | 01: Break condition is byte access | | | | | | 10: Break condition is word access | | | | | | 11: Break condition is longword access | [Legend] x: Don't care # 25.2.6 Break Control Register (BRCR) BRCR sets the following conditions: 1. Specifies whether a start of user break interrupt exception processing by instruction fetch cycle is set before or after instruction execution. BRCR is a 32-bit readable/writable register that has break condition match flags and bits for setting other break conditions. For the condition match flags of bits 15 to 12, writing 1 is invalid (previous values are retained) and writing 0 is only possible. To clear the flag, write 0 to the flag bit to be cleared and 1 to all other flag bits. BRCR is initialized to H'00000000 by a power-on reset, but retains its previous value by a manual reset or in software standby mode or sleep mode. | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----------------|------------|------------|------------|------------|----|----|----|----|----|------|------|----|----|----|----|----| | | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | _ | _ | | - | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | | | | | | | | | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 5 | SCMFC<br>0 | SCMFC<br>1 | SCMFD<br>0 | SCMFD<br>1 | _ | _ | - | - | _ | PCB1 | PCB0 | _ | _ | 1 | _ | _ | | Initial Value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R | R | R | R | R | R/W | R/W | R | R | R | R | R | | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 to 16 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 15 | SCMFC0 | 0 | R/W | C Bus Cycle Condition Match Flag 0 | | | | | | When the C bus cycle condition in the break conditions set for channel 0 is satisfied, this flag is set to 1. In order to clear this flag, write 0 to this bit. | | | | | | 0: The C bus cycle condition for channel 0 does not match | | | | | | 1: The C bus cycle condition for channel 0 matches | | Bit | Bit Name | Initial<br>Value | R/W | Description | |---------|----------|------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 | SCMFC1 | 0 | R/W | C Bus Cycle Condition Match Flag 1 | | | | | | When the C bus cycle condition in the break conditions set for channel 1 is satisfied, this flag is set to 1. In order to clear this flag, write 0 to this bit. | | | | | | The C bus cycle condition for channel 1 does not match | | | | | | 1: The C bus cycle condition for channel 1 matches | | 13 | SCMFD0 | 0 | R/W | I Bus Cycle Condition Match Flag 0 | | | | | | When the I bus cycle condition in the break conditions set for channel 0 is satisfied, this flag is set to 1. In order to clear this flag, write 0 to this bit. | | | | | | 0: The I bus cycle condition for channel 0 does not match | | | | | | 1: The I bus cycle condition for channel 0 matches | | 12 | SCMFD1 | 0 | R/W | I Bus Cycle Condition Match Flag 1 | | | | | | When the I bus cycle condition in the break conditions set for channel 1 is satisfied, this flag is set to 1. In order to clear this flag, write 0 to this bit. | | | | | | 0: The I bus cycle condition for channel 1 does not match | | | | | | 1: The I bus cycle condition for channel 1 matches | | 11 to 7 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | | 6 | PCB1 | 0 | R/W | PC Break Select 1 | | | | | | Selects the break timing of the instruction fetch cycle for channel 1 as before or after instruction execution. | | | | | | <ol> <li>PC break of channel 1 is generated before<br/>instruction execution</li> </ol> | | | | | | 1: PC break of channel 1 is generated after instruction execution | | 5 | PCB0 | 0 | R/W | PC Break Select 0 | | | | | | Selects the break timing of the instruction fetch cycle for channel 0 as before or after instruction execution. | | | | | | <ol> <li>PC break of channel 0 is generated before<br/>instruction execution</li> </ol> | | | | | | 1: PC break of channel 0 is generated after instruction execution | | 4 to 0 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0. The write value should always be 0. | # 25.3 Operation ### 25.3.1 Flow of the User Break Operation The flow from setting of break conditions to user break interrupt exception handling is described below: - 1. The break address is set in a break address register (BAR). The masked address bits are set in a break address mask register (BAMR). The break data is set in the break data register (BDR). The masked data bits are set in the break data mask register (BDMR). The bus break conditions are set in the break bus cycle register (BBR). Three control bit groups of BBR (C bus cycle/I bus cycle select, instruction fetch/data access select, and read/write select) are each set. No user break will be generated if even one of these groups is set to 00. The relevant break control conditions are set in the bits of the break control register (BRCR). Make sure to set all registers related to breaks before setting BBR, and branch after reading from the last written register. The newly written register values become valid from the instruction at the branch destination. - 2. In the case where the break conditions are satisfied and the user break interrupt request is enabled, the UBC sends a user break interrupt request to the INTC, sets the C bus condition match flag (SCMFC) or I bus condition match flag (SCMFD) for the appropriate channel. - 3. On receiving a user break interrupt request signal, the INTC determines its priority. Since the user break interrupt has a priority level of 15, it is accepted when the priority level set in the interrupt mask level bits (I3 to I0) of the status register (SR) is 14 or lower. If the I3 to I0 bits are set to a priority level of 15, the user break interrupt is not accepted, but the conditions are checked, and condition match flags are set if the conditions match. For details on ascertaining the priority, see section 6, Interrupt Controller (INTC). - 4. Condition match flags (SCMFC and SCMFD) can be used to check which condition has been satisfied. Clear the condition match flags during the user break interrupt exception processing routine. The interrupt occurs again if this operation is not performed. - 5. There is a chance that the break set in channel 0 and the break set in channel 1 occur around the same time. In this case, there will be only one user break request to the INTC, but these two break channel match flags may both be set. - 6. When selecting the I bus as the break condition, note as follows: - Several bus masters, including the CPU, DMAC, A-DMAC (including F-DMAC), and E-DMAC, are connected to the I bus. The UBC monitors bus cycles generated by the bus master specified by BBR, and determines the condition match. - Whether or not an access issued on the C bus by the CPU is issued on the I bus depends on the cache settings. Regarding the I bus operation under cache conditions, see table 4.8 in section 4, Cache. - When a break condition is specified for the I bus, only the data access cycle is monitored. The instruction fetch cycle (including the cache renewal cycle) is not monitored. - The DMAC only issues data access cycles for I bus cycles. - If a break condition is specified for the I bus, even when the condition matches in an I bus cycle resulting from an instruction executed by the CPU, at which instruction the user break interrupt request is to be accepted cannot be clearly defined. #### 25.3.2 **Break on Instruction Fetch Cycle** - 1. When C bus/instruction fetch/read/word or longword is set in the break bus cycle register (BBR), the break condition is the FAB bus instruction fetch cycle. Whether a start of user break interrupt exception processing is set before or after the execution of the instruction can then be selected with the PCB0 or PCB1 bit of the break control register (BRCR) for the appropriate channel. If an instruction fetch cycle is set as a break condition, clear BA0 bit in the break address register (BAR) to 0. A break cannot be generated as long as this bit is set to 1. - 2. A break for instruction fetch which is set as a break before instruction execution occurs when it is confirmed that the instruction has been fetched and will be executed. This means a break does not occur for instructions fetched by overrun (instructions fetched at a branch or during an interrupt transition, but not to be executed). When this kind of break is set for the delay slot of a delayed branch instruction, the user break interrupt request is not received until the execution of the first instruction at the branch destination. If a branch does not occur at a delayed branch instruction, the subsequent instruction is not recognized as a delay slot. - 3. When setting a break condition for break after instruction execution, the instruction set with the break condition is executed and then the break is generated prior to execution of the next instruction. As with pre-execution breaks, a break does not occur with overrun fetch instructions. When this kind of break is set for a delayed branch instruction and its delay slot, the user break interrupt request is not received until the first instruction at the branch destination. - 4. When an instruction fetch cycle is set, the break data register (BDR) is ignored. Therefore, break data cannot be set for the break of the instruction fetch cycle. - 5. If the I bus is set for a break of an instruction fetch cycle, the setting is invalidated. ### 25.3.3 Break on Data Access Cycle - 1. If the C bus is specified as a break condition for data access break, condition comparison is performed for the addresses (and data) accessed by the executed instructions, and a break occurs if the condition is satisfied. If the I bus is specified as a break condition, condition comparison is performed for the addresses (and data) of the data access cycles that are issued by the bus master specified by the bits to select the bus master of the I bus, and a break occurs if the condition is satisfied. For details on the CPU bus cycles issued on the I bus, see 6 in section 25.3.1, Flow of the User Break Operation. - 2. The relationship between the data access cycle address and the comparison condition for each operand size is listed in table 25.2. Table 25.2 Data Access Cycle Addresses and Operand Size Comparison Conditions | Access Size | Address Compared | |-------------|--------------------------------------------------------------------------| | Longword | Compares break address register bits 31 to 2 to address bus bits 31 to 2 | | Word | Compares break address register bits 31 to 1 to address bus bits 31 to 1 | | Byte | Compares break address register bits 31 to 0 to address bus bits 31 to 0 | This means that when address H'00001003 is set in the break address register (BAR), for example, the bus cycle in which the break condition is satisfied is as follows (where other conditions are met). Longword access at H'00001000 Word access at H'00001002 Byte access at H'00001003 - 3. When the data value is included in the break conditions: - When the data value is included in the break conditions, either longword, word, or byte is specified as the operand size in the break bus cycle register (BBR). When data values are included in break conditions, a break is generated when the address conditions and data conditions both match. To specify byte data for this case, set the same data in the four bytes at bits 31 to 24, 23 to 16, 15 to 8, and 7 to 0 of the break data register (BDR) and break data mask register (BDMR). To specify word data for this case, set the same data in the two words at bits 31 to 16 and 15 to 0. - 4. Access by a PREF instruction is handled as read access in longword units without access data. Therefore, if including the value of the data bus when a PREF instruction is specified as a break condition, a break will not occur. - 5. If the data access cycle is selected, the instruction at which the break will occur cannot be determined. ### 25.3.4 Value of Saved Program Counter When a user break interrupt request is received, the address of the instruction from where execution is to be resumed is saved to the stack, and the exception handling state is entered. If the C bus (FAB)/instruction fetch cycle is specified as a break condition, the instruction at which the break should occur can be uniquely determined. If the C bus/data access cycle or I bus/data access cycle is specified as a break condition, the instruction at which the break should occur cannot be uniquely determined. - 1. When C bus (FAB)/instruction fetch (before instruction execution) is specified as a break condition: - The address of the instruction that matched the break condition is saved to the stack. The instruction that matched the condition is not executed, and the break occurs before it. However when a delay slot instruction matches the condition, the instruction is executed, and the branch destination address is saved to the stack. - 2. When C bus (FAB)/instruction fetch (after instruction execution) is specified as a break condition: - The address of the instruction following the instruction that matched the break condition is saved to the stack. The instruction that matches the condition is executed, and the break occurs before the next instruction is executed. However when a delayed branch instruction or delay slot matches the condition, the instruction is executed, and the branch destination address is saved to the stack. - 3. When C bus/data access cycle or I bus/data access cycle is specified as a break condition: The address after executing several instructions of the instruction that matched the break condition is saved to the stack. ### 25.3.5 Usage Examples ### (1) Break Condition Specified for C Bus Instruction Fetch Cycle (Example 1-1) • Register specifications BAR\_0 = H'00000404, BAMR\_0 = H'00000000, BBR\_0 = H'0054, BAR\_1 = H'00008010, BAMR\_1 = H'00000006, BBR\_1 = H'0054, BDR\_1 = H'00000000, BDMR\_1 = H'00000000, BRCR = H'00000020 <Channel 0> Address: H'00000404, Address mask: H'00000000 Bus cycle: C bus/instruction fetch (after instruction execution)/read (operand size is not included in the condition) <Channel 1> Address: H'00008010, Address mask: H'00000006 Data: H'00000000, Data mask: H'00000000 Bus cycle: C bus/instruction fetch (before instruction execution)/read (operand size is not included in the condition) A user break occurs after an instruction of address H'00000404 is executed or before instructions of addresses H'00008010 to H'00008016 are executed. ### (Example 1-2) Register specifications BAR\_0 = H'00027128, BAMR\_0 = H'00000000, BBR\_0 = H'005A, BAR\_1 = H'00031415, BAMR\_1 = H'00000000, BBR\_1 = H'0054, BDR\_1 = H'00000000, BDMR\_1 = H'00000000, BRCR = H'00000000 <Channel 0> Address: H'00027128, Address mask: H'00000000 Bus cycle: C bus/instruction fetch (before instruction execution)/write/word <Channel 1> Address: H'00031415, Address mask: H'00000000 Data: H'00000000, Data mask: H'00000000 Bus cycle: C bus/instruction fetch (before instruction execution)/read (operand size is not included in the condition) On channel 0, a user break does not occur since instruction fetch is not a write cycle. On channel 1, a user break does not occur since instruction fetch is performed for an even address. ### (Example 1-3) ### • Register specifications BAR\_0 = H'00008404, BAMR\_0 = H'00000FFF, BBR\_0 = H'0054, BAR\_1 = H'00008010, BAMR\_1 = H'00000006, BBR\_1 = H'0054, BDR\_1 = H'00000000, BDMR\_1 = H'00000000, BRCR = H'00000020 <Channel 0> Address: H'00008404, Address mask: H'00000FFF Bus cycle: C bus/instruction fetch (after instruction execution)/read (operand size is not included in the condition) <Channel 1> Address: H'00008010, Address mask: H'00000006 Data: H'00000000, Data mask: H'00000000 Bus cycle: C bus/instruction fetch (before instruction execution)/read (operand size is not included in the condition) A user break occurs after an instruction with addresses H'00008000 to H'00008FFE is executed or before an instruction with addresses H'00008010 to H'00008016 are executed. ### (2) Break Condition Specified for C Bus Data Access Cycle (Example 2-1) # • Register specifications BAR\_0 = H'00123456, BAMR\_0 = H'00000000, BBR\_0 = H'0064, BAR\_1 = H'000ABCDE, BAMR\_1 = H'000000FF, BBR\_1 = H'106A, BDR\_1 = H'A512A512, $BDMR_1 = H'000000000, BRCR = H'000000000$ <Channel 0> Address: H'00123456, Address mask: H'00000000 Bus cycle: C bus/data access/read (operand size is not included in the condition) <Channel 1> Address: H'000ABCDE, Address mask: H'000000FF Data: H'0000A512, Data mask: H'00000000 Bus cycle: C bus/data access/write/word On channel 0, a user break occurs with longword read from address H'00123456, word read from address H'00123456, or byte read from address H'00123456. On channel 1, a user break occurs when word H'A512 is written in addresses H'000ABC00 to H'000ABCFE. # (3) Break Condition Specified for I Bus Data Access Cycle (Example 3-1) ### • Register specifications BAR\_0 = H'00314156, BAMR\_0 = H'00000000, BBR\_0 = H'0094, BAR\_1 = H'00055555, BAMR\_1 = H'00000000, BBR\_1 = H'12A9, BDR\_1 = H'78787878, BDMR\_1 = H'0F0F0F0F0F, BRCR = H'00000000 <Channel 0> Address: H'00314156, Address mask: H'00000000 Bus cycle: I bus/instruction fetch/read (operand size is not included in the condition) <Channel 1> Address: H'00055555, Address mask: H'00000000 Data: H'00000078, Data mask: H'0000000F Bus cycle: I bus/data access/write/byte On channel 0, the setting of I bus/instruction fetch is ignored. On channel 1, a user break occurs when the DMAC writes byte data H'7x in address H'00055555 on the I bus (write by the CPU does not generate a user break). ## 25.4 Usage Notes - The CPU can read from or write to the UBC registers via the I bus. Accordingly, during the period from executing an instruction to rewrite the UBC register till the new value is actually rewritten, the desired break may not occur. In order to know the timing when the UBC register is changed, read from the last written register. Instructions after then are valid for the newly written register value. - 2. The UBC cannot monitor access to the C bus and I bus cycles in the same channel. - 3. When a user break interrupt request and another exception source occur at the same instruction, which has higher priority is determined according to the priority levels defined in table 5.1 in section 5, Exception Handling. If an exception source with higher priority occurs, the user break interrupt request is not received. - 4. Note the following when a break occurs in a delay slot. If a pre-execution break is set at a delay slot instruction, the user break interrupt request is not received immediately before execution of the branch destination. - 5. User breaks are disabled during UBC module standby mode. Do not read from or write to the UBC registers during UBC module standby mode; the values are not guaranteed. - 6. Do not set an address within an interrupt exception handling routine whose interrupt priority level is at least 15 (including user break interrupts) as a break address. - 7. Do not set break after instruction execution for the SLEEP instruction or for the delayed branch instruction where the SLEEP instruction is placed at its delay slot. - 8. When setting a break for a 32-bit instruction, set the address where the upper 16 bits are placed. If the address of the lower 16 bits is set and a break before instruction execution is set as a break condition, the break is handled as a break after instruction execution. - 9. Do not set a user break before instruction execution for the instruction following the DIVU or DIVS instruction. If a user break before instruction execution is set for the instruction following the DIVU or DIVS instruction and an exception or interrupt occurs during execution of the DIVU or DIVS instruction, a user break occurs before instruction execution even though execution of the DIVU or DIVS instruction is halted. - 10. Do not set a user break both before instruction execution and after instruction execution for instruction of the same address. If, for example, a user break before instruction execution on channel 0 and a user break after instruction on channel 1 are set at the instruction of the same address, the condition match flag for the channel 1 is set even though a user break on channel 0 occurs before instruction execution. # Section 26 High-Performance User Debugging Interface (H-UDI) This LSI incorporates a high-performance user debugging interface (H-UDI) for emulator support. ## 26.1 Features The high-performance user debugging interface (H-UDI) has reset and interrupt request functions. The H-UDI in this LSI is used for emulator connection. Refer to the emulator's manual for the method of connecting the emulator. Figure 26.1 shows a block diagram of the H-UDI. Figure 26.1 Block Diagram of H-UDI ## 26.2 Input/Output Pins **Table 26.1 Pin Configuration** | Pin Name | Symbol | I/O | Function | |------------------------------------------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | H-UDI serial data input/output clock pin | TCK | Input | Data is serially supplied to the H-UDI from the data input pin (TDI), and output from the data output pin (TDO), in synchronization with this clock. | | Mode select input pin | TMS | Input | The state of the TAP control circuit is determined by changing this signal in synchronization with TCK. For the protocol, see figure 26.2. | | H-UDI reset input pin | TRST | Input | Input is accepted asynchronously with respect to TCK, and when low, the H-UDI is reset. TRST must be low for a constant period when power is turned on regardless of using the H-UDI function. See section 26.4.2, Reset Configuration, for more information. | | H-UDI serial data input pin | TDI | Input | Data transfer to the H-UDI is executed by changing this signal in synchronization with TCK. | | H-UDI serial data output pin | TDO | Output | Data read from the H-UDI is executed by reading this pin in synchronization with TCK. The initial value of the data output timing is the TCK falling edge. This can be changed to the TCK rising edge by inputting the TDO change timing switch command to SDIR. See section 26.4.3, TDO Output Timing, for more information. | | ASE mode select pin | ASEMD* | Input | If a low level is input at the $\overline{\text{ASEMD}}$ pin while the $\overline{\text{RES}}$ pin is asserted, ASE mode is entered; if a high level is input, normal mode is entered. In ASE mode, dedicated emulator function can be used. The input level at the $\overline{\text{ASEMD}}$ pin should be held for at least one cycle after $\overline{\text{RES}}$ negation. | Note: \* When the emulator is not in use, fix this pin to the high level. ## **26.3** Register Descriptions The H-UDI has the following registers. **Table 26.2 Register Configuration** | Register Name | Abbreviation | R/W | Initial Value | Address | Access Size | |----------------------|--------------|-----|---------------|------------|-------------| | Bypass register | SDBPR | _ | _ | _ | _ | | Instruction register | SDIR | R | H'EFFD | H'FFFE2000 | 16 | ## 26.3.1 Bypass Register (SDBPR) SDBPR is a 1-bit register that cannot be accessed by the CPU. When SDIR is set to BYPASS mode, SDBPR is connected between H-UDI pins TDI and TDO. The initial value is undefined. ## 26.3.2 Instruction Register (SDIR) SDIR is a 16-bit read-only register. It is initialized by $\overline{\text{TRST}}$ assertion or in the TAP test-logic-reset state, and can be written to by the H-UDI irrespective of the CPU mode. Operation is not guaranteed if a reserved command is set in this register. The initial value is H'EFFD. Note: \* The initial value of the TI[7:0] bits is a reserved value. When setting a command, the TI[7:0] bits must be set to another value. | Bit | Bit Name | Initial Value | R/W | Description | |---------|----------|---------------|-----|--------------------------------------------------------------------------| | 15 to 8 | TI[7:0] | 111011111* | R | Test Instruction | | | | | | The H-UDI instruction is transferred to SDIR by a serial input from TDI. | | | | | | For commands, see table 26.3. | | 7 to 2 | _ | All 1 | R | Reserved | | | | | | These bits are always read as 1. | | 1 | _ | 0 | R | Reserved | | | | | | This bit is always read as 0. | | 0 | _ | 1 | R | Reserved | | | | | | This bit is always read as 1. | Table 26.3 H-UDI Commands Bits 15 to 8 | TI7 | TI6 | TI5 | TI4 | TI3 | TI2 | TI1 | TI0 | Description | |------------------|-----|-----|-----|----------|-----|-----|-----|--------------------------| | 0 | 1 | 1 | 0 | _ | _ | _ | _ | H-UDI reset negate | | 0 | 1 | 1 | 1 | _ | _ | _ | _ | H-UDI reset assert | | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | TDO change timing switch | | 1 | 0 | 1 | 1 | _ | _ | _ | _ | H-UDI interrupt | | 1 | 1 | 1 | 1 | _ | _ | _ | _ | BYPASS mode | | Other than above | | | | Reserved | | | | | ## 26.4 Operation ### 26.4.1 TAP Controller Figure 26.2 shows the internal states of the TAP controller. Figure 26.2 TAP Controller State Transitions Note: The transition condition is the TMS value at the rising edge of TCK. The TDI value is sampled at the rising edge of TCK; shifting occurs at the falling edge of TCK. For details on change timing of the TDO value, see section 26.4.3, TDO Output Timing. The TDO is at high impedance, except with shift-DR and shift-IR states. During the change to $\overline{TRST} = 0$ , there is a transition to test-logic-reset asynchronously with TCK. ## 26.4.2 Reset Configuration **Table 26.4 Reset Configuration** | ASEMD*1 | RES | TRST | Chip State | |---------|-----|------|--------------------------------| | Н | L | L | Power-on reset and H-UDI reset | | | | Н | Power-on reset | | | Н | L | H-UDI reset only | | | | Н | Normal operation | | L | L | L | Reset hold*2 | | | | Н | Power-on reset | | | Н | L | H-UDI reset only | | | | Н | Normal operation | Notes: 1. Performs normal mode and ASE mode settings ASEMD = H. normal mode $\overline{\mathsf{ASEMD}} = \mathsf{L}$ , ASE mode 2. In ASE mode, reset hold is entered if the TRST pin is driven low while the RES pin is negated. In this state, the CPU does not start up. When TRST is driven high, H-UDI operation is enabled, but the CPU does not start up. The reset hold state is cancelled by a power-on reset. #### 26.4.3 **TDO Output Timing** The initial value of the TDO change timing is to perform data output from the TDO pin on the TCK falling edge. However, setting a TDO change timing switch command in SDIR via the H-UDI pin and passing the Update-IR state synchronizes the TDO change timing to the TCK rising edge. Hereafter, to synchronize the change timing of TDO to the falling edge of TCK, the $\overline{\text{TRST}}$ pin must be simultaneously asserted with the power-on reset. In a case of power-on reset by the RES pin, the sync reset is still in operation for a certain period in the LSI even after the RES pin is negated. Thus, if the $\overline{TRST}$ pin is asserted immediately after the negate of the $\overline{RES}$ pin, the TDO change timing switch command is cleared, resulting the TDO change timing synchronized with the falling edge of TCK. To prevent this, make sure to put a period of 20 times of tcyc or longer between the signal change timing of the $\overline{RES}$ and $\overline{TRST}$ pins. Figure 26.3 H-UDI Data Transfer Timing ### **26.4.4** H-UDI Reset An H-UDI reset is executed by setting an H-UDI reset assert command in SDIR. An H-UDI reset is of the same kind as a power-on reset. An H-UDI reset is released by setting an H-UDI reset negate command. The required time between the H-UDI reset assert command and H-UDI reset negate command is the same as time for keeping the $\overline{RES}$ pin low to apply a power-on reset. Figure 26.4 H-UDI Reset ## 26.4.5 H-UDI Interrupt The H-UDI interrupt function generates an interrupt by setting a command from the H-UDI in SDIR. An H-UDI interrupt is a general exception/interrupt operation, resulting in fetching the exception service routine start address from the exception handling vector table, jumping to that address, and starting program execution from that address. This interrupt request has a fixed priority level of 15. H-UDI interrupts are accepted in sleep mode, but not in software standby mode. #### 26.5 **Usage Notes** - 1. An H-UDI command, once set, will not be modified as long as another command is not set again from the H-UDI. If the same command is to be set continuously, the command must be set after a command (BYPASS mode, etc.) that does not affect chip operations is once set. - 2. In software standby mode and H-UDI module standby state, all of the functions in the H-UDI cannot be used. To retain the TAP status before and after standby mode, keep TCK high before entering standby mode. - 3. Regardless of whether the H-UDI is used, the $\overline{\text{TRST}}$ pin needs to be kept low at power-on to initialize the H-UDI. This can be done by treating the TRST pin as described in the emulator's manual in a board to which an emulator is to be connected, and by pulling down the $\overline{TRST}$ pin in a board to which no emulator is connected. - 4. Make sure to put 20 $t_{cvc}$ or more between the signal change timing of the $\overline{RES}$ and $\overline{TRST}$ pins. - 5. When starting the TAP controller after the negation of the $\overline{TRST}$ pin, make sure to allow 200 ns or more after the negation. - 6. In a board to which an emulator is to be connected, treat the TCK, TMS, TDI, and TDO pins as described in the emulator's manual. In a board to which no emulator is connected, the TCK pin should be pulled up and the TMS, TDI, and TDO pins left open. Though TMS and TDI are input-only pins, leaving them open will not cause any problem because this LSI incorporates pull-up resistors. ## Section 27 On-Chip RAM This LSI has an on-chip RAM module which can be used to store instructions or data. On-chip RAM operation and write access to the RAM can be enabled or disabled through the RAM enable bits and RAM write enable bits. #### 27.1 **Features** Pages The on-chip RAM is divided into four pages (pages 0 to 3). Memory map The on-chip RAM is located in the address spaces shown in table 27.1. Table 27.1 On-Chip RAM Address Spaces | | 32 Kbytes | |--------|--------------------------| | Page | Address | | Page 0 | H'FFF80000 to H'FFF81FFF | | Page 1 | H'FFF82000 to H'FFF83FFF | | Page 2 | H'FFF84000 to H'FFF85FFF | | Page 3 | H'FFF86000 to H'FFF87FFF | ### **Ports** Each page has two independent read and write ports and is connected to the internal bus (I bus), CPU instruction fetch bus (F bus), and CPU memory access bus (M bus). (Note that the F bus is connected only to the read ports.) The F bus and M bus are used for access by the CPU, and the I bus is used for access by the DMAC. ## Priority When the same page is accessed from different buses simultaneously, the access is processed according to the priority. The priority is I bus > M bus > F bus. ## 27.2 Usage Notes ### 27.2.1 Page Conflict When the same page is accessed from different buses simultaneously, a conflict on the page occurs. Although each access is completed correctly, this kind of conflict degrades the memory access speed. Therefore, it is advisable to provide software measures to prevent such conflicts as far as possible. For example, no conflict will arise if different pages are accessed by each bus. ### 27.2.2 RAME and RAMWE Bits Before disabling memory operation or write access through the RAME or RAMWE bit, be sure to read from any address and then write to the same address in each page; otherwise, the last written data in each page may not be actually written to the RAM. ``` // For page 0 MOV.L #H'FFF80000,R0 MOV.L @R0,R1 MOV.L R1,@R0 // For page 1 MOV.L #H'FFF82000,R0 MOV.L @RO,R1 MOV.L R1, @R0 // For page 2 MOV.L #H'FFF84000,R0 MOV.L @R0,R1 MOV.L R1, @R0 // For page 3 MOV.L #H'FFF86000,R0 MOV.L @R0,R1 MOV.L R1,@R0 ``` Figure 27.1 Examples of Read/Write before Disabling RAM ## Section 28 List of Registers This section gives information on the on-chip I/O registers of this LSI as follows. ## 1. Register Addresses (by functional module, in order of the manual's section numbers): - Registers are described by functional module, in order of the manual's section numbers. - Access to reserved addresses that are not described in this list of register addresses is prohibited. - When addresses consist of 16 or 32 bits, the addresses of the MSBs are given on the assumption that big-endian mode is selected. ## 2. Register Bits: - Bit configurations of the registers are described in the same order as the list of register addresses (by functional module, in order of the manual's section numbers). - Reserved bits are indicated by "—" in the bit name. - No entry in the bit-name column indicates that the whole register is allocated as a counter or for holding data. ## 3. Register States in Each Operating Mode: - States of the registers are described in the same order as the list of register addresses (by functional module, in order of the manual's section numbers). - For the initial state of each bit, refer to the description of the register in the corresponding section. - The register states described are for basic operating modes. If there is a specific reset for an onchip peripheral module, refer to the section on that on-chip peripheral module. ## 4. Cautions Required when Writing into Registers in On-Chip Peripheral Modules: Accessing a register in an on-chip peripheral module takes at least two cycles of the peripheral module clock $(P\phi)$ from the internal bus. When, meanwhile, writing from the CPU to an on-chip peripheral module, the CPU executes subsequent instructions without waiting for the register writing to be completed. Here is an example involving a state transition to software standby mode for the purpose of reducing power consumption. This transition requires a SLEEP instruction to be executed after the SYBY bit of the STBCR register is set to 1. Before the execution of the SLEEP instruction, actually, it is necessary to read the STBCR register on a dummy basis. In the absence of dummy reading, the CPU executes the SLEEP instruction before the SYBY bit is set to 1, so that the state occurring after the transition will be not software standby mode, but sleep mode. Dummy-reading the STBCR register is thus required to wait until writing into the STBY bit is completed. If, as in this example, you want to reflect the change from an on-chip peripheral register at the time of execution of a subsequent instruction, you should dummy-read the same register after the register write instruction and then execute the subsequent instruction of the target. # 28.1 Register Addresses (by Functional Module, in Order of the Manual's Section Numbers) Entries under Access Size indicate the numbers of bits. Note: Access to undefined or reserved addresses is prohibited. Since operation or continued operation is not guaranteed when these registers are accessed, do not attempt such access. | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|--------------------------------|--------------|----------------|------------|----------------| | Cache | Cache control register 1 | CCR1 | 32 | H'FFFC1000 | 32 | | | Cache control register 2 | CCR2 | 32 | H'FFFC1004 | 32 | | INTC | Interrupt control register 0 | ICR0 | 16 | H'FFFE0800 | 16/32 | | | Interrupt control register 1 | ICR1 | 16 | H'FFFE0802 | 16/32 | | | IRQ interrupt request register | IRQRR | 16 | H'FFFE0806 | 16/32 | | | Bank control register | IBCR | 16 | H'FFFE080C | 16/32 | | | Bank number register | IBNR | 16 | H'FFFE080E | 16/32 | | | Interrupt priority register 01 | IPR01 | 16 | H'FFFE0818 | 16/32 | | | Interrupt priority register 02 | IPR02 | 16 | H'FFFE081A | 16/32 | | | Interrupt priority register 06 | IPR06 | 16 | H'FFFE0C00 | 16/32 | | | Interrupt priority register 07 | IPR07 | 16 | H'FFFE0C02 | 16/32 | | | Interrupt priority register 08 | IPR08 | 16 | H'FFFE0C04 | 16/32 | | | Interrupt priority register 09 | IPR09 | 16 | H'FFFE0C06 | 16/32 | | | Interrupt priority register 10 | IPR10 | 16 | H'FFFE0C08 | 16/32 | | | Interrupt priority register 11 | IPR11 | 16 | H'FFFE0C0A | 16/32 | | | Interrupt priority register 12 | IPR12 | 16 | H'FFFE0C0C | 16/32 | | | Interrupt priority register 13 | IPR13 | 16 | H'FFFE0C0E | 16/32 | | | Interrupt priority register 14 | IPR14 | 16 | H'FFFE0C10 | 16/32 | | | Interrupt priority register 15 | IPR15 | 16 | H'FFFE0C12 | 16/32 | | | Interrupt priority register 16 | IPR16 | 16 | H'FFFE0C14 | 16/32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-------------------------------------------|--------------|----------------|------------|----------------| | BSC | Common control register | CMNCR | 32 | H'FFFC0000 | 32 | | | CS0 space bus control register | CS0BCR | 32 | H'FFFC0004 | 32 | | | CS3 space bus control register | CS3BCR | 32 | H'FFFC0010 | 32 | | | CS4 space bus control register | CS4BCR | 32 | H'FFFC0014 | 32 | | | CS5 space bus control register | CS5BCR | 32 | H'FFFC0018 | 32 | | | CS6 space bus control register | CS6BCR | 32 | H'FFFC001C | 32 | | | CS0 space wait control register | CS0WCR | 32 | H'FFFC0028 | 32 | | | CS3 space wait control register | CS3WCR | 32 | H'FFFC0034 | 32 | | | CS4 space wait control register | CS4WCR | 32 | H'FFFC0038 | 32 | | | CS5 space wait control register | CS5WCR | 32 | H'FFFC003C | 32 | | | CS6 space wait control register | CS6WCR | 32 | H'FFFC0040 | 32 | | | SDRAM control register | SDCR | 32 | H'FFFC004C | 32 | | | Refresh timer control/status register | RTCSR | 32 | H'FFFC0050 | 32 | | | Refresh timer counter | RTCNT | 32 | H'FFFC0054 | 32 | | | Refresh time constant register | RTCOR | 32 | H'FFFC0058 | 32 | | | Internal bus master bus priority register | IBMPR | 32 | H'FFFC1818 | 32 | | DMAC | DMA source address register_0 | SAR_0 | 32 | H'FFFE1000 | 16/32 | | | DMA destination address register_0 | DAR_0 | 32 | H'FFFE1004 | 16/32 | | | DMA transfer count register_0 | DMATCR_0 | 32 | H'FFFE1008 | 16/32 | | | DMA channel control register_0 | CHCR_0 | 32 | H'FFFE100C | 8/16/32 | | | DMA source address register_1 | SAR_1 | 32 | H'FFFE1010 | 16/32 | | | DMA destination address register_1 | DAR_1 | 32 | H'FFFE1014 | 16/32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|------------------------------------|--------------|----------------|------------|----------------| | DMAC | DMA transfer count register_1 | DMATCR_1 | 32 | H'FFFE1018 | 16/32 | | | DMA channel control register_1 | CHCR_1 | 32 | H'FFFE101C | 8/16/32 | | | DMA source address register_2 | SAR_2 | 32 | H'FFFE1020 | 16/32 | | | DMA destination address register_2 | DAR_2 | 32 | H'FFFE1024 | 16/32 | | | DMA transfer count register_2 | DMATCR_2 | 32 | H'FFFE1028 | 16/32 | | | DMA channel control register_2 | CHCR_2 | 32 | H'FFFE102C | 8/16/32 | | | DMA source address register_3 | SAR_3 | 32 | H'FFFE1030 | 16/32 | | | DMA destination address register_3 | DAR_3 | 32 | H'FFFE1034 | 16/32 | | | DMA transfer count register_3 | DMATCR_3 | 32 | H'FFFE1038 | 16/32 | | | DMA channel control register_3 | CHCR_3 | 32 | H'FFFE103C | 8/16/32 | | | DMA source address register_4 | SAR_4 | 32 | H'FFFE1040 | 16/32 | | | DMA destination address register_4 | DAR_4 | 32 | H'FFFE1044 | 16/32 | | | DMA transfer count register_4 | DMATCR_4 | 32 | H'FFFE1048 | 16/32 | | | DMA channel control register_4 | CHCR_4 | 32 | H'FFFE104C | 8/16/32 | | | DMA source address register_5 | SAR_5 | 32 | H'FFFE1050 | 16/32 | | | DMA destination address register_5 | DAR_5 | 32 | H'FFFE1054 | 16/32 | | | DMA transfer count register_5 | DMATCR_5 | 32 | H'FFFE1058 | 16/32 | | | DMA channel control register_5 | CHCR_5 | 32 | H'FFFE105C | 8/16/32 | | | DMA source address register_6 | SAR_6 | 32 | H'FFFE1060 | 16/32 | | | DMA destination address register_6 | DAR_6 | 32 | H'FFFE1064 | 16/32 | | | DMA transfer count register_6 | DMATCR_6 | 32 | H'FFFE1068 | 16/32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-------------------------------------------|--------------|----------------|------------|----------------| | DMAC | DMA channel control register_6 | CHCR_6 | 32 | H'FFFE106C | 8/16/32 | | | DMA source address register_7 | SAR_7 | 32 | H'FFFE1070 | 16/32 | | | DMA destination address register_7 | DAR_7 | 32 | H'FFFE1074 | 16/32 | | | DMA transfer count register_7 | DMATCR_7 | 32 | H'FFFE1078 | 16/32 | | | DMA channel control register_7 | CHCR_7 | 32 | H'FFFE107C | 8/16/32 | | | DMA reload source address register_0 | RSAR_0 | 32 | H'FFFE1100 | 16/32 | | | DMA reload destination address register_0 | RDAR_0 | 32 | H'FFFE1104 | 16/32 | | | DMA reload transfer count register_0 | RDMATCR_0 | 32 | H'FFFE1108 | 16/32 | | | DMA reload source address register_1 | RSAR_1 | 32 | H'FFFE1110 | 16/32 | | | DMA reload destination address register_1 | RDAR_1 | 32 | H'FFFE1114 | 16/32 | | | DMA reload transfer count register_1 | RDMATCR_1 | 32 | H'FFFE1118 | 16/32 | | | DMA reload source address register_2 | RSAR_2 | 32 | H'FFFE1120 | 16/32 | | | DMA reload destination address register_2 | RDAR_2 | 32 | H'FFFE1124 | 16/32 | | | DMA reload transfer count register_2 | RDMATCR_2 | 32 | H'FFFE1128 | 16/32 | | | DMA reload source address register_3 | RSAR_3 | 32 | H'FFFE1130 | 16/32 | | | DMA reload destination address register_3 | RDAR_3 | 32 | H'FFFE1134 | 16/32 | | | DMA reload transfer count register_3 | RDMATCR_3 | 32 | H'FFFE1138 | 16/32 | | | DMA reload source address register_4 | RSAR_4 | 32 | H'FFFE1140 | 16/32 | | | DMA reload destination address register_4 | RDAR_4 | 32 | H'FFFE1144 | 16/32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-------------------------------------------|--------------|----------------|------------|----------------| | DMAC | DMA reload transfer count register_4 | RDMATCR_4 | 32 | H'FFFE1148 | 16/32 | | | DMA reload source address register_5 | RSAR_5 | 32 | H'FFFE1150 | 16/32 | | | DMA reload destination address register_5 | RDAR_5 | 32 | H'FFFE1154 | 16/32 | | | DMA reload transfer count register_5 | RDMATCR_5 | 32 | H'FFFE1158 | 16/32 | | | DMA reload source address register_6 | RSAR_6 | 32 | H'FFFE1160 | 16/32 | | | DMA reload destination address register_6 | RDAR_6 | 32 | H'FFFE1164 | 16/32 | | | DMA reload transfer count register_6 | RDMATCR_6 | 32 | H'FFFE1168 | 16/32 | | | DMA reload source address register_7 | RSAR_7 | 32 | H'FFFE1170 | 16/32 | | | DMA reload destination address register_7 | RDAR_7 | 32 | H'FFFE1174 | 16/32 | | | DMA reload transfer count register_7 | RDMATCR_7 | 32 | H'FFFE1178 | 16/32 | | | DMA operation register | DMAOR | 16 | H'FFFE1200 | 8/16 | | | DM extension resource selector 0 | DMARS0 | 16 | H'FFFE1300 | 16 | | | DM extension resource selector 1 | DMARS1 | 16 | H'FFFE1304 | 16 | | | DM extension resource selector 2 | DMARS2 | 16 | H'FFFE1308 | 16 | | | DM extension resource selector 3 | DMARS3 | 16 | H'FFFE130C | 16 | | CPG | Frequency control register | FRQCR | 16 | H'FFFE0010 | 16 | | WDT | Watchdog timer control/status register | WTCSR | 8 | H'FFFE0000 | 16 | | | Watchdog timer counter | WTCNT | 8 | H'FFFE0002 | 16 | | | Watchdog reset control/status register | WRCSR | 8 | H'FFFE0004 | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|--------------------------------------------|--------------|----------------|------------|----------------| | Power-down | Standby control register | STBCR | 8 | H'FFFE0014 | 8 | | mode | Standby control register 2 | STBCR2 | 8 | H'FFFE0018 | 8 | | | System control register 1 | SYSCR1 | 8 | H'FFFE0402 | 8 | | | System control register 2 | SYSCR2 | 8 | H'FFFE0404 | 8 | | | Standby control register 3 | STBCR3 | 8 | H'FFFE0408 | 8 | | | Standby control register 4 | STBCR4 | 8 | H'FFFE040C | 8 | | | System control register 3 | SYSCR3 | 8 | H'FFFE0418 | 8 | | EtherC | EtherC mode register | ECMR | 32 | H'FFFC2160 | 32 | | | EtherC status register | ECSR | 32 | H'FFFC2164 | 32 | | | EtherC interrupt enable register | ECSIPR | 32 | H'FFFC2168 | 32 | | | PHY section interface register | PIR | 32 | H'FFFC216C | 32 | | | MAC higher-order address register | MAHR | 32 | H'FFFC2170 | 32 | | | MAC lower-order address register | MALR | 32 | H'FFFC2174 | 32 | | | Upper receive frame length limit register | RFLR | 32 | H'FFFC2178 | 32 | | | PHY section status register | PSR | 32 | H'FFFC217C | 32 | | | Transmit retry counter register | TROCR | 32 | H'FFFC2180 | 32 | | | Delay collision detection counter register | CDCR | 32 | H'FFFC2184 | 32 | | | Carrier loss counter register | LCCR | 32 | H'FFFC2188 | 32 | | | Undetected carrier counter register | CNDCR | 32 | H'FFFC218C | 32 | | | CRC error frame reception counter register | CEFCR | 32 | H'FFFC2194 | 32 | | | Frame reception error counter register | FRECR | 32 | H'FFFC2198 | 32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|------------------------------------------------------|--------------|----------------|------------|----------------| | EtherC | Lower than 64 bytes frame reception counter register | TSFRCR | 32 | H'FFFC219C | 32 | | | Excessive bytes frame reception counter register | TLFRCR | 32 | H'FFFC21A0 | 32 | | | Fractional bits frame reception counter register | RFCR | 32 | H'FFFC21A4 | 32 | | | Multicast address frame reception counter register | MAFCR | 32 | H'FFFC21A8 | 32 | | | IPG setting register | IPGR | 32 | H'FFFC21B4 | 32 | | | Automatic PAUSE frame setting register | APR | 32 | H'FFFC21B8 | 32 | | | Manual PAUSE frame setting register | MPR | 32 | H'FFFC21BC | 32 | | | Automatic PAUSE frame resend count setting register | TPAUSER | 32 | H'FFFC21C4 | 32 | | E-DMAC | E-DMAC mode register | EDMR | 32 | H'FFFC2000 | 32 | | | E-DMAC send request register | EDTRR | 32 | H'FFFC2004 | 32 | | | E-DMAC receive request register | EDRRR | 32 | H'FFFC2008 | 32 | | | Transmit descriptor list's starting address register | TDLAR | 32 | H'FFFC200C | 32 | | | Receive descriptor list's starting address register | RDLAR | 32 | H'FFFC2010 | 32 | | | EtherC/E-DMAC status register | EESR | 32 | H'FFFC2014 | 32 | | | EtherC/E-DMAC status interrupt enable register | EESIPR | 32 | H'FFFC2018 | 32 | | | Transmit /receive status copying register | TRSCER | 32 | H'FFFC201C | 32 | | | Missed frames counter register | RMFCR | 32 | H'FFFC2020 | 32 | | | Transmit FIFO threshold value register | TFTR | 32 | H'FFFC2024 | 32 | | | FIFO capacity register | FDR | 32 | H'FFFC2028 | 32 | | | Receive method control register | RMCR | 32 | H'FFFC202C | 32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-----------------------------------------------------------|--------------|----------------|------------|----------------| | E-DMAC | E-DMAC operation control register | EDOCR | 32 | H'FFFC2030 | 32 | | | Flow control start FIFO threshold value register | FCFTR | 32 | H'FFFC2034 | 32 | | | Receive data padding setting register | RPADIR | 32 | H'FFFC2038 | 32 | | | Transmit interrupt setting register | TRIMD | 32 | H'FFFC203C | 32 | | | Receive buffer write address register | RBWAR | 32 | H'FFFC2040 | 32 | | | Receive descriptor fetch address register | RDFAR | 32 | H'FFFC2044 | 32 | | | Transmit buffer read address register | TBRAR | 32 | H'FFFC204C | 32 | | | Transmit descriptor fetch address register | TDFAR | 32 | H'FFFC2050 | 32 | | | Checksum mode register | CSMR | 32 | H'FFFC20E4 | 32 | | | Checksum skipped bytes monitor register | CSSBM | 32 | H'FFFC20E8 | 32 | | | Checksum monitor register | CSSMR | 32 | H'FFFC20EC | 32 | | A-DMAC | Channel 0 processing control register | COC | 32 | H'FFFC2440 | 32 | | | Channel 0 processing mode register | COM | 32 | H'FFFC2444 | 32 | | | Channel 0 processing interrupt request register | COI | 32 | H'FFFC2448 | 32 | | | Channel 0 processing descriptor starting address register | CODSA | 32 | H'FFFC247C | 32 | | | Channel 0 processing descriptor current address register | CODCA | 32 | H'FFFC2480 | 32 | | | Channel 0 processing descriptor 0 register | C0D0 | 32 | H'FFFC2484 | 32 | | | Channel 0 processing descriptor 1 register | C0D1 | 32 | H'FFFC2488 | 32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-----------------------------------------------------------|--------------|----------------|------------|----------------| | A-DMAC | Channel 0 processing descriptor 2 register | C0D2 | 32 | H'FFFC248C | 32 | | | Channel 0 processing descriptor 3 register | C0D3 | 32 | H'FFFC2490 | 32 | | | Channel 0 processing descriptor 4 register | C0D4 | 32 | H'FFFC2494 | 32 | | | Channel 1 processing control register | C1C | 32 | H'FFFC24B0 | 32 | | | Channel 1 processing mode register | C1M | 32 | H'FFFC24B4 | 32 | | | Channel 1 processing interrupt request register | C1I | 32 | H'FFFC24B8 | 32 | | | Channel 1 processing descriptor starting address register | C1DSA | 32 | H'FFFC24EC | 32 | | | Channel 1 processing descriptor current address register | C1DCA | 32 | H'FFFC24F0 | 32 | | | Channel 1 processing descriptor 0 register | C1D0 | 32 | H'FFFC24F4 | 32 | | | Channel 1 processing descriptor 1 register | C1D1 | 32 | H'FFFC24F8 | 32 | | | Channel 1 processing descriptor 2 register | C1D2 | 32 | H'FFFC24FC | 32 | | | Channel 1 processing descriptor 3 register | C1D3 | 32 | H'FFFC2500 | 32 | | | Channel 1 processing descriptor 4 register | C1D4 | 32 | H'FFFC2504 | 32 | | | FEC DMAC processing control register | FECC | 32 | H'FFFC2590 | 32 | | | FEC DMAC processing interrupt request register | FECI | 32 | H'FFFC2594 | 32 | | | FEC DMAC processing descriptor starting address register | FECDSA | 32 | H'FFFC2598 | 32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|---------------------------------------------------------|--------------|----------------|------------|----------------| | A-DMAC | FEC DMAC processing descriptor current address register | FECDCA | 32 | H'FFFC259C | 32 | | | FEC DMAC processing descriptor 0 register | FECD00 | 32 | H'FFFC25A0 | 32 | | | FEC DMAC processing descriptor 1 register | FECD01D0A | 32 | H'FFFC25A4 | 32 | | | FEC DMAC processing descriptor 2 register | FECD02S0A | 32 | H'FFFC25A8 | 32 | | | FEC DMAC processing descriptor 3 register | FECD03S1A | 32 | H'FFFC25AC | 32 | | STIF0 | STIF mode select register_0 | STMDR_0 | 32 | H'FFFFD000 | 32 | | | STIF control register_0 | STCTLR_0 | 32 | H'FFFFD004 | 32 | | | STIF internal counter control register_0 | STCNTCR_0 | 32 | H'FFFFD008 | 32 | | | STIF internal counter value setting register_0 | STCNTVR_0 | 32 | H'FFFFD00C | 32 | | | STIF status register_0 | STSTR_0 | 32 | H'FFFFD010 | 32 | | | STIF interrupt enable register_0 | STIER_0 | 32 | H'FFFFD014 | 32 | | | STIF transfer size register_0 | STSIZER_0 | 32 | H'FFFFD018 | 32 | | | STIF PWM mode register_0 | STPWMMR_0 | 32 | H'FFFFD020 | 32 | | | STIF PWM control register_0 | STPWMCR_0 | 32 | H'FFFFD024 | 32 | | | STIF PWM register_0 | STPWMR_0 | 32 | H'FFFFD028 | 32 | | | STIF PCR0 register_0 | STPCR0R_0 | 32 | H'FFFFD02C | 32 | | | STIF PCR1 register_0 | STPCR1R_0 | 32 | H'FFFFD030 | 32 | | | STIF STC0 register_0 | STSTC0R_0 | 32 | H'FFFFD034 | 32 | | | STIF STC1 register_0 | STSTC1R_0 | 32 | H'FFFFD038 | 32 | | | STIF lock control register_0 | STLKCR_0 | 32 | H'FFFFD03C | 32 | | | STIF debugging status register_0 | STDBGR_0 | 32 | H'FFFFD060 | 32 | | STIF1 | STIF mode select register_1 | STMDR_1 | 32 | H'FFFFD800 | 32 | | | STIF control register_1 | STCTLR_1 | 32 | H'FFFFD804 | 32 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|------------------------------------------------|--------------|----------------|------------|----------------| | STIF1 | STIF internal counter control register_1 | STCNTCR_1 | 32 | H'FFFFD808 | 32 | | | STIF internal counter value setting register_1 | STCNTVR_1 | 32 | H'FFFFD80C | 32 | | | STIF status register_1 | STSTR_1 | 32 | H'FFFFD810 | 32 | | | STIF interrupt enable register_1 | STIER_1 | 32 | H'FFFFD814 | 32 | | | STIF transfer size register_1 | STSIZER_1 | 32 | H'FFFFD818 | 32 | | | STIF PWM mode register_1 | STPWMMR_1 | 32 | H'FFFFD820 | 32 | | | STIF PWM control register_1 | STPWMCR_1 | 32 | H'FFFFD824 | 32 | | | STIF PWM register_1 | STPWMR_1 | 32 | H'FFFFD828 | 32 | | | STIF PCR0 register_1 | STPCR0R_1 | 32 | H'FFFFD82C | 32 | | | STIF PCR1 register_1 | STPCR1R_1 | 32 | H'FFFFD830 | 32 | | | STIF STC0 register_1 | STSTC0R_1 | 32 | H'FFFFD834 | 32 | | | STIF STC1 register_1 | STSTC1R_1 | 32 | H'FFFFD838 | 32 | | | STIF lock control register_1 | STLKCR_1 | 32 | H'FFFFD83C | 32 | | | STIF debugging status register_1 | STDBGR_1 | 32 | H'FFFFD860 | 32 | | SSI | SSI clock selection register_0 | SCSR_0 | 16 | H'FFFF0000 | 16 | | | SSI clock selection register_1 | SCSR_1 | 16 | H'FFFF0800 | 16 | | | Control register_0 | SSICR_0 | 32 | H'FFFFC000 | 32 | | | Status register_0 | SSISR_0 | 32 | H'FFFFC004 | 32 | | | Transmit data register_0 | SSITDR_0 | 32 | H'FFFFC008 | 32 | | | Receive data register_0 | SSIRDR_0 | 32 | H'FFFFC00C | 32 | | | Control register_1 | SSICR_1 | 32 | H'FFFFC800 | 32 | | | Status register_1 | SSISR_1 | 32 | H'FFFFC804 | 32 | | | Transmit data register_1 | SSITDR_1 | 32 | H'FFFFC808 | 32 | | | Receive data register_1 | SSIRDR_1 | 32 | H'FFFFC80C | 32 | | USB | D0FIFO bus wait setting register | D0FWAIT | 16 | H'FFFC1C0C | 16 | | | D1FIFO bus wait setting register | D1FWAIT | 16 | H'FFFC1C0E | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|---------------------------------------|--------------|----------------|------------|----------------| | USB | D0FIFO port register | D0FIFO | 32 | H'FFFC1C14 | 32 | | | D1FIFO port register | D1FIFO | 32 | H'FFFC1C18 | 32 | | | System configuration control register | SYSCFG | 16 | H'FFFFF800 | 16 | | | CPU bus wait setting register | BUSWAIT | 16 | H'FFFFF802 | 16 | | | System configuration status register | SYSSTS | 16 | H'FFFFF804 | 16 | | | Device control register | DVSTCTR | 16 | H'FFFFF808 | 16 | | | Test mode register | TESTMODE | 16 | H'FFFFF80C | 16 | | | D0FIFO bus configuration register | D0FBCFG | 16 | H'FFFFF810 | 16 | | | D1FIFO bus configuration register | D1FBCFG | 16 | H'FFFFF812 | 16 | | | CFIFO port register | CFIFO | 32 | H'FFFFF814 | 8/16/32 | | | CFIFO port selection register | CFIFOSEL | 16 | H'FFFFF820 | 16 | | | CFIFO port control register | CFIFOCTR | 16 | H'FFFFF822 | 16 | | | D0CFIFO port selection register | D0FIFOSEL | 16 | H'FFFFF828 | 16 | | | D0FIFO port control register | D0FIFOCTR | 16 | H'FFFFF82A | 16 | | | D1CFIFO port selection register | D1FIFOSEL | 16 | H'FFFFF82C | 16 | | | D1FIFO port control register | D1FIFOCTR | 16 | H'FFFFF82E | 16 | | | Interrupt enable register 0 | INTENB0 | 16 | H'FFFFF830 | 16 | | | Interrupt enable register 1 | INTENB1 | 16 | H'FFFFF832 | 16 | | | BRDY interrupt enable register | BRDYENB | 16 | H'FFFFF836 | 16 | | | NRDY interrupt enable register | NRDYENB | 16 | H'FFFFF838 | 16 | | | BEMP interrupt enable register | BEMPENB | 16 | H'FFFFF83A | 16 | | | SOF output configuration register | SOFCFG | 16 | H'FFFFF83C | 16 | | | Interrupt status register 0 | INTSTS0 | 16 | H'FFFFF840 | 16 | | | Interrupt status register 1 | INTSTS1 | 16 | H'FFFFF842 | 16 | | | BRDY interrupt status register | BRDYSTS | 16 | H'FFFFF846 | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-------------------------------------------|--------------|----------------|------------|----------------| | USB | NRDY interrupt status register | NRDYSTS | 16 | H'FFFFF848 | 16 | | | BEMP interrupt status register | BEMPSTS | 16 | H'FFFFF84A | 16 | | | Frame number register | FRMNUM | 16 | H'FFFFF84C | 16 | | | μ frame number register | UFRMNUM | 16 | H'FFFFF84E | 16 | | | USB address register | USBADDR | 16 | H'FFFFF850 | 16 | | | USB request type register | USBREQ | 16 | H'FFFFF854 | 16 | | | USB request value register | USBVAL | 16 | H'FFFFF856 | 16 | | | USB request index register | USBINDX | 16 | H'FFFFF858 | 16 | | | USB request length register | USBLENG | 16 | H'FFFFF85A | 16 | | | DCP configuration register | DCPCFG | 16 | H'FFFFF85C | 16 | | | DCP maximum packet size register | DCPMAXP | 16 | H'FFFFF85E | 16 | | | DCP control register | DCPCTR | 16 | H'FFFFF860 | 16 | | | Pipe window selection register | PIPESEL | 16 | H'FFFFF864 | 16 | | | Pipe configuration register | PIPECFG | 16 | H'FFFFF868 | 16 | | | Pipe buffer register | PIPEBUF | 16 | H'FFFFF86A | 16 | | | Pipe maximum packet size register | PIPEMAXP | 16 | H'FFFFF86C | 16 | | | Pipe cycle control register | PIPEPERI | 16 | H'FFFFF86E | 16 | | | PIPE1 control register | PIPE1CTR | 16 | H'FFFFF870 | 16 | | | PIPE2 control register | PIPE2CTR | 16 | H'FFFFF872 | 16 | | | PIPE3 control register | PIPE3CTR | 16 | H'FFFFF874 | 16 | | | PIPE4 control register | PIPE4CTR | 16 | H'FFFFF876 | 16 | | | PIPE5 control register | PIPE5CTR | 16 | H'FFFFF878 | 16 | | | PIPE6 control register | PIPE6CTR | 16 | H'FFFFF87A | 16 | | | PIPE7 control register | PIPE7CTR | 16 | H'FFFFF87C | 16 | | | PIPE8 control register | PIPE8CTR | 16 | H'FFFFF87E | 16 | | | PIPE9 control register | PIPE9CTR | 16 | H'FFFFF880 | 16 | | | PIPE1 transaction counter enable register | PIPE1TRE | 16 | H'FFFFF890 | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-------------------------------------------|--------------|----------------|------------|----------------| | USB | PIPE1 transaction counter register | PIPE1TRN | 16 | H'FFFFF892 | 16 | | | PIPE2 transaction counter enable register | PIPE2TRE | 16 | H'FFFFF894 | 16 | | | PIPE2 transaction counter register | PIPE2TRN | 16 | H'FFFFF896 | 16 | | | PIPE3 transaction counter enable register | PIPE3TRE | 16 | H'FFFFF898 | 16 | | | PIPE3 transaction counter register | PIPE3TRN | 16 | H'FFFFF89A | 16 | | | PIPE4 transaction counter enable register | PIPE4TRE | 16 | H'FFFFF89C | 16 | | | PIPE4 transaction counter register | PIPE4TRN | 16 | H'FFFFF89E | 16 | | | PIPE5 transaction counter enable register | PIPE5TRE | 16 | H'FFFFF8A0 | 16 | | | PIPE5 transaction counter register | PIPE5TRN | 16 | H'FFFFF8A2 | 16 | | | Device address 0 configuration register | DEVADD0 | 16 | H'FFFFF8D0 | 16 | | | Device address 1 configuration register | DEVADD1 | 16 | H'FFFFF8D2 | 16 | | | Device address 2 configuration register | DEVADD2 | 16 | H'FFFFF8D4 | 16 | | | Device address 3 configuration register | DEVADD3 | 16 | H'FFFFF8D6 | 16 | | | Device address 4 configuration register | DEVADD4 | 16 | H'FFFFF8D8 | 16 | | | Device address 5 configuration register | DEVADD5 | 16 | H'FFFFF8DA | 16 | | | Device address 6 configuration register | DEVADD6 | 16 | H'FFFFF8DC | 16 | | | Device address 7 configuration register | DEVADD7 | 16 | H'FFFFF8DE | 16 | | | Device address 8 configuration register | DEVADD8 | 16 | H'FFFFF8E0 | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|--------------------------------------------------|--------------|----------------|------------|----------------| | USB | Device address 9 configuration register | DEVADD9 | 16 | H'FFFFF8E2 | 16 | | | Device address A configuration register | DEVADDA | 16 | H'FFFFF8E4 | 16 | | IIC3 | I <sup>2</sup> C bus control register 1_0 | ICCR1_0 | 8 | H'FFFEE000 | 8 | | | I <sup>2</sup> C bus control register 2_0 | ICCR2_0 | 8 | H'FFFEE001 | 8 | | | I <sup>2</sup> C bus mode register_0 | ICMR_0 | 8 | H'FFFEE002 | 8 | | | I <sup>2</sup> C bus interrupt enable register_0 | ICIER_0 | 8 | H'FFFEE003 | 8 | | | I <sup>2</sup> C bus status register_0 | ICSR_0 | 8 | H'FFFEE004 | 8 | | | Slave address register_0 | SAR_0 | 8 | H'FFFEE005 | 8 | | | I <sup>2</sup> C bus transmit data register_0 | ICDRT_0 | 8 | H'FFFEE006 | 8 | | | I <sup>2</sup> C bus receive data register_0 | ICDRR_0 | 8 | H'FFFEE007 | 8 | | | NF2CYC register_0 | NF2CYC_0 | 8 | H'FFFEE008 | 8 | | HIF | HIF index register | HIFIDX | 32 | H'FFFFE000 | 32 | | | HIF general status register | HIFGSR | 32 | H'FFFFE004 | 32 | | | HIF status/control register | HIFSCR | 32 | H'FFFFE008 | 32 | | | HIF memory control register | HIFMCR | 32 | H'FFFFE00C | 32 | | | HIF internal interrupt control register | HIFIICR | 32 | H'FFFFE010 | 32 | | | HIF external interrupt control register | HIFEICR | 32 | H'FFFFE014 | 32 | | | HIF address register | HIFADR | 32 | H'FFFFE018 | 32 | | | HIF data register | HIFDATA | 32 | H'FFFFE01C | 32 | | | HIF DREQ trigger register | HIFDTR | 32 | H'FFFFE020 | 32 | | | HIF bank interrupt control register | HIFBICR | 32 | H'FFFFE024 | 32 | | | HIF boot control register | HIFBCR | 32 | H'FFFFE040 | 32 | | CMT | Compare match timer start register | CMSTR | 16 | H'FFFEC000 | 16 | | | Compare match timer control/status register_0 | CMCSR_0 | 16 | H'FFFEC002 | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-----------------------------------------------|--------------|----------------|------------|----------------| | CMT | Compare match counter_0 | CMCNT_0 | 16 | H'FFFEC004 | 16 | | | Compare match constant register_0 | CMCOR_0 | 16 | H'FFFEC006 | 16 | | | Compare match timer control/status register_1 | CMCSR_1 | 16 | H'FFFEC008 | 16 | | | Compare match counter_1 | CMCNT_1 | 16 | H'FFFEC00A | 16 | | | Compare match constant register_1 | CMCOR_1 | 16 | H'FFFEC00C | 16 | | SCIF0 | Serial mode register_0 | SCSMR_0 | 16 | H'FFFE8000 | 16 | | | Bit rate register_0 | SCBRR_0 | 8 | H'FFFE8004 | 8 | | | Serial control register_0 | SCSCR_0 | 16 | H'FFFE8008 | 16 | | | Transmit FIFO data register_0 | SCFTDR_0 | 8 | H'FFFE800C | 8 | | | Serial status register_0 | SCFSR_0 | 16 | H'FFFE8010 | 16 | | | Receive FIFO data register_0 | SCFRDR_0 | 8 | H'FFFE8014 | 8 | | | FIFO control register_0 | SCFCR_0 | 16 | H'FFFE8018 | 16 | | | FIFO data count set register_0 | SCFDR_0 | 16 | H'FFFE801C | 16 | | | Serial port register_0 | SCSPTR_0 | 16 | H'FFFE8020 | 16 | | | Line status register_0 | SCLSR_0 | 16 | H'FFFE8024 | 16 | | SCIF1 | Serial mode register_1 | SCSMR_1 | 16 | H'FFFE8800 | 16 | | | Bit rate register_1 | SCBRR_1 | 8 | H'FFFE8804 | 8 | | | Serial control register_1 | SCSCR_1 | 16 | H'FFFE8808 | 16 | | | Transmit FIFO data register_1 | SCFTDR_1 | 8 | H'FFFE880C | 8 | | | Serial status register_1 | SCFSR_1 | 16 | H'FFFE8810 | 16 | | | Receive FIFO data register_1 | SCFRDR_1 | 8 | H'FFFE8814 | 8 | | | FIFO control register_1 | SCFCR_1 | 16 | H'FFFE8818 | 16 | | | FIFO data count set register_1 | SCFDR_1 | 16 | H'FFFE881C | 16 | | | Serial port register_1 | SCSPTR_1 | 16 | H'FFFE8820 | 16 | | | Line status register_1 | SCLSR_1 | 16 | H'FFFE8824 | 16 | | SCIF2 | Serial mode register_2 | SCSMR_2 | 16 | H'FFFE9000 | 16 | | | Bit rate register_2 | SCBRR_2 | 8 | H'FFFE9004 | 8 | | | Serial control register_2 | SCSCR_2 | 16 | H'FFFE9008 | 16 | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|--------------------------------|--------------|----------------|------------|----------------| | SCIF2 | Transmit FIFO data register_2 | SCFTDR_2 | 8 | H'FFFE900C | 8 | | | Serial status register_2 | SCFSR_2 | 16 | H'FFFE9010 | 16 | | | Receive FIFO data register_2 | SCFRDR_2 | 8 | H'FFFE9014 | 8 | | | FIFO control register_2 | SCFCR_2 | 16 | H'FFFE9018 | 16 | | | FIFO data count set register_2 | SCFDR_2 | 16 | H'FFFE901C | 16 | | | Serial port register_2 | SCSPTR_2 | 16 | H'FFFE9020 | 16 | | | Line status register_2 | SCLSR_2 | 16 | H'FFFE9024 | 16 | | I/O | Port A data register H | PADRH | 16 | H'FFFE3800 | 8/16 | | | Port A IO register H | PAIORH | 16 | H'FFFE3804 | 8/16 | | | Port A control register H2 | PACRH2 | 16 | H'FFFE3808 | 8/16 | | | Port A control register H1 | PACRH1 | 16 | H'FFFE380A | 8/16 | | | Port B data register L | PBDRL | 16 | H'FFFE3882 | 8/16 | | | Port B IO register L | PBIORL | 16 | H'FFFE3886 | 8/16 | | | Port B control register L1 | PBCRL1 | 16 | H'FFFE388E | 8/16 | | | Port C data register H | PCDRH | 16 | H'FFFE3900 | 8/16 | | | Port C data register L | PCDRL | 16 | H'FFFE3902 | 8/16 | | | Port C IO register H | PCIORH | 16 | H'FFFE3904 | 8/16 | | | Port C IO register L | PCIORL | 16 | H'FFFE3906 | 8/16 | | | Port C control register H1 | PCCRH1 | 16 | H'FFFE390A | 8/16 | | | Port C control register L2 | PCCRL2 | 16 | H'FFFE390C | 8/16 | | | Port C control register L1 | PCCRL1 | 16 | H'FFFE390E | 8/16 | | | Port D data register L | PDDRL | 16 | H'FFFE3982 | 8/16 | | | Port D IO register L | PDIORL | 16 | H'FFFE3986 | 8/16 | | | Port D control register L1 | PDCRL1 | 16 | H'FFFE398E | 8/16 | | | Port E data register L | PEDRL | 16 | H'FFFE3A02 | 8/16 | | | Port E IO register L | PEIORL | 16 | H'FFFE3A06 | 8/16 | | | Port E control register L2 | PECRL2 | 16 | H'FFFE3A0C | 8/16 | | | Port E control register L1 | PECRL1 | 16 | H'FFFE3A0E | 8/16 | | | Port F data register L | PFDRL | 16 | H'FFFE3A82 | 8/16 | | | Port F IO register L | PFIORL | 16 | H'FFFE3A86 | 8/16 | | | | | | | | | Module<br>Name | Register Name | Abbreviation | Number of Bits | Address | Access<br>Size | |----------------|-------------------------------|--------------|----------------|------------|----------------| | I/O | Port F control register L2 | PFCRL2 | 16 | H'FFFE3A8C | 8/16 | | | Port F control register L1 | PFCRL1 | 16 | H'FFFE3A8E | 8/16 | | | Port G data register H | PGDRH | 16 | H'FFFE3B00 | 8/16 | | | Port G data register L | PGDRL | 16 | H'FFFE3B02 | 8/16 | | | Port G IO register H | PGIORH | 16 | H'FFFE3B04 | 8/16 | | | Port G IO register L | PGIORL | 16 | H'FFFE3B06 | 8/16 | | | Port G control register H2 | PGCRH2 | 16 | H'FFFE3B0A | 8/16 | | | Port G control register L2 | PGCRL2 | 16 | H'FFFE3B0C | 8/16 | | | Port G control register L1 | PGCRL1 | 16 | H'FFFE3B0E | 8/16 | | UBC | Break address register_0 | BAR_0 | 32 | H'FFFC0400 | 32 | | | Break address mask register_0 | BAMR_0 | 32 | H'FFFC0404 | 32 | | | Break data register_0 | BDR_0 | 32 | H'FFFC0408 | 32 | | | Break data mask register_0 | BDMR_0 | 32 | H'FFFC040C | 32 | | | Break address register_1 | BAR_1 | 32 | H'FFFC0410 | 32 | | | Break address mask register_1 | BAMR_1 | 32 | H'FFFC0414 | 32 | | | Break data register_1 | BDR_1 | 32 | H'FFFC0418 | 32 | | | Break data mask register_1 | BDMR_1 | 32 | H'FFFC041C | 32 | | | Break bus cycle register_0 | BBR_0 | 16 | H'FFFC04A0 | 16 | | | Break bus cycle register_1 | BBR_1 | 16 | H'FFFC04B0 | 16 | | | Break control register | BRCR | 32 | H'FFFC04C0 | 32 | | H-UDI | Instruction register | SDIR | 16 | H'FFFE2000 | 16 | ## 28.2 Register Bits Register addresses and bit names of the on-chip peripheral modules are described below. Each line covers eight bits, and 16-bit and 32-bit registers are shown as 2 or 4 lines, respectively. | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Cache | CCR1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | ICF | _ | _ | ICE | | | | _ | _ | _ | _ | OCF | _ | WT | OCE | | | CCR2 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | W3LORD | W3LOCK | | | | _ | _ | _ | _ | _ | _ | W2LORD | W2LOCK | | INTC | ICR0 | NMIL | _ | _ | _ | _ | _ | _ | NMIE | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | ICR1 | IRQ71S | IRQ70S | IRQ61S | IRQ60S | IRQ51S | IRQ50S | IRQ41S | IRQ40S | | | | IRQ31S | IRQ30S | IRQ21S | IRQ20S | IRQ11S | IRQ10S | IRQ01S | IRQ00S | | | IRQRR | _ | _ | _ | _ | _ | _ | _ | _ | | | | IRQ7F | IRQ6F | IRQ5F | IRQ4F | IRQ3F | IRQ2F | IRQ1F | IRQ0F | | | IBCR | E15 | E14 | E13 | E12 | E11 | E10 | E9 | E8 | | | | E7 | E6 | E5 | E4 | E3 | E2 | E1 | _ | | | IBNR | BE1 | BE0 | BOVE | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | BN3 | BN2 | BN1 | BN0 | | | IPR01 | | | | | | | | | | | | | | | | | | | | | | IPR02 | | | | | | | | | | | | | | | | | | | | | | IPR06 | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | INTC | IPR07 | | | | | | | | | | | IPR08 | | | | | | | | | | | IPR09 | | | | | | | | | | | IPR10 | | | | | | | | | | | IPR11 | - | | | | | | | | | | IPR12 | | | | | | | | | | | IPR13 | | | | | | | | | | | IPR14 | | | | | | | | | | | IPR15 | | | | | | | | | | | IPR16 | | | | | | | | | | BSC | CMNCR | | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | DMAIW2 | | | | DMAIW1 | DMAIW0 | DMAIWA | _ | _ | _ | HIZMEM | HIZCNT | | | CS0BCR | _ | IWW2 | IWW1 | IWW0 | IWRWD2 | IWRWD1 | IWRWD0 | IWRWS2 | | | | IWRWS1 | IWRWS0 | IWRRD2 | IWRRD1 | IWRRD0 | IWRRS2 | IWRRS1 | IWRRS0 | | | | _ | TYPE2 | TYPE1 | TYPE0 | ENDIAN | BSZ1 | BSZ0 | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | Name Register 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/ | /10/2 25/17/9/1 24/16/8/0 | |-----------------------------------------------------------------------------|---------------------------| | BSC CS3BCR — IWW2 IWW1 IWW0 IWRWD2 IWRW | VD1 IWRWD0 IWRWS2 | | IWRWS1 IWRWS0 IWRRD2 IWRRD1 IWRRD0 IWRR | RS2 IWRRS1 IWRRS0 | | TYPE2 TYPE1 TYPE0 ENDIAN BSZ1 | BSZ0 — | | | | | CS4BCR — IWW2 IWW1 IWW0 IWRWD2 IWRW | VD1 IWRWD0 IWRWS2 | | IWRWS1 IWRWS0 IWRRD2 IWRRD1 IWRRD0 IWRR | RS2 IWRRS1 IWRRS0 | | — TYPE2 TYPE1 TYPE0 ENDIAN BSZ1 | BSZ0 — | | | | | CS5BCR IWW2 IWW1 IWW0 IWRWD2 IWRW | VD1 IWRWD0 IWRWS2 | | IWRWS1 IWRWS0 IWRRD2 IWRRD1 IWRRD0 IWRR | RS2 IWRRS1 IWRRS0 | | — TYPE2 TYPE1 TYPE0 ENDIAN BSZ1 | BSZ0 — | | | | | CS6BCR IWW2 IWW1 IWW0 IWRWD2 IWRW | VD1 IWRWD0 IWRWS2 | | IWRWS1 IWRWS0 IWRRD2 IWRRD1 IWRRD0 IWRR | RS2 IWRRS1 IWRRS0 | | TYPE2 TYPE1 TYPE0 ENDIAN BSZ1 | BSZ0 — | | | | | CS0WCR | | | BAS | | | SW1 SW0 WR3 | WR2 WR1 | | WR0 WM — — — — | HW1 HW0 | | CS3WCR — — — — — — — | | | | | | WR3 | WR2 WR1 | | WR0 WM — — — — | | | CS3WCR — — — — — — — | | | (when | | | connected) — WTRP1 WTRP0 — WTRCD1 WTRC | CD0 — A3CL1 | | A3CL0 — TRWL1 TRWL0 — | WTRC1 WTRC0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|-----------------|------------|------------|------------|------------|------------|------------|-----------|-----------| | BSC | CS4WCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | BAS | _ | WW2 | WW1 | WW0 | | | | _ | _ | _ | SW1 | SW0 | WR3 | WR2 | WR1 | | | | WR0 | WM | _ | _ | _ | _ | HW1 | HW0 | | | CS5BWCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | BAS | _ | WW2 | WW1 | WW0 | | | | _ | _ | _ | SW1 | SW0 | WR3 | WR2 | WR1 | | | | WR0 | WM | _ | _ | _ | _ | HW1 | HW0 | | | CS5BWCR | _ | _ | _ | _ | _ | _ | _ | _ | | | (when PCMCIA is | _ | _ | SA1 | SA0 | _ | _ | _ | _ | | | connected) | | TED3 | TED2 | TED1 | TED0 | PCW3 | PCW2 | PCW1 | | | | PCW0 | WM | _ | _ | TEH3 | TEH2 | TEH1 | TEH0 | | | CS6BWCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | BAS | _ | _ | _ | _ | | | . <u>-</u><br>- | _ | _ | _ | SW1 | SW0 | WR3 | WR2 | WR1 | | | | WR0 | WM | _ | _ | _ | _ | HW1 | HW0 | | | CS6BWCR | _ | _ | _ | _ | _ | _ | _ | _ | | | (when PCMCIA is | _ | _ | SA1 | SA0 | _ | _ | _ | _ | | | connected) | | TED3 | TED2 | TED1 | TED0 | PCW3 | PCW2 | PCW1 | | | | PCW0 | WM | _ | _ | TEH3 | TEH2 | TEH1 | TEH0 | | | SDCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | DEEP | _ | RFSH | RMODE | PDOWN | BACTV | | | | _ | _ | _ | A3ROW1 | A3ROW0 | _ | A3COL1 | A3COL0 | | | RTCSR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | CMF | CMIE | CKS2 | CKS1 | CKS0 | RRC2 | RRC1 | RRC0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | BSC | RTCNT | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | | | _ | | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | RTCOR | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | IBMPR | | _ | OP1R1 | OP1R0 | _ | _ | OP2R1 | OP2R0 | | | | _ | _ | OP3R1 | OP3R0 | _ | _ | _ | _ | | | | | _ | | _ | _ | | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | DMAC | SAR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMATCR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | е | | | | | | | | | | |---|----------|------------|------------|------------|------------|------------|------------|-----------|----------| | | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/ | | | CHCR_0 | TC | _ | RLDSAR | RLDDAR | _ | _ | _ | _ | | | | DO | TL | _ | TEMASK | HE | HIE | AM | AL | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | DL | DS | ТВ | TS1 | TS0 | IE | TE | DE | | | SAR_1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAR_1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMATCR_1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CHCR_1 | TC | _ | RLDSAR | RLDDAR | _ | _ | _ | | | | | DO | TL | _ | TEMASK | HE | HIE | AM | AL | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | DL | DS | ТВ | TS1 | TS0 | IE | TE | DE | | | SAR_2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAR_2 | | | | | | | | | | | D/11 1_E | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |-----|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | | DMATCR_2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CHCR_2 | TC | _ | RLDSAR | RLDDAR | _ | _ | _ | _ | | | | | _ | _ | TEMASK | HE | HIE | | _ | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | _ | _ | ТВ | TS1 | TS0 | IE | TE | DE | | | SAR_3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAF | DAR_3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMATCR_3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CHCR_3 | TC | _ | RLDSAR | RLDDAR | _ | _ | _ | _ | | | | _ | _ | _ | TEMASK | HE | HIE | _ | _ | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | _ | | ТВ | TS1 | TS0 | IE | TE | DE | | | SAR_4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | DMAC | DAR_4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMATCR_4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - | | | | | | | | | | | CHCR_4 | TC | _ | RLDSAR | RLDDAR | _ | _ | _ | _ | | | | _ | _ | _ | TEMASK | HE | HIE | _ | _ | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | _ | _ | ТВ | TS1 | TS0 | IE | TE | DE | | | SAR_5 | | | | | | | | | | | | - | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAR_5 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMATOR 5 | | | | | | | | | | | DMATCR_5 | - | | | | | | | | | | | - | | | | | | | | | | | | | | | | | | | | | CHCR_5 | TC | | RLDSAR | RLDDAR | _ | | _ | | | | 5575 | | _ | _ | TEMASK | HE | HIE | _ | _ | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | _ | _ | ТВ | TS1 | TS0 | IE | TE | DE | | | | | | | | | - | | | | ) | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |---|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | | SAR_6 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAR_6 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMATCR_6 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - | CHCR_6 | TC | | RLDSAR | RLDDAR | _ | | | | | | 011011_0 | _ | _ | | TEMASK | HE | HIE | _ | _ | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | _ | _ | ТВ | TS1 | TS0 | IE | TE | DE | | | SAR_7 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DAR_7 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - | | | | | | | | | | | | DMATCR_7 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | DMAC | CHCR_7 | TC | _ | RLDSAR | RLDDAR | _ | _ | _ | _ | | | | _ | _ | _ | TEMASK | HE | HIE | _ | _ | | | | DM1 | DM0 | SM1 | SM0 | RS3 | RS2 | RS1 | RS0 | | | | _ | _ | ТВ | TS1 | TS0 | IE | TE | DE | | | RSAR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDMATCR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RSAR_1 | | | | | | | | | | | noan_i | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_1 | | | | | | | | | | | | - | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDMATCR_1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Vlodule<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |-----------------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | DMAC | RSAR_2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_2 | | | | | | | | | | | HDAH_Z | | | | | | | | | | | | - | | | | | | | | | | | | | | | | | | | | | RDMATCR_2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RSAR_3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDMATCR_3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RSAR_4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | DMAC | RDAR_4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDMATCR_4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RSAR_5 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_5 | | | | | | | | | | | | | | | | | | | | | | | - | | | | | | | | | | RDMATCR_5 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RSAR_6 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_6 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | | |----------------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------|--|--| | DMAC | RDMATCR_6 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RSAR_7 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDAR_7 | | | | | | | | | | | | | | | | | | | | | | | | | - | RDMATCR_7 | | | | | | | | | | | | | | | | | | | | | | | | | | DMAOR | CMS1 CMS0 | | | | | | PR1 | PR0 | | | | | | _ | _ | _ | _ | _ | AE | NMIF | DME | | | | | DMARS0 | | | CH1 N | /ID[5:0] | | | CH1 | RID[1:0] | | | | | | | | CH0 N | MID[5:0] | | | CH0 | RID[1:0] | | | | | DMARS1 | | | CH3 N | MID[5:0] | | | CH3 | RID[1:0] | | | | | | | | CH2 N | /ID[5:0] | | | CH2 | RID[1:0] | | | | | DMARS2 | | | CH5 N | | | CH5 | RID[1:0] | | | | | | | | | CH4 N | | | CH4 | RID[1:0] | | | | | | DMARS3 | | | CH7 N | /ID[5:0] | | | CH7I | RID[1:0] | | | | | | | | CH6 N | /ID[5:0] | | | CH6 | RID[1:0] | | | | CPG | FRQCR | | | CKOEN1 | CKOEN0 | _ | _ | STC1 | STC0 | | | | | | _ | _ | _ | IFC | _ | PFC2 | PFC1 | PFC0 | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | WDT | WTCSR | IOVF | WT/ĪT | TME | _ | _ | CKS2 | CKS1 | CKS0 | | | WTCNT | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | WRCSR | WOVF | RSTE | RSTS | _ | _ | _ | _ | _ | | Power- | STBCR | STBY | _ | _ | _ | _ | _ | _ | _ | | down<br>mode | STBCR2 | MSTP10 | MSTP9 | MSTP8 | MSTP7 | _ | _ | _ | _ | | mode | SYSCR1 | _ | _ | _ | _ | RAME3 | RAME2 | RAME1 | RAME0 | | | SYSCR2 | _ | _ | _ | _ | RAMWE3 | RAMWE2 | RAMWE1 | RAMWE0 | | | STBCR3 | HIZ | MSTP36 | MSTP35 | MSTP34 | MSTP33 | MSTP32 | MSTP31 | MSTP30 | | | STBCR4 | _ | MSTP46 | MSTP45 | MSTP44 | MSTP43 | MSTP42 | MSTP41 | MSTP40 | | | SYSCR3 | _ | _ | _ | _ | _ | _ | SSI1SRST | SSI0SRST | | EtherC | ECMR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | ZPF | PFR | RXF | TXF | | | | _ | _ | _ | PRCEF | _ | _ | MPDE | _ | | | | _ | RE | TE | _ | ILB | ELB | DM | PRM | | | ECSR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | PSRTO | _ | LCHNG | MPD | ICD | | | ECSIPR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | PSRTOIP | _ | LCHNGIP | MPDIP | ICDIP | | | PIR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | MDI | MDO | MMD | MDC | | | MAHR | MA47 | MA46 | MA45 | MA44 | MA43 | MA42 | MA41 | MA40 | | | | MA39 | MA38 | MA37 | MA36 | MA35 | MA34 | MA33 | MA32 | | | | MA31 | MA30 | MA29 | MA28 | MA27 | MA26 | MA25 | MA24 | | | | MA23 | MA22 | MA21 | MA20 | MA19 | MA18 | MA17 | MA16 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | EtherC | MALR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | | | | | MA15 | MA14 | MA13 | MA12 | MA11 | MA10 | MA9 | MA8 | | | | MA7 | MA6 | MA5 | MA4 | MA3 | MA2 | MA1 | MA0 | | | RFLR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | RFL11 | RFL10 | RFL9 | RFL8 | | | | RFL7 | RFL6 | RFL5 | RFL4 | RFL3 | RFL2 | RFL1 | RFL0 | | | PSR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | LMON | | | TROCR | TROC31 | TROC30 | TROC29 | TROC28 | TROC27 | TROC26 | TROC25 | TROC24 | | | | TROC23 | TROC22 | TROC21 | TROC20 | TROC19 | TROC18 | TROC17 | TROC16 | | | | TROC15 | TROC14 | TROC13 | TROC12 | TROC11 | TROC10 | TROC9 | TROC8 | | | | TROC7 | TROC6 | TROC5 | TROC4 | TROC3 | TROC2 | TROC1 | TROC0 | | | CDCR | COSDC31 | COSDC30 | COSDC29 | COSDC28 | COSDC27 | COSDC26 | COSDC25 | COSDC24 | | | | COSDC23 | COSDC22 | COSDC21 | COSDC20 | COSDC19 | COSDC18 | COSDC17 | COSDC16 | | | | COSDC15 | COSDC14 | COSDC13 | COSDC12 | COSDC11 | COSDC10 | COSDC9 | COSDC8 | | | | COSDC7 | COSDC6 | COSDC5 | COSDC4 | COSDC3 | COSDC2 | COSDC1 | COSDC0 | | | LCCR | LCC31 | LCC30 | LCC29 | LCC28 | LCC27 | LCC26 | LCC25 | LCC24 | | | | LCC23 | LCC22 | LCC21 | LCC20 | LCC19 | LCC18 | LCC17 | LCC16 | | | | LCC15 | LCC14 | LCC13 | LCC12 | LCC11 | LCC10 | LCC9 | LCC8 | | | | LCC7 | LCC6 | LCC5 | LCC4 | LCC3 | LCC2 | LCC1 | LCC0 | | | CNDCR | CNDC31 | CNDC30 | CNDC29 | CNDC28 | CNDC27 | CNDC26 | CNDC25 | CNDC24 | | | | CNDC23 | CNDC22 | CNDC21 | CNDC20 | CNDC19 | CNDC18 | CNDC17 | CNDC16 | | | | CNDC15 | CNDC14 | CNDC13 | CNDC12 | CNDC11 | CNDC10 | CNDC9 | CNDC8 | | | | CNDC7 | CNDC6 | CNDC5 | CNDC4 | CNDC3 | CNDC2 | CNDC1 | CNDC0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | EtherC | CEFCR | CEFC31 | CEFC30 | CEFC29 | CEFC28 | CEFC27 | CEFC26 | CEFC25 | CEFC24 | | | | CEFC23 | CEFC22 | CEFC21 | CEFC20 | CEFC19 | CEFC18 | CEFC17 | CEFC16 | | | | CEFC15 | CEFC14 | CEFC13 | CEFC12 | CEFC11 | CEFC10 | CEFC9 | CEFC8 | | | | CEFC7 | CEFC6 | CEFC5 | CEFC4 | CEFC3 | CEFC2 | CEFC1 | CEFC0 | | | FRECR | FREC31 | FREC30 | FREC29 | FREC28 | FREC27 | FREC26 | FREC25 | FREC24 | | | | FREC23 | FREC22 | FREC21 | FREC20 | FREC19 | FREC18 | FREC17 | FREC16 | | | | FREC15 | FREC14 | FREC13 | FREC12 | FREC11 | FREC10 | FREC9 | FREC8 | | | | FREC7 | FREC6 | FREC5 | FREC4 | FREC3 | FREC2 | FREC1 | FREC0 | | | TSFRCR | TSFC31 | TSFC30 | TSFC29 | TSFC28 | TSFC27 | TSFC26 | TSFC25 | TSFC24 | | | | TSFC23 | TSFC22 | TSFC21 | TSFC20 | TSFC19 | TSFC18 | TSFC17 | TSFC16 | | | | TSFC15 | TSFC14 | TSFC13 | TSFC12 | TSFC11 | TSFC10 | TSFC9 | TSFC8 | | | | TSFC7 | TSFC6 | TSFC5 | TSFC4 | TSFC3 | TSFC2 | TSFC1 | TSFC0 | | | TLFRCR | TLFC31 | TLFC30 | TLFC29 | TLFC28 | TLFC27 | TLFC26 | TLFC25 | TLFC24 | | | | TLFC23 | TLFC22 | TLFC21 | TLFC20 | TLFC19 | TLFC18 | TLFC17 | TLFC16 | | | | TLFC15 | TLFC14 | TLFC13 | TLFC12 | TLFC11 | TLFC10 | TLFC9 | TLFC8 | | | | TLFC7 | TLFC6 | TLFC5 | TLFC4 | TLFC3 | TLFC2 | TLFC1 | TLFC0 | | | RFCR | RFC31 | RFC30 | RFC29 | RFC28 | RFC27 | RFC26 | RFC25 | RFC24 | | | | RFC23 | RFC22 | RFC21 | RFC20 | RFC19 | RFC18 | RFC17 | RFC16 | | | | RFC15 | RFC14 | RFC13 | RFC12 | RFC11 | RFC10 | RFC9 | RFC8 | | | | RFC7 | RFC6 | RFC5 | RFC4 | RFC3 | RFC2 | RFC1 | RFC0 | | | MAFCR | MAFC31 | MAFC30 | MAFC29 | MAFC28 | MAFC27 | MAFC26 | MAFC25 | MAFC24 | | | | MAFC23 | MAFC22 | MAFC21 | MAFC20 | MAFC19 | MAFC18 | MAFC17 | MAFC16 | | | | MAFC15 | MAFC14 | MAFC13 | MAFC12 | MAFC11 | MAFC10 | MAFC9 | MAFC8 | | | | MAFC7 | MAFC6 | MAFC5 | MAFC4 | MAFC3 | MAFC2 | MAFC1 | MAFC0 | | | IPGR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | IPG4 | IPG3 | IPG2 | IPG1 | IPG0 | | EtherC AF | PAUSER | — — — — — — — — — — — — — — — — — — — | | —<br>—<br>AP13<br>AP5 | <b>28/20/12/4</b> — — AP12 AP4 | <br><br>AP11 | AP10 | AP9 | 24/16/8/0<br>—<br>— | |-----------|--------|---------------------------------------|-------------|-----------------------|--------------------------------|--------------|----------|---------|---------------------| | MF<br>TF | IPR | AP15 AP7 — | AP14 | —<br>АР13<br>АР5 | —<br>AP12 | —<br>AP11 | _ | | _ | | TF | | AP15 AP7 — | AP14<br>AP6 | AP13<br>AP5 | AP12 | AP11 | | | | | TF | | AP7<br>— | AP6 | AP5 | | | AP10 | AP9 | A DO | | TF | | _<br>_ | | | AP4 | | | | AP8 | | TF | | _ | _ | | | AP3 | AP2 | AP1 | AP0 | | | PAUSER | —<br>MP15 | | _ | _ | _ | _ | _ | _ | | | PAUSER | MP15 | _ | _ | | _ | _ | _ | _ | | | PAUSER | | MP14 | MP13 | MP12 | MP11 | MP10 | MP9 | MP8 | | | PAUSER | MP7 | MP6 | MP5 | MP4 | MP3 | MP2 | MP1 | MP0 | | E-DMAC ED | | _ | _ | _ | _ | _ | _ | _ | _ | | E-DMAC ED | | _ | _ | _ | _ | _ | _ | _ | _ | | E-DMAC ED | • | TPAUSE15 | TPAUSE14 | TPAUSE13 | TPAUSE12 | TPAUSE11 | TPAUSE10 | TPAUSE9 | TPAUSE8 | | E-DMAC ED | • | TPAUSE7 | TPAUSE6 | TPAUSE5 | TPAUSE4 | TPAUSE3 | TPAUSE2 | TPAUSE1 | TPAUSE0 | | | DMR | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | DE | DL1 | DL0 | _ | _ | _ | SWR | | EC | DTRR | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | TR | | EC | DRRR | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | • | _ | _ | _ | _ | _ | _ | _ | RR | | TC | DLAR | TDLA31 | TDLA30 | TDLA29 | TDLA28 | TDLA27 | TDLA26 | TDLA25 | TDLA24 | | | • | TDLA23 | TDLA22 | TDLA21 | TDLA20 | TDLA19 | TDLA18 | TDLA17 | TDLA16 | | | • | TDLA15 | TDLA14 | TDLA13 | TDLA12 | TDLA11 | TDLA10 | TDLA9 | TDLA8 | | | | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|------------------|------------|------------|------------|------------|------------|------------|-----------|-----------| | E-DMAC | RDLAR | RDLA31 | RDLA30 | RDLA29 | RDLA28 | RDLA27 | RDLA26 | RDLA25 | RDLA24 | | | | RDLA23 | RDLA22 | RDLA21 | RDLA20 | RDLA19 | RDLA18 | RDLA17 | RDLA16 | | | | RDLA15 | RDLA14 | RDLA13 | RDLA12 | RDLA11 | RDLA10 | RDLA9 | RDLA8 | | | | RDLA7 | RDLA6 | RDLA5 | RDLA4 | RDLA3 | RDLA2 | RDLA1 | RDLA0 | | | EESR | _ | TWB | _ | _ | _ | TABT | RABT | RFCOF | | | | ADE | ECI | TC | TDE | TFUF | FR | RDE | RFOF | | | | _ | _ | _ | _ | CND | DLC | CD | TRO | | | | RMAF | _ | _ | RRF | RTLF | RTSF | PRE | CERF | | | EESIPR | _ | TWBIP | _ | _ | _ | TABTIP | RABTIP | RFCOFIP | | | | ADEIP | ECIIP | TCIP | TDEIP | TFUFIP | FRIP | RDEIP | RFOFIP | | | -<br>-<br>- | | _ | _ | _ | CNDIP | DLCIP | CDIP | TROIP | | | | RMAFIP | _ | _ | RRFIP | RTLFIP | RTSFIP | PREIP | CERFIP | | | TRSCER | | _ | _ | _ | _ | _ | _ | | | | -<br>-<br>-<br>- | | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | CNDCE | DLCCE | CDCE | TROCE | | | | RMAFCE | _ | _ | RRFCE | RTLFCE | RTSFCE | PRECE | CERFCE | | | RMFCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | | | | | MFC15 | MFC14 | MFC13 | MFC12 | MFC11 | MFC10 | MFC9 | MFC8 | | | | MFC7 | MFC6 | MFC5 | MFC4 | MFC3 | MFC2 | MFC1 | MFC0 | | | TFTR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | TFT10 | TFT9 | TFT8 | | | | TFT7 | TFT6 | TFT5 | TFT4 | TFT3 | TFT2 | TFT1 | TFT0 | | | FDR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | TFD2 | TFD1 | TFD0 | | | | _ | _ | _ | _ | _ | RFD2 | RFD1 | RFD0 | | Module | | | | | | | | | | |--------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | E-DMAC | RMCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | RNC | | | EDOCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | FEC | AEC | EDH | _ | | | FCFTR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | RFF2 | RFF1 | RFF0 | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | RFD2 | RFD1 | RFD0 | | | RPADIR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | PADS1 | PADS0 | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | PADR5 | PADR4 | PADR3 | PADR2 | PADR1 | PADR0 | | | TRIMD | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | TIS | | | RBWAR | RBWA31 | RBWA30 | RBWA29 | RBWA28 | RBWA27 | RBWA26 | RBWA25 | RBWA24 | | | | RBWA23 | RBWA22 | RBWA21 | RBWA20 | RBWA19 | RBWA18 | RBWA17 | RBWA16 | | | | RBWA15 | RBWA14 | RBWA13 | RBWA12 | RBWA11 | RBWA10 | RBWA9 | RBWA8 | | | | RBWA7 | RBWA6 | RBWA5 | RBWA4 | RBWA3 | RBWA2 | RBWA1 | RBWA0 | | | RDFAR | RDFA31 | RDFA30 | RDFA29 | RDFA28 | RDFA27 | RDFA26 | RDFA25 | RDFA24 | | | | RDFA23 | RDFA22 | RDFA21 | RDFA20 | RDFA19 | RDFA18 | RDFA17 | RDFA16 | | | | RDFA15 | RDFA14 | RDFA13 | RDFA12 | RDFA11 | RDFA10 | RDFA9 | RDFA8 | | | | RDFA7 | RDFA6 | RDFA5 | RDFA4 | RDFA3 | RDFA2 | RDFA1 | RDFA0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | E-DMAC | TBRAR | TBRA31 | TBRA30 | TBRA29 | TBRA28 | TBRA27 | TBRA26 | TBRA25 | TBRA24 | | | | TBRA23 | TBRA22 | TBRA21 | TBRA20 | TBRA19 | TBRA18 | TBRA17 | TBRA16 | | | | TBRA15 | TBRA14 | TBRA13 | TBRA12 | TBRA11 | TBRA10 | TBRA9 | TBRA8 | | | | TBRA7 | TBRA6 | TBRA5 | TBRA4 | TBRA3 | TBRA2 | TBRA1 | TBRA0 | | | TDFAR | TDFA31 | TDFA30 | TDFA29 | TDFA28 | TDFA27 | TDFA26 | TDFA25 | TDFA24 | | | | TDFA23 | TDFA22 | TDFA21 | TDFA20 | TDFA19 | TDFA18 | TDFA17 | TDFA16 | | | | TDFA15 | TDFA14 | TDFA13 | TDFA12 | TDFA11 | TDFA10 | TDFA9 | TDFA8 | | | | TDFA7 | TDFA6 | TDFA5 | TDFA4 | TDFA3 | TDFA2 | TDFA1 | TDFA0 | | | CSMR | CSEBL | CSMD | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | SB5 | SB4 | SB3 | SB2 | SB1 | SB0 | | | CSSBM | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | SBM5 | SBM4 | SBM3 | SBM2 | SBM1 | SBM0 | | | CSSMR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | CS15 | CS14 | CS13 | CS12 | CS11 | CS10 | CS9 | CS8 | | | | CS7 | CS6 | CS5 | CS4 | CS3 | CS2 | CS1 | CS0 | | A-DMAC | C0C | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | C0C_R | | | | _ | _ | _ | C0C_DWF | _ | _ | _ | C0C_VLD | | | | _ | _ | _ | C0C_EIE | _ | _ | _ | C0C_E | | | СОМ | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | C0M_LIE | _ | _ | _ | _ | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | | |----------------|----------|-------------|--------------------|------------|------------|------------|------------|-----------|-----------|--|--| | A-DMAC | C0I | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | C0I_DI | _ | _ | _ | C0I_LI | | | | | | _ | _ | _ | _ | _ | _ | _ | C0I_EI | | | | | C0DSA | | | | C0DS | A[31:24] | | | | | | | | | | | | C0DS | A[23:16] | | | | | | | | | | | | C0DS | A[15:8] | | | | | | | | | | | | CODS | SA[7:0] | | | | | | | | C0DCA | | | | C0DC | A[31:24] | | | | | | | | | | | | CODC | A[23:16] | | | | | | | | | | | | | | | | | | | | | | | | | CODO | CA[7:0] | | | | | | | | C0D0 | C0CRDO[3:0] | | | | C0CH | DO[3:0] | | | | | | | | | C0CRDO[3:0] C0DA C | | | | | COC | SM[1:0] | | | | | | | _ | _ | _ | _ | _ | | | | | | | | _ | _ | | C0F[2:0] | | | | | | | | | C0D1 | | | | C0D1 | OD1[31:24] | | | | | | | | | | | | C0D1 | [23:16] | | | | | | | | | | | | C0D | 1[15:8] | | | | | | | | | | | | C0D | 1[7:0] | | | | | | | | C0D2 | | | | C0D2 | 2[31:24] | | | | | | | | | | | | C0D2 | 2[23:16] | | | | | | | | | | | | COD | 2[15:8] | | | | | | | | | | | | C0D | 2[7:0] | | | | | | | | C0D3 | _ | _ | CODWE | CODIE | _ | _ | | _ | | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | | | COD | 3[15:8] | | | | | | | | | | | | C0D | 3[7:0] | | | | | | | Module | | | | | | | | | | |--------|----------|------------|------------|------------|-----------|----------|------------|-----------|-----------| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | | | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | A-DMAC | C0D4 | | | | C0D4 | [31:24] | | | | | | | | | | C0D4 | [23:16] | | | | | | | | | | | 4[15:8] | | | | | | | | | | C0D4[7:1] | | | | _ | | | C1C | | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | C1C_R | | | | | _ | _ | C1C_DWF | _ | _ | _ | C1C_VLD | | | | _ | _ | _ | C1C_EIE | _ | _ | _ | C1C_E | | | C1M | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | C1M_LIE | _ | _ | _ | _ | | | C1I | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | C1I_DI | _ | _ | _ | C1I_LI | | | | _ | _ | _ | _ | _ | _ | _ | C1I_EI | | | C1DSA | | | | C1DS. | A[31:24] | | | | | | | | | | C1DS. | A[23:16] | | | | | | | | | | C1DS | SA[15:8] | | | | | | | | | | C1DS | SA[7:0] | | | | | | C1DCA | | | | C1DC | A[31:24] | | | | | | | | | | C1DC | A[23:16] | | | | | | | | | | C1DC | CA[15:8] | | | | | | | | | | C1D0 | CA[7:0] | | | | | | C1D0 | | | | | | C1CH | DO[3:0] | | | | | | | O[3:0] | | C1DA | C1SA | | SM[1:0] | | | | | _ | _ | _ | _ | _ | _ | | | | | | | | | | | C1F[2:0] | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | A-DMAC | C1D1 | | | | C1D1 | [31:24] | | | | | | | | | | C1D1 | [23:16] | | | | | | | | | | C1D | 1[15:8] | | | | | | | | | | C1D | 1[7:0] | | | | | | C1D2 | | | | C1D2 | 2[31:24] | | | | | | | | | | C1D2 | 2[23:16] | | | | | | | | | | C1D2 | 2[15:8] | | | | | | | | | | C1D | 2[7:0] | | | | | | C1D3 | _ | _ | C1DWE | C1DIE | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | C1D | 3[15:8] | | | | | | | | | | C1D | 3[7:0] | | | | | | C1D4 | | | | C1D4 | [31:24] | | | | | | | | | | C1D4 | [23:16] | | | | | | | | | | C1D4 | 4[15:8] | | | | | | | | | | 4[7:0] | | | | | | | FECC | _ | _ | _ | FECC_R | _ | _ | _ | FECC_DWF | | | | _ | _ | _ | FECC_DWE | _ | _ | _ | FECC_DIE | | | | _ | _ | _ | FECC_LIE | _ | _ | _ | FECC_NIE | | | | _ | _ | _ | FECC_EIE | _ | _ | _ | FECC_E | | | FECI | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | FECI_DI | _ | _ | _ | FECI_LI | | | | _ | _ | _ | FECI_NI | _ | _ | _ | FECI_EI | | | FECDSA | | | | FECDS | SA[31:24] | | | | | | | | | | FECDS | SA[23:16] | | | | | | | | | | | | | | | | | | | | | FECD | SA[7:0] | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | |----------------|-----------|------------|----------------|------------|------------|----------------|------------|-------------|-----------|--| | A-DMAC | FECDCA | | | | FECDO | CA[31:24] | | | | | | | | | | | FECDO | CA[23:16] | | | | | | | | | | | FECDO | CA[15:8] | | | | | | | | | | | FECD | CA[7:0] | | | | | | | FECD00 | | | | FECD00 | _SZ[15:8] | | | | | | | | | | | FECD0 | 0_SZ[7:0] | | | | | | | | | FECD00 | )_DO[3:0] | | | FECD00 | D_SO[3:0] | | | | | | | FECD00 | )_SN[3:0] | | FECD00_<br>DRE | F | FECD00_F[2: | 0] | | | | FECD01D0A | | | | FECD01 | D0A[31:24] | | | _ | | | | | _ | | | FECD01I | D0A[23:16] | | | _ | | | | | | | | FECD01 | D0A[15:8] | | | | | | | | | | | FECD0 | 1D0A[7:0] | | | | | | | FECD02S0A | | | | FECD02 | S0A[31:24] | | | | | | | | | | | FECD02 | S0A[23:16] | | | | | | | | | | | FECD02 | S0A[15:8] | | | | | | | | | FECD02S0A[7:0] | | | | | | | | | | FECD03S1A | | | | FECD03 | S1A[31:24] | | | | | | | | | | | FECD03 | S1A[23:16] | | | | | | | | | | | FECD03 | S1A[15:8] | | | | | | _ | | | | | FECD03 | 3S1A[7:0] | | | | | | STIF0 | STMDR_0 | | _ | _ | _ | _ | _ | _ | | | | | | | _ | _ | _ | _ | _ | _ | | | | | | | LSBSEL | EDGSEL | CLKSEL | CKFRSEL3 | CKFRSEL2 | CKFRSEL1 | CKFRSEL0 | | | | | REQACSEL | VLDACTSEL | SYCACTSEL | IOSEL | IFMDSEL3 | IFMDSEL2 | IFMDSEL1 | IFMDSEL0 | | | | STCTLR_0 | | _ | _ | _ | _ | _ | _ | | | | | | | _ | _ | _ | _ | _ | _ | | | | | | | _ | _ | _ | RCVTM2 | RCVTM1 | RCVTM0 | RCV | | | | | TRICK | _ | _ | _ | _ | REQEN | EN | SRST | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | STIF0 | STCNTCR_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | CRD | CSTP | CSET | CRST | | | STCNTVR_0 | VLU31 | VLU30 | VLU29 | VLU28 | VLU27 | VLU26 | VLU25 | VLU24 | | | | VLU23 | VLU22 | VLU21 | VLU20 | VLU19 | VLU18 | VLU17 | VLU16 | | | | VLU15 | VLU14 | VLU13 | VLU12 | VLU11 | VLU10 | VLU9 | VLU8 | | | | VLU7 | VLU6 | VLU5 | VLU4 | VLU3 | VLU2 | VLU1 | VLU0 | | | STSTR_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | LKZF | LKF | DISF | UNZF | PCRF | | | | TENDF | RENDF | RCVF3 | RCVF2 | RCVF1 | UPF | OPF | OVF | | - | STIER_0 | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | LKZE | LKE | DISE | UNZE | PCRE | | | | TENDE | RENDE | RCVE3 | RCVE2 | RCVE1 | UPE | OPE | OVE | | | STSIZER_0 | | | | SIZE | [31:24] | | | | | | | | | | SIZE | [23:16] | | | | | | | | | | SIZE | [15:8] | | | | | | | | | | SIZI | Ε[7:0] | | | | | | STPWMMR_0 | _ | | _ | PID12 | PID11 | PID10 | PID9 | PID8 | | | | PID7 | PID6 | PID5 | PID4 | PID3 | PID2 | PID1 | PID0 | | | | PIDEN | PWMUEN | PWMSEL | PWMSEL2 | | PWMC | CYC[3:0] | | | | | | PWMS | SFT[3:0] | | | PWMI | DIV[3:0] | | | | STPWMCR_0 | | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | STCXP | | | | PWMBRS | PWMBWP | PWMRS | PWMWP | STCRS | STCWP | PCRRS | PCRWP | | Module | | | | | | | | | | |--------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | STIF0 | STPWMR_0 | PWMB15 | PWMB14 | PWMB13 | PWMB12 | PWMB11 | PWMB10 | PWMB9 | PWMB8 | | | | PWMB7 | PWMB6 | PWMB5 | PWMB4 | PWMB3 | PWMB2 | PWMB1 | PWMB0 | | | | PWM15 | PWM14 | PWM13 | PWM12 | PWM11 | PWM10 | PWM9 | PWM8 | | | | PWM7 | PWM6 | PWM5 | PWM4 | PWM3 | PWM2 | PWM1 | PWM0 | | | STPCR0R_0 | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | PCRB32 | PCRB31 | | | | PCRB30 | PCRB29 | PCRB28 | PCRB27 | PCRB26 | PCRB25 | PCRB24 | PCRB23 | | | STPCR1R_0 | PCRB22 | PCRB21 | PCRB20 | PCRB19 | PCRB18 | PCRB17 | PCRB16 | PCRB15 | | | | PCRB14 | PCRB13 | PCRB12 | PCRB11 | PCRB10 | PCRB9 | PCRB8 | PCRB7 | | | | PCRB6 | PCRB5 | PCRB4 | PCRB3 | PCRB2 | PCRB1 | PCRB0 | PCRX8 | | | | PCRX7 | PCRX6 | PCRX5 | PCRX4 | PCRX3 | PCRX2 | PCRX1 | PCRX0 | | | STSTC0R_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | STCB32 | STCB31 | | | | STCB30 | STCB29 | STCB28 | STCB27 | STCB26 | STCB25 | STCB24 | STCB23 | | | STSTC1R_0 | STCB22 | STCB21 | STCB20 | STCB19 | STCB18 | STCB17 | STCB16 | STCB15 | | | | STCB14 | STCB13 | STCB12 | STCB11 | STCB10 | STCB9 | STCB8 | STCB7 | | | | STCB6 | STCB5 | STCB4 | STCB3 | STCB2 | STCB1 | STCB0 | STCX8 | | | | STCX7 | STCX6 | STCX5 | STCX4 | STCX3 | STCX2 | STCX1 | STCX0 | | | STLKCR_0 | _ | _ | _ | _ | _ | _ | LKWP | ULWP | | | | ULCNT3 | ULCNT2 | ULCNT1 | ULCNT0 | LKCNT3 | LKCNT2 | LKCNT1 | LKCNT0 | | | | GAIN3 | GAIN2 | GAIN1 | GAIN0 | LKCYC3 | LKCYC2 | LKCYC1 | LKCYC0 | | | | ULREF3 | ULREF2 | ULREF1 | ULREF0 | LKREF3 | LKREF2 | LKREF1 | LKREF0 | | | STDBGR_0 | STMON31 | STMON30 | STMON29 | STMON28 | STMON27 | STMON26 | STMON25 | STMON24 | | | | STMON23 | STMON22 | STMON21 | STMON20 | STMON19 | STMON18 | STMON17 | STMON16 | | | | STMON15 | STMON14 | STMON13 | STMON12 | STMON11 | STMON10 | STMON9 | STMON8 | | | | STMON7 | STMON6 | STMON5 | STMON4 | STMON3 | STMON2 | STMON1 | STMON0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|-----------|------------|------------|------------|------------|----------------|------------|-----------|-----------| | STIF1 | STMDR_1 | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | LSBSEL | EDGSEL | CLKSEL | CKFRSEL3 | CKFRSEL2 | CKFRSEL1 | CKFRSEL0 | | | | REQACSEL | VLDACTSEL | SYCACTSEL | IOSEL | IFMDSEL3 | IFMDSEL2 | IFMDSEL1 | IFMDSEL0 | | | STCTLR_1 | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | RCVTM2 | RCVTM1 | RCVTM0 | RCV | | | | TRICK | _ | _ | _ | _ | REQEN | EN | SRST | | | STCNTCR_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | CRD | CSTP | CSET | CRST | | | STCNTVR_1 | VLU31 | VLU30 | VLU29 | VLU28 | VLU27 | VLU26 | VLU25 | VLU24 | | | | VLU23 | VLU22 | VLU21 | VLU20 | VLU19 | VLU18 | VLU17 | VLU16 | | | | VLU15 | VLU14 | VLU13 | VLU12 | VLU11 | VLU10 | VLU9 | VLU8 | | | | VLU7 | VLU6 | VLU5 | VLU4 | VLU3 | VLU2 | VLU1 | VLU0 | | | STSTR_1 | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | | _ | _ | _ | _ | | | | | _ | _ | _ | LKZF | LKF | DISF | UNZF | PCRF | | | | TENDF | RENDF | RCVF3 | RCVF2 | RCVF1 | UPF | OPF | OWF | | | STIER_1 | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | LKZE | LKE | DISE | UNZE | PCRE | | | | TENDE | RENDE | RCVE3 | RCVE2 | RCVE1 | UPE | OPE | OWE | | | STSIZER_1 | | | | SIZE | [31:24] | | | | | | | | | | SIZE | [23:16] | | | | | | | | | | SIZE | [15:8] | | | | | | | | | | SIZI | <b>E</b> [7:0] | | | | | Module | | | | | | | | | | |--------|-----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | STIF1 | STPWMMR_1 | _ | _ | _ | PID12 | PID11 | PID10 | PID9 | PID8 | | | | PID7 | PID6 | PID5 | PID4 | PID3 | PID2 | PID1 | PID0 | | | | PIDEN | PWMUEN | PWMSEL | PWMSEL2 | | PWMC | CYC[3:0] | | | | | | PWMS | SFT[3:0] | | | PWMI | DIV[3:0] | | | | STPWMCR_1 | | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | STCXP | | | | PWMBRS | PWMBWP | PWMRS | PWMWP | STCRS | STCWP | PCRRS | PCRWP | | | STPWMR_1 | PWMB15 | PWMB14 | PWMB13 | PWMB12 | PWMB11 | PWMB10 | PWMB9 | PWMB8 | | | | PWMB7 | PWMB6 | PWMB5 | PWMB4 | PWMB3 | PWMB2 | PWMB1 | PWMB0 | | | | PWM15 | PWM14 | PWM13 | PWM12 | PWM11 | PWM10 | PWM9 | PWM8 | | | | PWM7 | PWM6 | PWM5 | PWM4 | PWM3 | PWM2 | PWM1 | PWM0 | | | STPCR0R_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | PCRB32 | PCRB31 | | | | PCRB30 | PCRB29 | PCRB28 | PCRB27 | PCRB26 | PCRB25 | PCRB24 | PCRB23 | | | STPCR1R_1 | PCRB22 | PCRB21 | PCRB20 | PCRB19 | PCRB18 | PCRB17 | PCRB16 | PCRB15 | | | | PCRB14 | PCRB13 | PCRB12 | PCRB11 | PCRB10 | PCRB9 | PCRB8 | PCRB7 | | | | PCRB6 | PCRB5 | PCRB4 | PCRB3 | PCRB2 | PCRB1 | PCRB0 | PCRX8 | | | | PCRX7 | PCRX6 | PCRX5 | PCRX4 | PCRX3 | PCRX2 | PCRX1 | PCRX0 | | | STSTC0R_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | STCB32 | STCB31 | | | | STCB30 | STCB29 | STCB28 | STCB27 | STCB26 | STCB25 | STCB24 | STCB23 | | | STSTC1R_1 | STCB22 | STCB21 | STCB20 | STCB19 | STCB18 | STCB17 | STCB16 | STCB15 | | | | STCB14 | STCB13 | STCB12 | STCB11 | STCB10 | STCB9 | STCB8 | STCB7 | | | | STCB6 | STCB5 | STCB4 | STCB3 | STCB2 | STCB1 | STCB0 | STCX8 | | | | STCX7 | STCX6 | STCX5 | STCX4 | STCX3 | STCX2 | STCX1 | STCX0 | | Module | | | | | | | | | | |--------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | STIF1 | STLKCR_1 | | _ | _ | _ | _ | _ | LKWP | ULWP | | | | ULCNT3 | ULCNT2 | ULCNT1 | ULCNT0 | LKCNT3 | LKCNT2 | LKCNT1 | LKCNT0 | | | | GAIN3 | GAIN2 | GAIN1 | GAIN0 | LKCYC3 | LKCYC2 | LKCYC1 | LKCYC0 | | | | ULREF3 | ULREF2 | ULREF1 | ULREF0 | LKREF3 | LKREF2 | LKREF1 | LKREF0 | | | STDBGR_1 | STMON31 | STMON30 | STMON29 | STMON28 | STMON27 | STMON26 | STMON25 | STMON24 | | | | STMON23 | STMON22 | STMON21 | STMON20 | STMON19 | STMON18 | STMON17 | STMON16 | | | | STMON15 | STMON14 | STMON13 | STMON12 | STMON11 | STMON10 | STMON9 | STMON8 | | | | STMON7 | STMON6 | STMON5 | STMON4 | STMON3 | STMON2 | STMON1 | STMON0 | | SSI | SCSR_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | SSI0CKS2 | SSI0CKS1 | SSI0CKS0 | | | SCSR_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | SSI1CKS2 | SSI1CKS1 | SSI1CKS0 | | | SSICR_0 | _ | _ | _ | DMEN | UIEN | OIEN | IIEN | DIEN | | | | CHNL1 | CHNL0 | DWL2 | DWL1 | DWL0 | SWL2 | SWL1 | SWL0 | | | | SCKD | SWSD | SCKP | SWSP | SPDP | SDTA | PDTA | DEL | | | | _ | CKDV2 | CKDV1 | CKDV0 | MUEN | _ | TRMD | EN | | | SSISR_0 | _ | _ | _ | DMRQ | UIRQ | OIRQ | IIRQ | DIRQ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | CHNO1 | CHNO0 | SWNO | IDST | | | SSITDR_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | SSIRDR_0 | | | | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | | | | | | | | | | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | SSI | SSICR_1 | _ | _ | _ | DMEN | UIEN | OIEN | IIEN | DIEN | | | | CHNL1 | CHNL0 | DWL2 | DWL1 | DWL0 | SWL2 | SWL1 | SWL0 | | | | SCKD | SWSD | SCKP | SWSP | SPDP | SDTA | PDTA | DEL | | | | _ | CKDV2 | CKDV1 | CKDV0 | MUEN | _ | TRMD | EN | | | SSISR_1 | _ | _ | _ | DMRQ | UIRQ | OIRQ | IIRQ | DIRQ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | CHNO1 | CHNO0 | SWNO | IDST | | | SSITDR_1 | | | | | | | | | | | | | | | | | | | | | | SSIRDR_1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | USB | D0FWAIT | | | _ | _ | _ | _ | | _ | | | | _ | | | | FWAIT3 | FWAIT2 | FWAIT1 | FWAIT0 | | | D1FWAIT | | | _ | _ | _ | _ | | _ | | | | _ | _ | _ | _ | FWAIT3 | FWAIT2 | FWAIT1 | FWAIT0 | | | D0FIFO | | | | FIFOPO | RT[31:24] | | | | | | | | | | FIFOPO | RT[23:16] | | | | | | | | | | FIFOPO | DRT[15:8] | | | | | | | | | | FIFOP | ORT[7:0] | | | | | | D1FIFO | | | | FIFOPO | RT[31:24] | | | | | | | | | | FIFOPO | RT[23:16] | | | | | | | | | | FIFOPO | DRT[15:8] | | | | | | | | | | FIFOP | ORT[7:0] | | | | | | SYSCFG | _ | _ | _ | _ | _ | SCKE | _ | | | | | HSE | DCFM | DRPD | DPRPU | _ | _ | _ | USBE | | Module | | | | | | | | | | | | |--------|-----------|------------|------------|------------|----------------|------------|------------|-----------|-----------|--|--| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | | | USB | BUSWAIT | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | _ | BWAIT3 | BWAIT2 | BWAIT1 | BWAIT0 | | | | | SYSSTS | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | _ | _ | _ | LNST1 | LNST0 | | | | | DVSTCTR | _ | _ | _ | _ | _ | _ | _ | WKUP | | | | | | RWUPE | USBRST | RESUME | UACT | _ | RHST2 | RHST1 | RHST0 | | | | | TESTMODE | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | _ | UTST3 | UTST2 | UTST1 | UTST0 | | | | | D0FBCFG | _ | _ | DF | ACC | _ | _ | _ | _ | | | | | | _ | _ | _ | TENDE | _ | _ | _ | _ | | | | | D1FBCFG | _ | _ | DF. | ACC | _ | _ | _ | _ | | | | | | _ | _ | _ | TENDE | _ | _ | _ | _ | | | | | CFIFO | | | | FIFOPORT[15:8] | | | | | | | | | | | | | FIFOP | ORT[7:0] | | | | | | | | CFIFOSEL | RCNT | REW | _ | _ | MBW1 | MBW0 | _ | BIGEND | | | | | | _ | _ | ISEL | _ | CURPIPE3 | CURPIPE2 | CURPIPE1 | CURPIPE0 | | | | | CFIFOCTR | BVAL | BCLR | FRDY | _ | DTLN11 | DTLN10 | DTLN9 | DTLN8 | | | | | | DTLN7 | DTLN6 | DTLN5 | DTLN4 | DTLN3 | DTLN2 | DTLN1 | DTLN0 | | | | | D0FIFOSEL | RCNT | REW | DCLRM | DREQE | MBW1 | MBW0 | _ | BIGEND | | | | | | _ | _ | _ | _ | CURPIPE3 | CURPIPE2 | CURPIPE1 | CURPIPE0 | | | | | D0FIFOCTR | BVAL | BCLR | FRDY | _ | DTLN11 | DTLN10 | DTLN9 | DTLN8 | | | | | | DTLN7 | DTLN6 | DTLN5 | DTLN4 | DTLN3 | DTLN2 | DTLN1 | DTLN0 | | | | | D1FIFOSEL | RCNT | REW | DCLRM | DREQE | MBW1 | MBW0 | _ | BIGEND | | | | | | _ | _ | _ | _ | CURPIPE3 | CURPIPE2 | CURPIPE1 | CURPIPE0 | | | | | D1FIFOCTR | BVAL | BCLR | FRDY | _ | DTLN11 | DTLN10 | DTLN9 | DTLN8 | | | | | | DTLN7 | DTLN6 | DTLN5 | DTLN4 | DTLN3 | DTLN2 | DTLN1 | DTLN0 | | | | | INTENB0 | VBSE | RSME | SOFE | DVSE | CTRE | BEMPE | NRDYE | BRDYE | | | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | INTENB1 | _ | BCHGE | _ | DTCHE | ATTCHE | _ | _ | | | | | | | _ | EOFERRE | SIGNE | SACKE | _ | _ | _ | _ | | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 20/21/13/5 | 28/20/12// | 27/19/11/3 | 26/18/10/2 | 25/17/0/1 | 24/16/8/0 | | | |----------------|----------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|--| | | | | 30/22/14/0 | 29/21/10/0 | 20/20/12/4 | 27/13/11/3 | 20/10/10/2 | PIPE9 | PIPE8 | | | | USB | BRDYENB | _ | _ | _ | _ | _ | _ | BRDYE | BRDYE | | | | | | PIPE7 | PIPE6 | PIPE5 | PIPE4 | PIPE3 | PIPE2 | PIPE1 | PIPE0 | | | | | | BRDYE | | | | NRDYENB | _ | _ | _ | _ | _ | _ | PIPE9<br>NRDYE | PIPE8<br>NRDYE | | | | | | PIPE7<br>NRDYE | PIPE6<br>NRDYE | PIPE5<br>NRDYE | PIPE4<br>NRDYE | PIPE3<br>NRDYE | PIPE2<br>NRDYE | PIPE1<br>NRDYE | PIPE0<br>NRDYE | | | | | BEMPENB | _ | _ | _ | _ | _ | _ | PIPE9<br>BEMPE | PIPE8<br>BEMPE | | | | | | PIPE7<br>BEMPE | PIPE6<br>BEMPE | PIPE5<br>BEMPE | PIPE4<br>BEMPE | PIPE3<br>BEMPE | PIPE2<br>BEMPE | PIPE1<br>BEMPE | PIPE0<br>BEMPE | | | | | SOFCFG | _ | _ | _ | _ | _ | _ | _ | TRNENSEL | | | | | | _ | BRDYM | _ | _ | _ | _ | _ | | | | | | INTSTS0 | VBINT | RESM | SOFR | DVST | CTRT | BEMP | NRDY | BRDY | | | | | | VBSTS | DVSQ2 | DVSQ1 | DVSQ0 | VALID | CTSQ2 | CTSQ1 | CTSQ0 | | | | | INTSTS1 | _ | BCHG | _ | DTCH | ATTCH | _ | _ | | | | | | | _ | EOFERR | SIGN | SACK | _ | _ | _ | _ | | | | | BRDYSTS | _ | _ | _ | _ | _ | _ | PIPE9<br>BRDY | PIPE8<br>BRDY | | | | | | PIPE7 | PIPE6 | PIPE5 | PIPE4 | PIPE3 | PIPE2 | PIPE1 | PIPE0 | | | | | | BRDY | | | | NRDYSTS | _ | _ | _ | _ | _ | _ | PIPE9<br>NRDY | PIPE8<br>NRDY | | | | | | PIPE7 | PIPE6 | PIPE5 | PIPE4 | PIPE3 | PIPE2 | PIPE1 | PIPE0 | | | | | | NRDY | | | | BEMPSTS | | _ | _ | _ | _ | _ | PIPE9<br>BEMP | PIPE8<br>BEMP | | | | | | PIPE7 | PIPE6 | PIPE5 | PIPE4 | PIPE3 | PIPE2 | PIPE1 | PIPE0 | | | | | | BEMP | | | | FRMNUM | OVRN | CRCE | | | | | FRNM[10:8 | ] | | | | | | | | | FRN | M[7:0] | | | | | | | | UFRMNUM | | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | _ | _ | _ | | UFRNM[2:0 | ] | | | | | USBADDR | | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | | | l | USBADDR[6: | 0] | | | | | | | USBREQ | BREQUEST[7:0] | | | | | | | | | | | | | | | | BMREQUE | STTYPE[7:0] | | | | | | | Module | | | | | | | | | | | |--------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------|--| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | | USB | USBVAL | | | | WVAL | UE[15:8] | | | | | | | | | | | WVAL | UE[7:0] | | | | | | | USBINDX | | | | WINDI | EX[15:8] | | | | | | | | | | | WIND | EX[7:0] | | | | | | | USBLENG | | | | WLENG | GTH[15:8] | | | | | | | | | | | WLEN | GTH[7:0] | | | | | | | DCPCFG | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | DIR | _ | _ | _ | _ | | | | DCPMAXP | DEVSEL3 | DEVSEL2 | DEVSEL1 | DEVSEL0 | _ | _ | _ | _ | | | | | _ | MXPS6 | MXPS5 | MXPS4 | MXPS3 | MXPS2 | MXPS1 | MXPS0 | | | | DCPCTR | BSTS | SUREQ | CSCLR | CSSTS | SUREQCLR | _ | _ | SQCLR | | | | | SQSET | SQMON | PBUSY | PINGE | _ | CCPL | PID1 | PID0 | | | | PIPESEL | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | PIPESEL3 | PIPESEL2 | PIPESEL1 | PIPESEL0 | | | | PIPECFG | TYPE1 | TYPE0 | _ | _ | _ | BFRE | DBLB | CNTMD | | | | | SHTNAK | _ | _ | DIR | EPNUM3 | EPNUM2 | EPNUM1 | EPNUM0 | | | | PIPEBUF | | | | _ | | | | | | | | | | | | BUFN | MB[7:0] | | | | | | | PIPEMAXP | | DEVS | EL[3:0] | | _ | MXPS[10:8] | | | | | | | | | | MXF | PS[7:0] | | | | | | | PIPEPERI | | _ | _ | IFIS | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | IITV2 | IITV1 | IITV0 | | | | PIPE1CTR | BSTS | INBUFM | CSCLR | CSSTS | _ | ATREPM | ACLRM | SQCLR | | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | | PIPE2CTR | BSTS | INBUFM | CSCLR | CSSTS | _ | ATREPM | ACLRM | SQCLR | | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | | PIPE3CTR | BSTS | INBUFM | CSCLR | CSSTS | _ | ATREPM | ACLRM | SQCLR | | | | | SQSET | SQMON | PBUSY | _ | | | PID1 | PID0 | | | | PIPE4CTR | BSTS | INBUFM | CSCLR | CSSTS | | ATREPM | ACLRM | SQCLR | | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | | PIPE5CTR | BSTS | INBUFM | CSCLR | CSSTS | | ATREPM | ACLRM | SQCLR | | | | | SQSET | SQMON | PBUSY | _ | _ | | PID1 | PID0 | | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | USB | PIPE6CTR | BSTS | _ | CSCLR | CSSTS | _ | _ | ACLRM | SQCLR | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | PIPE7CTR | BSTS | _ | CSCLR | CSSTS | _ | _ | ACLRM | SQCLR | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | PIPE8CTR | BSTS | _ | CSCLR | CSSTS | _ | _ | ACLRM | SQCLR | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | PIPE9CTR | BSTS | _ | CSCLR | CSSTS | _ | _ | ACLRM | SQCLR | | | | SQSET | SQMON | PBUSY | _ | _ | _ | PID1 | PID0 | | | PIPE1TRE | _ | _ | _ | _ | _ | _ | TRENB | TRCLR | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | PIPE1TRN | | | | TRNCI | NT[15:8] | | | | | | | | | | TRNC | NT[7:0] | | | | | | PIPE2TRE | _ | _ | _ | _ | _ | _ | TRENB | TRCLR | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | PIPE2TRN | | | | TRNCI | NT[15:8] | | | | | | | | | | TRNC | :NT[7:0] | | | | | | PIPE3TRE | _ | _ | _ | _ | _ | _ | TRENB | TRCLR | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | PIPE3TRN | | | | TRNCI | NT[15:8] | | | | | | | | | | TRNC | NT[7:0] | | | | | | PIPE4TRE | _ | _ | _ | _ | _ | _ | TRENB | TRCLR | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | PIPE4TRN | | | | TRNCI | NT[15:8] | | | | | | | | | | TRNC | NT[7:0] | | | | | | PIPE5TRE | _ | _ | _ | _ | _ | _ | TRENB | TRCLR | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | PIPE5TRN | | | | TRNCI | NT[15:8] | | | | | | | | | | TRNC | NT[7:0] | | | | | | DEVADD0 | | | UPPH | UB[3:0] | - | HUBPORT[2 | :0] | | | | | USBS | PD[1:0] | _ | _ | _ | _ | _ | _ | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|--------------|------------|-------------|------------|------------|------------|------------|-----------| | USB | DEVADD1 | | | | IUB[3:0] | | | HUBPORT[2: | | | | | USBS | PD[1:0] | _ | _ | _ | | | | | | DEVADD2 | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBS | PD[1:0] | _ | _ | _ | _ | _ | _ | | | DEVADD3 | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBSPD[1: | :0] | _ | _ | _ | _ | _ | _ | | | DEVADD4 | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBS | PD[1:0] | _ | _ | _ | _ | _ | _ | | | DEVADD5 | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBS | PD[1:0] | _ | _ | _ | _ | _ | | | | DEVADD6 | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | | | | | _ | | | _ | | | DEVADD7 | | | UPPHUB[3:0] | | | | HUBPORT[2: | 0] | | | | USBSPD[1:0] | | _ | _ | _ | _ | _ | _ | | | DEVADD8 | | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBS | PD[1:0] | | | _ | _ | _ | _ | | | DEVADD9 | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBS | PD[1:0] | _ | _ | _ | | | _ | | | DEVADDA | _ | | UPPH | IUB[3:0] | | | HUBPORT[2: | 0] | | | | USBS | PD[1:0] | _ | _ | _ | _ | _ | _ | | IIC3 | ICCR1_0 | ICE | RCVD | MST | TRS | CKS3 | CKS2 | CKS1 | CKS0 | | | ICCR2_0 | BBSY | SCP | SDAO | SDAOP | SCLO | _ | IIRST | _ | | | ICMR_0 | MLS | _ | _ | _ | BCWP | BC2 | BC1 | BC0 | | | ICIER_0 | TIE | TEIE | RIE | NAKIE | STIE | ACKE | ACKBR | ACKBT | | | ICSR_0 | TDRE | TEND | RDRF | NACKF | STOP | AL/OVE | AAS | ADZ | | | SAR_0 | SVA6 | SVA5 | SVA4 | SVA3 | SVA2 | SVA1 | SVA0 | FS | | | ICDRT_0 | | | | | | | | | | | ICDRR_0 | | | | | | | | | | | NF2CYC_0 | NF2CYC_0 — — | | | _ | _ | _ | PRS | NF2CYC | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | HIF | HIFIDX | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | REG5 | REG4 | REG3 | REG2 | REG1 | REG0 | BYTE1 | BYTE0 | | | HIFGSR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | STATUS15 | STATUS14 | STATUS13 | STATUS12 | STATUS11 | STATUS10 | STATUS9 | STATUS8 | | | | STATUS7 | STATUS6 | STATUS5 | STATUS4 | STATUS3 | STATUS2 | STATUS1 | STATUS0 | | | HIFSCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | DMD | DPOL | BMD | BSEL | | | | _ | _ | MD1 | _ | _ | WBSWP | EDN | во | | | HIFMCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | LOCK | _ | WT | _ | RD | _ | _ | AI/AD | | | HIFIICR | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | IIC6 | IIC5 | IIC4 | IIC3 | IIC2 | IIC1 | IIC0 | IIR | | | HIFEICR | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | _ | | | | EIC6 | EIC5 | EIC4 | EIC3 | EIC2 | EIC1 | EIC0 | EIR | | | HIFADR | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | _ | _ | | _ | _ | | | | | | _ | _ | _ | _ | _ | A9 | A8 | | | | A7 | A6 | A5 | A4 | А3 | A2 | | _ | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | HIF | HIFDATA | D31 | D30 | D29 | D28 | D27 | D26 | D25 | D24 | | | | D23 | D22 | D21 | D20 | D19 | D18 | D17 | D16 | | | | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | | | | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | | HIFDTR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | DTRG | | | HIFBICR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | BIE | BIF | | | HIFBCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | AC | | CMT | CMSTR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | STR1 | STR0 | | | CMCSR_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | CMF | CMIE | _ | _ | _ | _ | CKS1 | CKS0 | | | CMCNT_0 | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | CMCOR_0 | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | CMCSR_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | CMF | CMIE | _ | _ | _ | _ | CKS1 | CKS0 | | | CMCNT_1 | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | CMCOR_1 | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | SCIF0 | SCSMR_0 | _ | _ | _ | _ | | _ | _ | _ | | | | C/Ā | CHR | PE | O/Ē | STOP | _ | CKS1 | CKS0 | | | SCBRR_0 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCSCR_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | TIE | RIE | TE | RE | REIE | _ | CKE1 | CKE0 | | | SCFTDR_0 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCFSR_0 | PER3 | PER2 | PER1 | PER0 | FER3 | FER2 | FER1 | FER0 | | | | ER | TEND | TDFE | BRK | FER | PER | RDF | DR | | | SCFRDR_0 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCFCR_0 | _ | _ | _ | _ | _ | RSTRG2 | RSTRG1 | RSTRG0 | | | | RTRG1 | RTRG0 | TTRG1 | TTRG0 | MCE | TFRST | RFRST | LOOP | | | SCFDR_0 | _ | _ | _ | T4 | Т3 | T2 | T1 | T0 | | | | _ | _ | _ | R4 | R3 | R2 | R1 | R0 | | | SCSPTR_ | _ | _ | _ | _ | _ | _ | _ | _ | | | 0 | RTSIO | RTSDT | CTSIO | CTSDT | SCKIO | SCKDT | SPB2IO | SPB2DT | | | SCLSR_0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | ORER | | SCIF1 | SCSMR_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | C/A | CHR | PE | O/E | STOP | _ | CKS1 | CKS0 | | | SCBRR_1 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCSCR_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | TIE | RIE | TE | RE | REIE | _ | CKE1 | CKE0 | | | SCFTDR_1 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCFSR_1 | PER3 | PER2 | PER1 | PER0 | FER3 | FER2 | FER1 | FER0 | | | | ER | TEND | TDFE | BRK | FER | PER | RDF | DR | | | SCFRDR_1 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCFCR_1 | _ | | | _ | _ | RSTRG2 | RSTRG1 | RSTRG0 | | | | RTRG1 | RTRG0 | TTRG1 | TTRG0 | MCE | TFRST | RFRST | LOOP | | | SCFDR_1 | | | | T4 | Т3 | T2 | T1 | ТО | | | | | _ | _ | R4 | R3 | R2 | R1 | R0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | SCIF1 | SCSPTR_ | _ | _ | _ | _ | _ | _ | _ | _ | | | 1 | RTSIO | RTSDT | CTSIO | CTSDT | SCKIO | SCKDT | SPB2IO | SPB2DT | | | SCLSR_1 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | ORER | | SCIF2 | SCSMR_2 | _ | _ | _ | _ | _ | _ | _ | _ | | | | C/Ā | CHR | PE | O/E | STOP | _ | CKS1 | CKS0 | | | SCBRR_2 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCSCR_2 | _ | _ | _ | _ | _ | _ | _ | _ | | | | TIE | RIE | TE | RE | REIE | _ | CKE1 | CKE0 | | | SCFTDR_2 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCFSR_2 | PER3 | PER2 | PER1 | PER0 | FER3 | FER2 | FER1 | FER0 | | | | ER | TEND | TDFE | BRK | FER | PER | RDF | DR | | | SCFRDR_2 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | SCFCR_2 | _ | _ | _ | _ | _ | RSTRG2 | RSTRG1 | RSTRG0 | | | | RTRG1 | RTRG0 | TTRG1 | TTRG0 | MCE | TFRST | RFRST | LOOP | | | SCFDR_2 | _ | _ | _ | T4 | Т3 | T2 | T1 | T0 | | | | _ | _ | _ | R4 | R3 | R2 | R1 | R0 | | | SCSPTR_ | _ | _ | _ | _ | _ | _ | _ | _ | | | 2 | RTSIO | RTSDT | CTSIO | CTSDT | SCKIO | SCKDT | SPB2IO | SPB2DT | | | SCLSR_2 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | ORER | | I/O | PADRH | _ | _ | _ | _ | _ | _ | PA25DR | PA24DR | | | | PA23DR | PA22DR | PA21DR | PA20DR | PA19DR | PA18DR | PA17DR | _ | | | PAIORH | _ | _ | _ | _ | _ | _ | PA25IOR | PA24IOR | | | | PA23IOR | PA22IOR | PA21IOR | PA20IOR | PA19IOR | PA18IOR | PA17IOR | _ | | | PACRH2 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | PA25MD0 | _ | PA24MD0 | | | PACRH1 | _ | PA23MD0 | _ | PA22MD0 | _ | PA21MD0 | _ | PA20MD0 | | | | _ | PA19MD0 | _ | PA18MD0 | _ | PA17MD0 | _ | _ | | | PBDRL | _ | _ | _ | _ | _ | _ | _ | _ | | | | PB7DR | PB6DR | PB5DR | PB4DR | PB3DR | PB2DR | PB1DR | PB0DR | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | I/O | PBIORL | _ | _ | _ | | | _ | _ | _ | | | | PB7IOR | PB6IOR | PB5IOR | PB4IOR | PB3IOR | PB2IOR | PB1IOR | PB0IOR | | | PBCRL1 | _ | PB7MD0 | _ | PB6MD0 | PB5MD1 | PB5MD0 | PB4MD1 | PB4MD0 | | | | PB3MD1 | PB3MD0 | PB2MD1 | PB2MD0 | PB1MD1 | PB1MD0 | PB0MD1 | PB0MD0 | | | PCDRH | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | PC20DR | PC19DR | PC18DR | PC17DR | PC16DR | | | PCDRL | PC15DR | PC14DR | PC13DR | PC12DR | PC11DR | PC10DR | PC9DR | PC8DR | | | | PC7DR | PC6DR | PC5DR | PC4DR | PC3DR | PC2DR | PC1DR | PC0DR | | | PCIORH | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | PC20IOR | PC19IOR | PC18IOR | PC17IOR | PC16IOR | | | PCIORL | PC15IOR | PC14IOR | PC13IOR | PC12IOR | PC11IOR | PC10IOR | PC9IOR | PC8IOR | | | | PC7IOR | PC6IOR | PC5IOR | PC4IOR | PC3IOR | PC2IOR | PC1IOR | PC0IOR | | | PCCRH1 | _ | _ | _ | _ | _ | _ | _ | PC20MD0 | | | | _ | PC19MD0 | _ | PC18MD0 | _ | PC17MD0 | _ | PC16MD0 | | | PCCRL2 | _ | PC15MD0 | _ | PC14MD0 | _ | PC13MD0 | _ | PC12MD0 | | | | _ | PC11MD0 | _ | PC10MD0 | _ | PC9MD0 | _ | PC8MD0 | | | PCCRL1 | _ | PC7MD0 | _ | PC6MD0 | _ | PC5MD0 | _ | PC4MD0 | | | | _ | PC3MD0 | _ | PC2MD0 | _ | PC1MD0 | _ | PC0MD0 | | | PDDRL | _ | _ | _ | _ | _ | _ | _ | _ | | | | PD7DR | PD6DR | PD5DR | PD4DR | PD3DR | PD2DR | PD1DR | PD0DR | | | PDIORL | _ | _ | _ | _ | _ | _ | _ | _ | | | | PD7IOR | PD6IOR | PD5IOR | PD4IOR | PD3IOR | PD2IOR | PD1IOR | PD0IOR | | | PDCRL1 | PD7MD1 | PD7MD0 | PD6MD1 | PD6MD0 | PD5MD1 | PD5MD0 | PD4MD1 | PD4MD0 | | | | PD3MD1 | PD3MD0 | PD2MD1 | PD2MD0 | PD1MD1 | PD1MD0 | PD0MD1 | PD0MD0 | | | PEDRL | _ | _ | _ | _ | PE11DR | PE10DR | PE9DR | PE8DR | | | | PE7DR | PE6DR | PE5DR | PE4DR | PE3DR | PE2DR | PE1DR | PE0DR | | | PEIORL | _ | _ | _ | _ | PE11IOR | PE10IOR | PE9IOR | PE8IOR | | | | PE7IOR | PE6IOR | PE5IOR | PE4IOR | PE3IOR | PE2IOR | PE1IOR | PE0IOR | | | PECRL2 | _ | _ | _ | _ | PE13MD1 | PE13MD0 | PE12MD1 | PE12MD0 | | | | PE11MD1 | PE11MD0 | PE10MD1 | PE10MD0 | PE09MD1 | PE09MD0 | PE08MD1 | PE08MD0 | | Module | | | | | | | | | | |--------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | I/O | PECRL1 | PE07MD1 | PE07MD0 | PE06MD1 | PE06MD0 | PE05MD1 | PE05MD0 | PE04MD1 | PE04MD0 | | | | PE03MD1 | PE03MD0 | PE02MD1 | PE02MD0 | PE01MD1 | PE01MD0 | PE00MD1 | PE00MD0 | | | PFDRL | | _ | _ | _ | PF11DR | PF10DR | PF9DR | PF8DR | | | | PF7DR | PF6DR | PF5DR | PF4DR | PF3DR | PF2DR | PF1DR | PF0DR | | | PFIORL | _ | _ | _ | _ | PF11IOR | PF10IOR | PF9IOR | PF8IOR | | | | PF7IOR | PF6IOR | PF5IOR | PF4IOR | PF3IOR | PF2IOR | PF1IOR | PF0IOR | | | PFCRL2 | _ | _ | _ | _ | PF13MD1 | PF13MD0 | _ | _ | | | | PF11MD1 | PF11MD0 | PF10MD1 | PF10MD0 | PF09MD1 | PF09MD0 | _ | PF08MD0 | | | PFCRL1 | PF07MD1 | PF07MD0 | PF06MD1 | PF06MD0 | PF05MD1 | PF05MD0 | PF04MD1 | PF04MD0 | | | | PF03MD1 | PF03MD0 | PF02MD1 | PF02MD0 | PF01MD1 | PF01MD0 | _ | PF00MD0 | | | PGDRH | _ | _ | _ | _ | _ | _ | _ | _ | | | | PG23DR | PG22DR | PG21DR | PG20DR | PG19DR | PG18DR | PG17DR | PG16DR | | | PGDRL | PG15DR | PG14DR | PG13DR | PG12DR | PG11DR | PG10DR | PG9DR | PG8DR | | | | PG7DR | PG6DR | PG5DR | PG4DR | PG3DR | PG2DR | PG1DR | PG0DR | | | PGIORH | _ | _ | _ | _ | _ | _ | _ | _ | | | | PG23IOR | PG22IOR | PG21IOR | PG20IOR | PG19IOR | PG18IOR | PG17IOR | PG16IOR | | | PGIORL | PG15IOR | PG14IOR | PG13IOR | PG12IOR | PG11IOR | PG10IOR | PG9IOR | PG8IOR | | | | PG7IOR | PG6IOR | PG5IOR | PG4IOR | PG3IOR | PG2IOR | PG1IOR | PG0IOR | | | PGCRH2 | _ | PG23MD0 | _ | PG22MD0 | _ | PG21MD0 | _ | PG20MD0 | | | | _ | PG19MD0 | _ | PG18MD0 | _ | PG17MD0 | _ | PG16MD0 | | | PGCRL2 | _ | PG15MD0 | _ | PG14MD0 | _ | PG13MD0 | _ | PG12MD0 | | | | _ | PG11MD0 | _ | PG10MD0 | _ | PG09MD0 | _ | PG08MD0 | | | PGCRL1 | _ | PG07MD0 | _ | PG06MD0 | _ | PG05MD0 | _ | PG04MD0 | | | | _ | PG03MD0 | _ | PG02MD0 | _ | PG01MD0 | _ | PG00MD0 | | UBC | BAR_0 | BA31 | BA30 | BA29 | BA28 | BA27 | BA26 | BA25 | BA24 | | | | BA23 | BA22 | BA21 | BA20 | BA19 | BA18 | BA17 | BA16 | | | | BA15 | BA14 | BA13 | BA12 | BA11 | BA10 | BA9 | BA8 | | | | BA7 | BA6 | BA5 | BA4 | BA3 | BA2 | BA1 | BA0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | UBC | BAMR_0 | BAM31 | BAM30 | BAM29 | BAM28 | BAM27 | BAM26 | BAM25 | BAM24 | | OBO | DAWN 1_0 | BAM23 | BAM22 | BAM21 | BAM20 | BAM19 | BAM18 | BAM17 | BAM16 | | | | BAM15 | BAM14 | BAM13 | BAM12 | BAM11 | BAM10 | BAM9 | BAM8 | | | | BAM7 | BAM6 | BAM5 | BAM4 | BAM3 | BAM2 | BAM1 | BAM0 | | | BDR_0 | BD31 | BD30 | BD29 | BD28 | BD27 | BD26 | BD25 | BD24 | | | DD11_0 | BD23 | BD22 | BD21 | BD20 | BD19 | BD18 | BD17 | BD16 | | | | BD15 | BD14 | BD13 | BD12 | BD19 | BD10 | BD9 | BD8 | | | | | | | | | | | BD0 | | | DDMD 0 | BD7 | BD6 | BD5 | BD4 | BD3 | BD2 | BD1 | | | | BDMR_0 | BDM31 | BDM30 | BDM29 | BDM28 | BDM27 | BDM26 | BDM25 | BDM24 | | | | BDM23 | BDM22 | BDM21 | BDM20 | BDM19 | BDM18 | BDM17 | BDM16 | | | | BDM15 | BDM14 | BDM13 | BDM12 | BDM11 | BDM10 | BDM9 | BDM8 | | | | BDM7 | BDM6 | BDM5 | BDM4 | BDM3 | BDM2 | BDM1 | BDM0 | | | BAR_1 | BA31 | BA30 | BA29 | BA28 | BA27 | BA26 | BA25 | BA24 | | | | BA23 | BA22 | BA21 | BA20 | BA19 | BA18 | BA17 | BA16 | | | | BA15 | BA14 | BA13 | BA12 | BA11 | BA10 | BA9 | BA8 | | | | BA7 | BA6 | BA5 | BA4 | BA3 | BA2 | BA1 | BA0 | | | BAMR_1 | BAM31 | BAM30 | BAM29 | BAM28 | BAM27 | BAM26 | BAM25 | BAM24 | | | | BAM23 | BAM22 | BAM21 | BAM20 | BAM19 | BAM18 | BAM17 | BAM16 | | | | BAM15 | BAM14 | BAM13 | BAM12 | BAM11 | BAM10 | BAM9 | BAM8 | | | | BAM7 | BAM6 | BAM5 | BAM4 | ВАМ3 | BAM2 | BAM1 | BAM0 | | | BDR_1 | BD31 | BD30 | BD29 | BD28 | BD27 | BD26 | BD25 | BD24 | | | | BD23 | BD22 | BD21 | BD20 | BD19 | BD18 | BD17 | BD16 | | | | BD15 | BD14 | BD13 | BD12 | BD11 | BD10 | BD9 | BD8 | | | | BD7 | BD6 | BD5 | BD4 | BD3 | BD2 | BD1 | BD0 | | | BDMR_1 | BDM31 | BDM30 | BDM29 | BDM28 | BDM27 | BDM26 | BDM25 | BDM24 | | | | BDM23 | BDM22 | BDM21 | BDM20 | BDM19 | BDM18 | BDM17 | BDM16 | | | | BDM15 | BDM14 | BDM13 | BDM12 | BDM11 | BDM10 | BDM9 | BDM8 | | | | BDM7 | BDM6 | BDM5 | BDM4 | врмз | BDM2 | BDM1 | BDM0 | | | BBR_0 | _ | _ | UBID | DBE | CP3 | CP2 | CP1 | CP0 | | | | CD1 | CD0 | ID1 | ID0 | RW1 | RW0 | SZ1 | SZ0 | | Module<br>Name | Register | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | |----------------|----------|------------|------------|------------|------------|------------|------------|-----------|-----------| | UBC | BBR_1 | _ | _ | UBID | DBE | CP3 | CP2 | CP1 | CP0 | | | | CD1 | CD0 | ID1 | ID0 | RW1 | RW0 | SZ1 | SZ0 | | | BRCR | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | | SCMFC0 | SCMFC1 | SCMFD0 | SCMFD1 | _ | _ | _ | _ | | | | _ | PCB1 | PCB0 | _ | _ | _ | _ | _ | | H-UDI | SDIR | TI7 | TI6 | TI5 | TI4 | TI3 | TI2 | TI1 | TIO | | | | _ | _ | _ | _ | _ | _ | _ | _ | # 28.3 Register States in Each Operating Mode | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | Cache | CCR1 | H'FFFC1000 | Initialized | Retained | Retained | Retained | | | CCR2 | H'FFFC1004 | Initialized | Retained | Retained | Retained | | INTC | ICR0 | H'FFFE0800 | Initialized*1 | Retained | *³ | Retained | | | ICR1 | H'FFFE0802 | Initialized*1 | Retained | *³ | Retained | | | IRQRR | H'FFFE0806 | Initialized | Retained | *³ | Retained | | | IBCR | H'FFFE080C | Initialized | Retained | —* <sup>3</sup> | Retained | | | IBNR | H'FFFE080E | Initialized | Retained | *³ | Retained | | | IPR01 | H'FFFE0818 | Initialized | Retained | *³ | Retained | | | IPR02 | H'FFFE081A | Initialized | Retained | —* <sup>3</sup> | Retained | | | IPR06 | H'FFFE0C00 | Initialized | Retained | *³ | Retained | | | IPR07 | H'FFFE0C02 | Initialized | Retained | *³ | Retained | | | IPR08 | H'FFFE0C04 | Initialized | Retained | *³ | Retained | | | IPR09 | H'FFFE0C06 | Initialized | Retained | *³ | Retained | | | IPR10 | H'FFFE0C08 | Initialized | Retained | *³ | Retained | | | IPR11 | H'FFFE0C0A | Initialized | Retained | *³ | Retained | | | IPR12 | H'FFFE0C0C | Initialized | Retained | *³ | Retained | | | IPR13 | H'FFFE0C0E | Initialized | Retained | *³ | Retained | | | IPR14 | H'FFFE0C10 | Initialized | Retained | *³ | Retained | | | IPR15 | H'FFFE0C12 | Initialized | Retained | *³ | Retained | | | IPR16 | H'FFFE0C14 | Initialized | Retained | *³ | Retained | | BSC | CMNCR | H'FFFC0000 | Initialized*1 | Retained | *³ | Retained | | | CS0BCR | H'FFFC0004 | Initialized | Retained | *³ | Retained | | | CS3BCR | H'FFFC0010 | Initialized | Retained | *³ | Retained | | | CS4BCR | H'FFFC0014 | Initialized | Retained | —* <sup>3</sup> | Retained | | | CS5BCR | H'FFFC0018 | Initialized | Retained | *³ | Retained | | | CS6BCR | H'FFFC001C | Initialized | Retained | *³ | Retained | | | CS0WCR | H'FFFC0028 | Initialized | Retained | *³ | Retained | | | CS3WCR | H'FFFC0034 | Initialized | Retained | *³ | Retained | | | CS4WCR | H'FFFC0038 | Initialized | Retained | *³ | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | BSC | CS5WCR | H'FFFC003C | Initialized | Retained | *³ | Retained | | | CS6WCR | H'FFFC0040 | Initialized | Retained | *³ | Retained | | | SDCR | H'FFFC004C | Initialized | Retained | *³ | Retained | | | RTCSR | H'FFFC0050 | Initialized | Retained | *³ | Retained | | | RTCNT | H'FFFC0054 | Initialized | Retained | *³ | Retained | | | RTCOR | H'FFFC0058 | Initialized | Retained | *³ | Retained | | | IBMPR | H'FFFC1818 | Initialized | Retained | Retained | Retained | | DMAC | SAR_0 | H'FFFE1000 | Initialized | Retained | Retained | Retained | | | DAR_0 | H'FFFE1004 | Initialized | Retained | Retained | Retained | | | DMATCR_0 | H'FFFE1008 | Initialized | Retained | Retained | Retained | | | CHCR_0 | H'FFFE100C | Initialized | Retained | Retained | Retained | | | SAR_1 | H'FFFE1010 | Initialized | Retained | Retained | Retained | | | DAR_1 | H'FFFE1014 | Initialized | Retained | Retained | Retained | | | DMATCR_1 | H'FFFE1018 | Initialized | Retained | Retained | Retained | | | CHCR_1 | H'FFFE101C | Initialized | Retained | Retained | Retained | | | SAR_2 | H'FFFE1020 | Initialized | Retained | Retained | Retained | | | DAR_2 | H'FFFE1024 | Initialized | Retained | Retained | Retained | | | DMATCR_2 | H'FFFE1028 | Initialized | Retained | Retained | Retained | | | CHCR_2 | H'FFFE102C | Initialized | Retained | Retained | Retained | | | SAR_3 | H'FFFE1030 | Initialized | Retained | Retained | Retained | | | DAR_3 | H'FFFE1034 | Initialized | Retained | Retained | Retained | | | DMATCR_3 | H'FFFE1038 | Initialized | Retained | Retained | Retained | | | CHCR_3 | H'FFFE103C | Initialized | Retained | Retained | Retained | | | SAR_4 | H'FFFE1040 | Initialized | Retained | Retained | Retained | | | DAR_4 | H'FFFE1044 | Initialized | Retained | Retained | Retained | | | DMATCR_4 | H'FFFE1048 | Initialized | Retained | Retained | Retained | | | CHCR_4 | H'FFFE104C | Initialized | Retained | Retained | Retained | | | SAR_5 | H'FFFE1050 | Initialized | Retained | Retained | Retained | | | DAR_5 | H'FFFE1054 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | DMAC | DMATCR_5 | H'FFFE1058 | Initialized | Retained | Retained | Retained | | | CHCR_5 | H'FFFE105C | Initialized | Retained | Retained | Retained | | | SAR_6 | H'FFFE1060 | Initialized | Retained | Retained | Retained | | | DAR_6 | H'FFFE1064 | Initialized | Retained | Retained | Retained | | | DMATCR_6 | H'FFFE1068 | Initialized | Retained | Retained | Retained | | | CHCR_6 | H'FFFE106C | Initialized | Retained | Retained | Retained | | | SAR_7 | H'FFFE1070 | Initialized | Retained | Retained | Retained | | | DAR_7 | H'FFFE1074 | Initialized | Retained | Retained | Retained | | | DMATCR_7 | H'FFFE1078 | Initialized | Retained | Retained | Retained | | | CHCR_7 | H'FFFE107C | Initialized | Retained | Retained | Retained | | | RSAR_0 | H'FFFE1100 | Initialized | Retained | Retained | Retained | | | RDAR_0 | H'FFFE1104 | Initialized | Retained | Retained | Retained | | | RDMATCR_0 | H'FFFE1108 | Initialized | Retained | Retained | Retained | | | RSAR_1 | H'FFFE1110 | Initialized | Retained | Retained | Retained | | | RDAR_1 | H'FFFE1114 | Initialized | Retained | Retained | Retained | | | RDMATCR_1 | H'FFFE1118 | Initialized | Retained | Retained | Retained | | | RSAR_2 | H'FFFE1120 | Initialized | Retained | Retained | Retained | | | RDAR_2 | H'FFFE1124 | Initialized | Retained | Retained | Retained | | | RDMATCR_2 | H'FFFE1128 | Initialized | Retained | Retained | Retained | | | RSAR_3 | H'FFFE1130 | Initialized | Retained | Retained | Retained | | | RDAR_3 | H'FFFE1134 | Initialized | Retained | Retained | Retained | | | RDMATCR_3 | H'FFFE1138 | Initialized | Retained | Retained | Retained | | | RSAR_4 | H'FFFE1140 | Initialized | Retained | Retained | Retained | | | RDAR_4 | H'FFFE1144 | Initialized | Retained | Retained | Retained | | | RDMATCR_4 | H'FFFE1148 | Initialized | Retained | Retained | Retained | | | RSAR_5 | H'FFFE1150 | Initialized | Retained | Retained | Retained | | | RDAR_5 | H'FFFE1154 | Initialized | Retained | Retained | Retained | | | RDMATCR_5 | H'FFFE1158 | Initialized | Retained | Retained | Retained | | | RSAR_6 | H'FFFE1160 | Initialized | Retained | Retained | Retained | | | RDAR_6 | H'FFFE1164 | Initialized | Retained | Retained | Retained | | - <u></u> | RDMATCR_6 | H'FFFE1168 | Initialized | Retained | Retained | Retained | Page 1170 of 1278 | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | DMAC | RSAR_7 | H'FFFE1170 | Initialized | Retained | Retained | Retained | | | RDAR_7 | H'FFFE1174 | Initialized | Retained | Retained | Retained | | | RDMATCR_7 | H'FFFE1178 | Initialized | Retained | Retained | Retained | | | DMAOR | H'FFFE1200 | Initialized | Retained | Retained | Retained | | | DMARS0 | H'FFFE1300 | Initialized | Retained | Retained | Retained | | | DMARS1 | H'FFFE1304 | Initialized | Retained | Retained | Retained | | | DMARS2 | H'FFFE1308 | Initialized | Retained | Retained | Retained | | | DMARS3 | H'FFFE130C | Initialized | Retained | Retained | Retained | | CPG | FRQCR | H'FFFE0010 | Initialized | Retained | Retained | Retained | | WDT | WTCSR | H'FFFE0000 | Initialized*2 | Retained | *³ | Retained | | | WTCNT | H'FFFE0002 | Initialized*2 | Retained | *³ | Retained | | | WRCSR | H'FFFE0004 | Initialized*2 | Retained | *³ | Retained | | Power- | STBCR | H'FFFE0014 | Initialized | Retained | *³ | Retained | | down<br>mode | STBCR2 | H'FFFE0018 | Initialized | Retained | *³ | Retained | | mode | SYSCR1 | H'FFFE0402 | Initialized | Retained | *³ | Retained | | | SYSCR2 | H'FFFE0404 | Initialized | Retained | *³ | Retained | | | STBCR3 | H'FFFE0408 | Initialized | Retained | *³ | Retained | | | STBCR4 | H'FFFE040C | Initialized | Retained | *³ | Retained | | | SYSCR3 | H'FFFE0418 | Initialized | Retained | *³ | Retained | | EtherC | ECMR | H'FFFC2160 | Initialized | Retained | Retained | Retained | | | ECSR | H'FFFC2164 | Initialized | Retained | Retained | Retained | | | ECSIPR | H'FFFC2168 | Initialized | Retained | Retained | Retained | | | PIR | H'FFFC216C | Initialized*1 | Retained | Retained | Retained | | | MAHR | H'FFFC2170 | Initialized | Retained | Retained | Retained | | | MALR | H'FFFC2174 | Initialized | Retained | Retained | Retained | | | RFLR | H'FFFC2178 | Initialized | Retained | Retained | Retained | | | PSR | H'FFFC217C | Initialized*1 | Retained | Retained | Retained | | | TROCR | H'FFFC2180 | Initialized | Retained | Retained | Retained | | | CDCR | H'FFFC2184 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | EtherC | LCCR | H'FFFC2188 | Initialized | Retained | Retained | Retained | | | CNDCR | H'FFFC218C | Initialized | Retained | Retained | Retained | | | CEFCR | H'FFFC2194 | Initialized | Retained | Retained | Retained | | | FRECR | H'FFFC2198 | Initialized | Retained | Retained | Retained | | | TSFRCR | H'FFFC219C | Initialized | Retained | Retained | Retained | | | TLFRCR | H'FFFC21A0 | Initialized | Retained | Retained | Retained | | | RFCR | H'FFFC21A4 | Initialized | Retained | Retained | Retained | | | MAFCR | H'FFFC21A8 | Initialized | Retained | Retained | Retained | | | IPGR | H'FFFC21B4 | Initialized | Retained | Retained | Retained | | | APR | H'FFFC21B8 | Initialized | Retained | Retained | Retained | | | MPR | H'FFFC21BC | Initialized | Retained | Retained | Retained | | | TPAUSER | H'FFFC21C4 | Initialized | Retained | Retained | Retained | | E-DMAC | EDMR | H'FFFC2000 | Initialized | Retained | Retained | Retained | | | EDTRR | H'FFFC2004 | Initialized | Retained | Retained | Retained | | | EDRRR | H'FFFC2008 | Initialized | Retained | Retained | Retained | | | TDLAR | H'FFFC200C | Initialized | Retained | Retained | Retained | | | RDLAR | H'FFFC2010 | Initialized | Retained | Retained | Retained | | | EESR | H'FFFC2014 | Initialized | Retained | Retained | Retained | | | EESIPR | H'FFFC2018 | Initialized | Retained | Retained | Retained | | | TRSCER | H'FFFC201C | Initialized | Retained | Retained | Retained | | | RMFCR | H'FFFC2020 | Initialized | Retained | Retained | Retained | | | TFTR | H'FFFC2024 | Initialized | Retained | Retained | Retained | | | FDR | H'FFFC2028 | Initialized | Retained | Retained | Retained | | | RMCR | H'FFFC202C | Initialized | Retained | Retained | Retained | | | EDOCR | H'FFFC2030 | Initialized | Retained | Retained | Retained | | | FCFTR | H'FFFC2034 | Initialized | Retained | Retained | Retained | | | RPADIR | H'FFFC2038 | Initialized | Retained | Retained | Retained | | | TRIMD | H'FFFC203C | Initialized | Retained | Retained | Retained | | | RBWAR | H'FFFC2040 | Initialized | Retained | Retained | Retained | | | RDFAR | H'FFFC2044 | Initialized | Retained | Retained | Retained | | | TBRAR | H'FFFC204C | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | E-DMAC | TDFAR | H'FFFC2050 | Initialized | Retained | Retained | Retained | | | CSMR | H'FFFC20E4 | Initialized | Retained | Retained | Retained | | | CSSBM | H'FFFC20E8 | Initialized | Retained | Retained | Retained | | | CSSMR | H'FFFC20EC | Initialized | Retained | Retained | Retained | | A-DMAC | C0C | H'FFFC2440 | Initialized | Retained | Retained | Retained | | | COM | H'FFFC2444 | Initialized | Retained | Retained | Retained | | | C0I | H'FFFC2448 | Initialized | Retained | Retained | Retained | | | C0DSA | H'FFFC247C | Initialized | Retained | Retained | Retained | | | C0DCA | H'FFFC2480 | Initialized | Retained | Retained | Retained | | | C0D0 | H'FFFC2484 | Initialized | Retained | Retained | Retained | | | C0D1 | H'FFFC2488 | Initialized | Retained | Retained | Retained | | | C0D2 | H'FFFC248C | Initialized | Retained | Retained | Retained | | | C0D3 | H'FFFC2490 | Initialized | Retained | Retained | Retained | | | C0D4 | H'FFFC2494 | Initialized | Retained | Retained | Retained | | | C1C | H'FFFC24B0 | Initialized | Retained | Retained | Retained | | | C1M | H'FFFC24B4 | Initialized | Retained | Retained | Retained | | | C1I | H'FFFC24B8 | Initialized | Retained | Retained | Retained | | | C1DSA | H'FFFC24EC | Initialized | Retained | Retained | Retained | | | C1DCA | H'FFFC24F0 | Initialized | Retained | Retained | Retained | | | C1D0 | H'FFFC24F4 | Initialized | Retained | Retained | Retained | | | C1D1 | H'FFFC24F8 | Initialized | Retained | Retained | Retained | | | C1D2 | H'FFFC24FC | Initialized | Retained | Retained | Retained | | | C1D3 | H'FFFC2500 | Initialized | Retained | Retained | Retained | | | C1D4 | H'FFFC2504 | Initialized | Retained | Retained | Retained | | | FECC | H'FFFC2590 | Initialized | Retained | Retained | Retained | | | FECI | H'FFFC2594 | Initialized | Retained | Retained | Retained | | | FECDSA | H'FFFC2598 | Initialized | Retained | Retained | Retained | | | FECDCA | H'FFFC259C | Initialized | Retained | Retained | Retained | | | FECD00 | H'FFFC25A0 | Initialized | Retained | Retained | Retained | | | FECD01D0A | H'FFFC25A4 | Initialized | Retained | Retained | Retained | | | FECD02S0A | H'FFFC25A8 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | A-DMAC | FECD03S1A | H'FFFC25AC | Initialized | Retained | Retained | Retained | | STIF0 | STMDR_0 | H'FFFFD000 | Initialized | Retained | Retained | Retained | | | STCTLR_0 | H'FFFFD004 | Initialized | Retained | Retained | Retained | | | STCNTCR_0 | H'FFFFD008 | Initialized | Retained | Retained | Retained | | | STCNTVR_0 | H'FFFFD00C | Initialized | Retained | Retained | Retained | | | STSTR_0 | H'FFFFD010 | Initialized | Retained | Retained | Retained | | | STIER_0 | H'FFFFD014 | Initialized | Retained | Retained | Retained | | | STSIZER_0 | H'FFFFD018 | Initialized | Retained | Retained | Retained | | | STPWMMR_0 | H'FFFFD020 | Initialized | Retained | Retained | Retained | | | STPWMCR_0 | H'FFFFD024 | Initialized | Retained | Retained | Retained | | | STPWMR_0 | H'FFFFD028 | Initialized | Retained | Retained | Retained | | | STPCR0R_0 | H'FFFFD02C | Initialized | Retained | Retained | Retained | | | STPCR1R_0 | H'FFFFD030 | Initialized | Retained | Retained | Retained | | | STSTC0R_0 | H'FFFFD034 | Initialized | Retained | Retained | Retained | | | STSTC1R_0 | H'FFFFD038 | Initialized | Retained | Retained | Retained | | | STLKCR_0 | H'FFFFD03C | Initialized | Retained | Retained | Retained | | | STDBGR_0 | H'FFFFD060 | Initialized | Retained | Retained | Retained | | STIF1 | STMDR_1 | H'FFFFD800 | Initialized | Retained | Retained | Retained | | | STCTLR_1 | H'FFFFD804 | Initialized | Retained | Retained | Retained | | | STCNTCR_1 | H'FFFFD808 | Initialized | Retained | Retained | Retained | | | STCNTVR_1 | H'FFFFD80C | Initialized | Retained | Retained | Retained | | | STSTR_1 | H'FFFFD810 | Initialized | Retained | Retained | Retained | | | STIER_1 | H'FFFFD814 | Initialized | Retained | Retained | Retained | | | STSIZER_1 | H'FFFFD818 | Initialized | Retained | Retained | Retained | | | STPWMMR_1 | H'FFFFD820 | Initialized | Retained | Retained | Retained | | | STPWMCR_1 | H'FFFFD824 | Initialized | Retained | Retained | Retained | | | STPWMR_1 | H'FFFFD828 | Initialized | Retained | Retained | Retained | | | STPCR0R_1 | H'FFFFD82C | Initialized | Retained | Retained | Retained | | | STPCR1R_1 | H'FFFFD830 | Initialized | Retained | Retained | Retained | | | STSTC0R_1 | H'FFFFD834 | Initialized | Retained | Retained | Retained | | | STSTC1R_1 | H'FFFFD838 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | STIF1 | STLKCR_1 | H'FFFFD83C | Initialized | Retained | Retained | Retained | | | STDBGR_1 | H'FFFFD860 | Initialized | Retained | Retained | Retained | | SSI | SCSR_0 | H'FFFF0000 | Initialized | Retained | Retained | Retained | | | SCSR_1 | H'FFFF0800 | Initialized | Retained | Retained | Retained | | | SSICR_0 | H'FFFFC000 | Initialized | Retained | Retained | Retained | | | SSISR_0 | H'FFFFC004 | Initialized | Retained | Retained | Retained | | | SSITDR_0 | H'FFFFC008 | Initialized | Retained | Retained | Retained | | | SSIRDR_0 | H'FFFFC00C | Initialized | Retained | Retained | Retained | | | SSICR_1 | H'FFFFC800 | Initialized | Retained | Retained | Retained | | | SSISR_1 | H'FFFFC804 | Initialized | Retained | Retained | Retained | | | SSITDR_1 | H'FFFFC808 | Initialized | Retained | Retained | Retained | | | SSIRDR_1 | H'FFFFC80C | Initialized | Retained | Retained | Retained | | USB | D0FWAIT | H'FFFC1C0C | Initialized | Retained | Retained | Retained | | | D1FWAIT | H'FFFC1C0E | Initialized | Retained | Retained | Retained | | | D0FIFO | H'FFFC1C14 | Initialized | Retained | Retained | Retained | | | D1FIFO | H'FFFC1C18 | Initialized | Retained | Retained | Retained | | | SYSCFG | H'FFFFF800 | Initialized | Retained | Retained | Retained | | | BUSWAIT | H'FFFFF802 | Initialized | Retained | Retained | Retained | | | SYSSTS | H'FFFFF804 | Initialized | Retained | Retained | Retained | | | DVSTCTR | H'FFFFF808 | Initialized | Retained | Retained | Retained | | | TESTMODE | H'FFFFF80C | Initialized | Retained | Retained | Retained | | | D0FBCFG | H'FFFFF810 | Initialized | Retained | Retained | Retained | | | D1FBCFG | H'FFFFF812 | Initialized | Retained | Retained | Retained | | | CFIFO | H'FFFFF814 | Initialized | Retained | Retained | Retained | | | CFIFOSEL | H'FFFFF820 | Initialized | Retained | Retained | Retained | | | CFIFOCTR | H'FFFFF822 | Initialized | Retained | Retained | Retained | | | D0FIFOSEL | H'FFFFF828 | Initialized | Retained | Retained | Retained | | | D0FIFOCTR | H'FFFFF82A | Initialized | Retained | Retained | Retained | | | D1FIFOSEL | H'FFFFF82C | Initialized | Retained | Retained | Retained | | | D1FIFOCTR | H'FFFFF82E | Initialized | Retained | Retained | Retained | | | INTENB0 | H'FFFFF830 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | USB | INTENB1 | H'FFFFF832 | Initialized | Retained | Retained | Retained | | | BRDYENB | H'FFFFF836 | Initialized | Retained | Retained | Retained | | | NRDYENB | H'FFFFF838 | Initialized | Retained | Retained | Retained | | | BEMPENB | H'FFFFF83A | Initialized | Retained | Retained | Retained | | | SOFCFG | H'FFFFF83C | Initialized | Retained | Retained | Retained | | | INTSTS0 | H'FFFFF840 | Initialized | Retained | Retained | Retained | | | INTSTS1 | H'FFFFF842 | Initialized | Retained | Retained | Retained | | | BRDYSTS | H'FFFFF846 | Initialized | Retained | Retained | Retained | | | NRDYSTS | H'FFFFF848 | Initialized | Retained | Retained | Retained | | | BEMPSTS | H'FFFFF84A | Initialized | Retained | Retained | Retained | | | FRMNUM | H'FFFFF84C | Initialized | Retained | Retained | Retained | | | UFRMNUM | H'FFFFF84E | Initialized | Retained | Retained | Retained | | | USBADDR | H'FFFFF850 | Initialized | Retained | Retained | Retained | | | USBREQ | H'FFFFF854 | Initialized | Retained | Retained | Retained | | | USBVAL | H'FFFFF856 | Initialized | Retained | Retained | Retained | | | USBINDX | H'FFFFF858 | Initialized | Retained | Retained | Retained | | | USBLENG | H'FFFFF85A | Initialized | Retained | Retained | Retained | | | DCPCFG | H'FFFFF85C | Initialized | Retained | Retained | Retained | | | DCPMAXP | H'FFFFF85E | Initialized | Retained | Retained | Retained | | | DCPCTR | H'FFFFF860 | Initialized | Retained | Retained | Retained | | | PIPESEL | H'FFFFF864 | Initialized | Retained | Retained | Retained | | | PIPECFG | H'FFFFF868 | Initialized | Retained | Retained | Retained | | | PIPEBUF | H'FFFFF86A | Initialized | Retained | Retained | Retained | | | PIPEMAXP | H'FFFFF86C | Initialized | Retained | Retained | Retained | | | PIPEPERI | H'FFFFF86E | Initialized | Retained | Retained | Retained | | | PIPE1CTR | H'FFFFF870 | Initialized | Retained | Retained | Retained | | | PIPE2CTR | H'FFFFF872 | Initialized | Retained | Retained | Retained | | | PIPE3CTR | H'FFFFF874 | Initialized | Retained | Retained | Retained | | | PIPE4CTR | H'FFFFF876 | Initialized | Retained | Retained | Retained | | | PIPE5CTR | H'FFFFF878 | Initialized | Retained | Retained | Retained | | | PIPE6CTR | H'FFFFF87A | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | USB | PIPE7CTR | H'FFFFF87C | Initialized | Retained | Retained | Retained | | | PIPE8CTR | H'FFFFF87E | Initialized | Retained | Retained | Retained | | | PIPE9CTR | H'FFFFF880 | Initialized | Retained | Retained | Retained | | | PIPE1TRE | H'FFFFF890 | Initialized | Retained | Retained | Retained | | | PIPE1TRN | H'FFFFF892 | Initialized | Retained | Retained | Retained | | | PIPE2TRE | H'FFFFF894 | Initialized | Retained | Retained | Retained | | | PIPE2TRN | H'FFFFF896 | Initialized | Retained | Retained | Retained | | | PIPE3TRE | H'FFFFF898 | Initialized | Retained | Retained | Retained | | | PIPE3TRN | H'FFFFF89A | Initialized | Retained | Retained | Retained | | | PIPE4TRE | H'FFFFF89C | Initialized | Retained | Retained | Retained | | | PIPE4TRN | H'FFFFF89E | Initialized | Retained | Retained | Retained | | | PIPE5TRE | H'FFFFF8A0 | Initialized | Retained | Retained | Retained | | | PIPE5TRN | H'FFFFF8A2 | Initialized | Retained | Retained | Retained | | | DEVADD0 | H'FFFFF8D0 | Initialized | Retained | Retained | Retained | | | DEVADD1 | H'FFFFF8D2 | Initialized | Retained | Retained | Retained | | | DEVADD2 | H'FFFFF8D4 | Initialized | Retained | Retained | Retained | | | DEVADD3 | H'FFFFF8D6 | Initialized | Retained | Retained | Retained | | | DEVADD4 | H'FFFFF8D8 | Initialized | Retained | Retained | Retained | | | DEVADD5 | H'FFFFF8DA | Initialized | Retained | Retained | Retained | | | DEVADD6 | H'FFFFF8DC | Initialized | Retained | Retained | Retained | | | DEVADD7 | H'FFFFF8DE | Initialized | Retained | Retained | Retained | | | DEVADD8 | H'FFFFF8E0 | Initialized | Retained | Retained | Retained | | | DEVADD9 | H'FFFFF8E2 | Initialized | Retained | Retained | Retained | | | DEVADDA | H'FFFFF8E4 | Initialized | Retained | Retained | Retained | | IIC3 | ICCR1_0 | H'FFFEE000 | Initialized | Retained | Retained | Retained | | | ICCR2_0 | H'FFFEE001 | Initialized | Retained | Retained | Retained | | | ICMR_0 | H'FFFEE002 | Initialized | Retained | Retained | Retained | | | ICIER_0 | H'FFFEE003 | Initialized | Retained | Retained | Retained | | | ICSR_0 | H'FFFEE004 | Initialized | Retained | Retained | Retained | | | SAR_0 | H'FFFEE005 | Initialized | Retained | Retained | Retained | | | ICDRT_0 | H'FFFEE006 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | IIC3 | ICDRR_0 | H'FFFEE007 | Initialized | Retained | Retained | Retained | | | NF2CYC_0 | H'FFFEE008 | Initialized | Retained | Retained | Retained | | HIF | HIFIDX | H'FFFFE000 | Initialized | Retained | Retained | Retained | | | HIFGSR | H'FFFFE004 | Initialized | Retained | Retained | Retained | | | HIFSCR | H'FFFFE008 | Initialized*1 | Retained | Retained | Retained | | | HIFMCR | H'FFFFE00C | Initialized | Retained | Retained | Retained | | | HIFIICR | H'FFFFE010 | Initialized | Retained | Retained | Retained | | | HIFEICR | H'FFFFE014 | Initialized | Retained | Retained | Retained | | | HIFADR | H'FFFFE018 | Initialized | Retained | Retained | Retained | | | HIFDATA | H'FFFFE01C | Initialized | Retained | Retained | Retained | | | HIFDTR | H'FFFFE020 | Initialized | Retained | Retained | Retained | | | HIFBICR | H'FFFFE024 | Initialized | Retained | Retained | Retained | | | HIFBCR | H'FFFFE040 | Initialized*1 | Retained | Retained | Retained | | CMT | CMSTR | H'FFFEC000 | Initialized | Initialized | Retained | Retained | | | CMCSR_0 | H'FFFEC002 | Initialized | Initialized | Retained | Retained | | | CMCNT_0 | H'FFFEC004 | Initialized | Initialized | Retained | Retained | | | CMCOR_0 | H'FFFEC006 | Initialized | Initialized | Retained | Retained | | | CMCSR_1 | H'FFFEC008 | Initialized | Initialized | Retained | Retained | | | CMCNT_1 | H'FFFEC00A | Initialized | Initialized | Retained | Retained | | | CMCOR_1 | H'FFFEC00C | Initialized | Initialized | Retained | Retained | | SCIF0 | SCSMR_0 | H'FFFE8000 | Initialized | Retained | Retained | Retained | | | SCBRR_0 | H'FFFE8004 | Initialized | Retained | Retained | Retained | | | SCSCR_0 | H'FFFE8008 | Initialized | Retained | Retained | Retained | | | SCFTDR_0 | H'FFFE800C | Undefined | Retained | Retained | Retained | | | SCFSR_0 | H'FFFE8010 | Initialized | Retained | Retained | Retained | | | SCFRDR_0 | H'FFFE8014 | Undefined | Retained | Retained | Retained | | | SCFCR_0 | H'FFFE8018 | Initialized | Retained | Retained | Retained | | | SCFDR_0 | H'FFFE801C | Initialized | Retained | Retained | Retained | | | SCSPTR_0 | H'FFFE8020 | Initialized*1 | Retained | Retained | Retained | | | SCLSR_0 | H'FFFE8024 | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | SCIF1 | SCSMR_1 | H'FFFE8800 | Initialized | Retained | Retained | Retained | | | SCBRR_1 | H'FFFE8804 | Initialized | Retained | Retained | Retained | | | SCSCR_1 | H'FFFE8808 | Initialized | Retained | Retained | Retained | | | SCFTDR_1 | H'FFFE880C | Undefined | Retained | Retained | Retained | | | SCFSR_1 | H'FFFE8810 | Initialized | Retained | Retained | Retained | | | SCFRDR_1 | H'FFFE8814 | Undefined | Retained | Retained | Retained | | | SCFCR_1 | H'FFFE8818 | Initialized | Retained | Retained | Retained | | | SCFDR_1 | H'FFFE881C | Initialized | Retained | Retained | Retained | | | SCSPTR_1 | H'FFFE8820 | Initialized*1 | Retained | Retained | Retained | | | SCLSR_1 | H'FFFE8824 | Initialized | Retained | Retained | Retained | | SCIF2 | SCSMR_2 | H'FFFE9000 | Initialized | Retained | Retained | Retained | | | SCBRR_2 | H'FFFE9004 | Initialized | Retained | Retained | Retained | | | SCSCR_2 | H'FFFE9008 | Initialized | Retained | Retained | Retained | | | SCFTDR_2 | H'FFFE900C | Undefined | Retained | Retained | Retained | | | SCFSR_2 | H'FFFE9010 | Initialized | Retained | Retained | Retained | | | SCFRDR_2 | H'FFFE9014 | Undefined | Retained | Retained | Retained | | | SCFCR_2 | H'FFFE9018 | Initialized | Retained | Retained | Retained | | | SCFDR_2 | H'FFFE901C | Initialized | Retained | Retained | Retained | | | SCSPTR_2 | H'FFFE9020 | Initialized*1 | Retained | Retained | Retained | | | SCLSR_2 | H'FFFE9024 | Initialized | Retained | Retained | Retained | | I/O | PADRH | H'FFFE3800 | Initialized | Retained | *³ | Retained | | | PAIORH | H'FFFE3804 | Initialized | Retained | *³ | Retained | | | PACRH2 | H'FFFE3808 | Initialized | Retained | *³ | Retained | | | PACRH1 | H'FFFE380A | Initialized | Retained | *³ | Retained | | | PBDRL | H'FFFE3882 | Initialized | Retained | *³ | Retained | | | PBIORL | H'FFFE3886 | Initialized | Retained | *³ | Retained | | | PBCRL1 | H'FFFE388E | Initialized | Retained | *³ | Retained | | | PCDRH | H'FFFE3900 | Initialized | Retained | *³ | Retained | | | PCDRL | H'FFFE3902 | Initialized | Retained | *³ | Retained | | | PCIORH | H'FFFE3904 | Initialized | Retained | *³ | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | I/O | PCIORL | H'FFFE3906 | Initialized | Retained | *³ | Retained | | | PCCRH1 | H'FFFE390A | Initialized | Retained | *³ | Retained | | | PCCRL2 | H'FFFE390C | Initialized | Retained | *³ | Retained | | | PCCRL1 | H'FFFE390E | Initialized | Retained | *³ | Retained | | | PDDRL | H'FFFE3982 | Initialized | Retained | *³ | Retained | | | PDIORL | H'FFFE3986 | Initialized | Retained | *³ | Retained | | | PDCRL1 | H'FFFE398E | Initialized | Retained | *³ | Retained | | | PEDRL | H'FFFE3A02 | Initialized | Retained | *³ | Retained | | | PEIORL | H'FFFE3A06 | Initialized | Retained | *³ | Retained | | | PECRL2 | H'FFFE3A0C | Initialized | Retained | *³ | Retained | | | PECRL1 | H'FFFE3A0E | Initialized | Retained | *³ | Retained | | | PFDRL | H'FFFE3A82 | Initialized | Retained | *³ | Retained | | | PFIORL | H'FFFE3A86 | Initialized | Retained | *³ | Retained | | | PFCRL2 | H'FFFE3A8C | Initialized | Retained | *³ | Retained | | | PFCRL1 | H'FFFE3A8E | Initialized | Retained | *³ | Retained | | | PGDRH | H'FFFE3B00 | Initialized | Retained | *³ | Retained | | | PGDRL | H'FFFE3B02 | Initialized | Retained | *³ | Retained | | | PGIORH | H'FFFE3B04 | Initialized | Retained | *³ | Retained | | | PGIORL | H'FFFE3B06 | Initialized | Retained | *³ | Retained | | | PGCRH2 | H'FFFE3B0A | Initialized | Retained | *³ | Retained | | | PGCRL2 | H'FFFE3B0C | Initialized | Retained | *³ | Retained | | | PGCRL1 | H'FFFE3B0E | Initialized | Retained | *³ | Retained | | UBC | BAR_0 | H'FFFC0400 | Initialized | Retained | Retained | Retained | | | BAMR_0 | H'FFFC0404 | Initialized | Retained | Retained | Retained | | | BDR_0 | H'FFFC0408 | Initialized | Retained | Retained | Retained | | | BDMR_0 | H'FFFC040C | Initialized | Retained | Retained | Retained | | | BAR_1 | H'FFFC0410 | Initialized | Retained | Retained | Retained | | | BAMR_1 | H'FFFC0414 | Initialized | Retained | Retained | Retained | | | BDR_1 | H'FFFC0418 | Initialized | Retained | Retained | Retained | | | BDMR_1 | H'FFFC041C | Initialized | Retained | Retained | Retained | | Module<br>Name | Register<br>Abbreviation | Address | Power-on<br>Reset | Software<br>Standby | Module<br>Standby | Sleep | |----------------|--------------------------|------------|-------------------|---------------------|-------------------|----------| | UBC | BBR_0 | H'FFFC04A0 | Initialized | Retained | Retained | Retained | | | BBR_1 | H'FFFC04B0 | Initialized | Retained | Retained | Retained | | | BRCR | H'FFFC04C0 | Initialized | Retained | Retained | Retained | | H-UDI | SDIR | H'FFFE2000 | Retained | Retained | Retained | Retained | Notes: 1. There are bits that will not be initialized. - 2. No initialization occurs if a WDT-based power-on reset is used. - 3. This module provides no module standby function. - 4. This is not a reset based on the power-on reset pin, but it is initialization performed by applying the PHY power supply. ## Section 29 Electrical Characteristics ## 29.1 Absolute Maximum Ratings Table 29.1 lists the absolute maximum ratings. **Table 29.1 Absolute Maximum Ratings** | Item | Symbol | Value | Unit | |------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------|------| | Power supply voltage (I/O) | VccQ | -0.3 to 4.6 | ٧ | | Power supply voltage (internal) | Vcc | -0.3 to 1.7 | ٧ | | PLL power supply voltage | Vcc (PLL) | -0.3 to 1.7 | V | | Analog power supply voltage at the USB transceiver block (core) | AV33 | -0.3 to 4.6 | V | | Analog power supply voltage at the USB transceiver block (core) | AV12 | -0.3 to 1.7 | V | | Digital power supply voltage at the USB transceiver block (pins) | DV33 | -0.3 to 4.6 | V | | Digital power supply voltage at the USB transceiver block (pins) | DV12 | -0.3 to 1.7 | V | | Digital power supply voltage at the USB transceiver block (core) | UV12 | -0.3 to 1.7 | V | | Input voltage | Vin | -0.3 to VccQ + 0.3 | V | | Operating temperature | Topr | -20 to 70 (regular specifications)<br>-40 to 85 (wide temperature<br>specifications) | °C | | Storage temperature | T <sub>stg</sub> | -55 to 125 | °C | Caution: Permanent damage to the LSI may result if absolute maximum ratings are exceeded. ## 29.2 Power-on/Power-off Sequence The sequences for turning on and off power supplies are shown below together with recommended values. Figure 29.1 Power-on/Power-off Sequence Table 29.2 Recommended Time for Power-on/Power-off Sequence | Item | Symbol | Min. | Max. | Unit | |--------------------------------------------------------------|------------------|------|------|------| | Time difference in turning on 3.3 V to 1.2 V power supplies | t <sub>pwu</sub> | 0 | _ | ms | | Time difference in turning off 1.2 V to 3.3 V power supplies | t <sub>pwd</sub> | 0 | _ | ms | | State undefined time | tunc | _ | 100 | ms | Note: The table shown above is recommended values, so they represent guidelines rather than strict requirements. The 3.3-V power supply ( $V_{\rm CC}Q$ , AV33, and DV33) should be turned on before the 1.2-V power supply ( $V_{\rm CC}$ , $V_{\rm CC}$ (PLL), AV12, DV12, and UV12) is turned on. In addition, the 3.3-V power supply should be turned off after the 1.2-V power supply is turned off. An undefined time appears until the 1.2-V power supply reaches above the minimum voltage and after it has reached below the minimum voltage. During these periods, pin and internal states become undefined. Design the system so that these undefined states do not cause an overall malfunction. #### **DC** Characteristics 29.3 ## Table 29.3 DC Characteristics (1) [Common Items] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, $AV12 = 1.1 \text{ to } 1.3 \text{ V}, \ AV33 = 3.1 \text{ to } 3.5 \text{ V}, \ V_{ss} = V_{ss} \ (PLL) = DG12 = UG12 = V_{ss}Q = DG33 = AG12 = AG33 = 0 \text{ V},$ Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to $85^{\circ}$ C (wide temperature specifications) | Item | | Symbol | Min. | Тур. | Max. | Unit | <b>Test Conditions</b> | | |--------------------------|-------------|--------------|----------------------|------|-------------------|-------------------|------------------------|-----------------------------------------------------------------------------------------| | Power supp | ply voltage | | VccQ | 3.1 | 3.3 | 3.5 | V | | | | | | Vcc | 1.1 | 1.2 | 1.3 | ٧ | | | PLL power supply voltage | | | Vcc (PLL) | 1.1 | 1.2 | 1.3 | ٧ | | | USB power supply voltage | | | AV33<br>DV33 | 3.1 | 3.3 | 3.5 | V | | | | | | AV12<br>DV12<br>UV12 | 1.1 | 1.2 | 1.3 | V | | | Supply | Normal | VccQ | Icc0 | _ | 50* <sup>3</sup> | 70*³ | mA | Values measured at | | current*1 | operation | | | | 33*4 | 50*4 | | maximum power supply voltages. | | | | DV33 | Icc1*2 | _ | 44 | 65 | | Regular | | | | Vcc | Icc2 | _ | 230*³ | 460* <sup>3</sup> | | specifications:<br>I | | | | Vcc (PLL) | | | 166* <sup>4</sup> | 400*4 | | $B\phi = 100 \text{ MHz}$ | | | | DV12<br>UV12 | Icc3*2 | _ | 32 | 55 | _ | Pφ = 50 MHz<br>Wide temperature | | | | AV33 | Icc4*2 | _ | 4 | 5 | _ | specifications:<br>Io = 133.3 MHz | | | | AV12 | Icc5*2 | _ | 14 | 16 | | $B\phi = 66.6 \text{ MHz}$<br>$P\phi = 33.3 \text{ MHz}$ | | | Sleep mode | VccQ | I <sub>sleep</sub> 0 | _ | 50* <sup>3</sup> | 70*³ | mA | Values measured at | | | | | | | 33*4 | 50*⁴ | | maximum power supply voltages. | | | | DV33 | Isleep1*2 | _ | 44 | 65 | | Regular | | | | Vcc | Isleep2 | _ | 170*³ | 400* <sup>3</sup> | | specifications:<br>I | | | | Vcc (PLL) | | | 127*4 | 360*4 | | $B\phi = 100 \text{ MHz}$ | | | | DV12<br>UV12 | Isleep3*2 | _ | 32 | 55 | _ | $P\phi = 50 \text{ MHz}$<br>Wide temperature | | | | AV33 | Isleep4*2 | _ | 4 | 5 | _ | specifications: | | | | AV12 | Isleep5*2 | _ | 14 | 16 | _ | $I\phi = 133.3 \text{ MHz}$<br>$B\phi = 66.6 \text{ MHz}$<br>$P\phi = 33.3 \text{ MHz}$ | | | | | | | | | | | | Item | | | Symbol | Min. | Тур. | Max. | Unit | Test<br>Conditions | |-----------------------------|---------------------------------------|----------------------------------|-----------------------|------|------|------|------|--------------------------------------------------------| | Supply current*5 | Software<br>standby<br>mode | VccQ | I <sub>sstby</sub> 00 | _ | 38 | 45 | μΑ | Ta > 50°C | | | | DV33 | | | | | | Values | | | | Vcc<br>Vcc (PLL)<br>DV12<br>UV12 | I <sub>sstby</sub> 01 | _ | 250 | 280 | mA | measured at<br>maximum<br>power supply<br>voltages | | | | AV33 | Isstby02 | _ | 20 | 40 | μΑ | _ | | | | AV12 | I <sub>sstby</sub> 03 | _ | 2 | 5 | _ | | | | | VccQ | I <sub>sstby</sub> 10 | _ | 35 | 42 | μΑ | $T_a \leq 50^{\circ}C$ | | | | DV33 | | | | | | _Values | | | | Vcc<br>Vcc (PLL)<br>DV12<br>UV12 | Isstby 11 | _ | 40 | 80 | mA | measured at<br>maximum<br>power supply<br>voltages | | | | AV33 | I <sub>sstby</sub> 12 | _ | 20 | 40 | μΑ | _ | | | | AV12 | Isstby 13 | _ | 2 | 5 | | <del>-</del> | | Input<br>leakage | All input pins<br>(except PB7 to PB0) | | Iin | _ | _ | 1.0 | μА | $V_{in} = 0.5 \text{ to}$<br>$V_{CC}Q - 0.5 \text{ V}$ | | current | PB01,PB00 | | = | _ | _ | 10 | μΑ | _ | | Three-state leakage current | All input/ou<br>output pins | | II <sub>STI</sub> I | _ | _ | 1.0 | μА | $V_{in} = 0.5 \text{ to}$ $V_{CC}Q - 0.5 \text{ V}$ | | Pin capacitance | All pins | | Cin | _ | _ | 15 | pF | | Notes: 1. Supply current values are the values measured when all of the output pins and pins with the pull-up function are unloaded. - 2. In USB operations. - 3. Regular specifications - 4. Wide temperature specifications - 5. Supply current values are the values measured when all the output pins are unloaded. ## Table 29.3 DC Characteristics (2) [Excluding the Pins Related to I<sup>2</sup>C and USB] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Тур. | Max. | Unit | Test<br>Conditions | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|------|---------------|------|--------------------| | Input high voltage | EXTAL, CKIO, RES, TCK, TRST, ASEMD, TESTMD, MD_BW, MD_CK1, MD_CK0, NMI, ST1_CLKIN/SSISCK1, ST1_VCO_CLKIN/AUDIO_CLK, ST0_VCO_CLKIN/AUDIO_CLK, ST1_CLKIN/SSISCK1, ST1_VCO_CLKIN/AUDIO_CLK, ST0_CLKIN/SSISCK1, ST1_VCO_CLKIN/AUDIO_CLK, ST0_CLKIN/SSISCK0, ST0_VCO_CLKIN/AUDIO_CLK | V <sub>I</sub> н | VccQ - 0.3 | _ | VccQ + 0.3 | V | | | | Input pins other than above (excluding PB0 to PB00) | | 2.1 | _ | VccQ +<br>0.3 | V | | | Input low voltage | EXTAL, CKIO, RES, TCK, TRST, ASEMD, MD_BW, MD_CK1, MD_CK0, NMI | VIL | -0.3 | _ | 0.3 | V | | | | Input pins other than above (excluding PB0 to PB00) | _ | -0.3 | _ | 0.8 | V | | | Port B input characteristics | PB07,<br>PB06, | VIH | VccQ -<br>0.5 | _ | VccQ + 0.3 | V | | | | PB05/IRQ3,<br>PB04/IRQ2,<br>PB03/IRQ1/DREQ1,<br>PB02/IRQ0 | VIL | -0.3 | | 0.5 | V | | | Output high voltage | | Vон | 2.4 | _ | _ | V | Iон =<br>–200 μA | | Output low volta | ige | Vol | _ | _ | 0.4 | V | loL = 1.6 mA | #### Table 29.3 DC Characteristics (3) [Pins Related to I<sup>2</sup>C\*] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Тур. | Max. | Unit | Test<br>Conditions | |---------------------------------------|---------|--------------|------|---------|-------|--------------------------| | Input high voltage | VIH | Vcc Q − 0 | .5 — | VccQ+ | 0.3 V | | | Input low voltage | VIL | -0.3 | _ | 0.5 | V | | | Schmitt trigger input characteristics | VIH-VIL | Vcc Q × 0.05 | _ | _ | V | | | Output low voltage | Vol | | | Vcc Q × | 0.2 V | I <sub>OL</sub> = 3.0 mA | Note: \* Referring to the PB01/IOIS16/SCL and PB00/WAIT/SDA pins (open-drain pins) #### Table 29.3 DC Characteristics (4) [Pins Related to USB\*] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), −40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Тур. | Max. | Unit | Test<br>Conditions | |-----------------------------|--------|-------------|--------------|-------------|------|--------------------| | Reference resistance | RREF | 5.6 – 1% | 5.6 | 5.6 + 1% | kΩ | _ | | Input high voltage (VBUS) | VIH | 4.0 | _ | 5.5 | V | | | Input low voltage (VBUS) | VIL | -0.3 | _ | 1.0 | V | | | Input high voltage (USB_X1) | VIH | Vcc Q − 0.3 | <del>-</del> | Vcc Q + 0.3 | V | | | Input low voltage (USB_X1) | VIL | -0.3 | _ | 0.3 | V | | Note: \* Referring to the REFRIN, VBUS, USB\_X1, and USB\_X2 pins # Table 29.3 DC Characteristics (5) [Pins Related to USB\* (Low-Speed/Full-Speed/High-Speed Common Items)] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), −40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Тур. | Max. | Unit | Test Conditions | |--------------------------------------------------------|-----------------|-------|------|-------|------|--------------------------| | DP pull-up resistance | R <sub>pu</sub> | 0.900 | _ | 1.575 | kΩ | In idle mode | | (when the function is selected) | | 1.425 | _ | 3.090 | kΩ | In transmit/receive mode | | DP/DM pull-down resistance (when the host is selected) | R <sub>pd</sub> | 14.25 | _ | 24.80 | kΩ | | Note: \* Referring to the DP and DM pins ## Table 29.3 DC Characteristics (6) [Pins Related to USB\* (for Low-Speed/Full Speed)] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Тур. | Max. | Unit | <b>Test Conditions</b> | |-----------------------------------------|-----------------|------|------|------|------|---------------------------| | Input high voltage | VIH | 2.0 | _ | _ | V | _ | | Input low voltage | VIL | _ | _ | 0.8 | V | | | Differential input sensitivity | V <sub>DI</sub> | 0.2 | _ | _ | V | l (DP) – (DM) l | | Differential common mode range | V <sub>СМ</sub> | 0.8 | _ | 2.5 | V | | | Output high voltage | Vон | 2.8 | _ | _ | V | I <sub>OH</sub> = -200 μA | | Output low voltage | Vон | _ | _ | 0.3 | V | I <sub>OL</sub> = 2.0 mA | | Single-ended receiver threshold voltage | Vse | 0.8 | _ | 2.0 | V | | | Output signal crossover voltage range | Vors | 1.3 | | 2.0 | V | C <sub>L</sub> = 50 pF | Note: \* Referring to the DP and DM pins #### Table 29.3 DC Characteristics (7) [Pins Related to USB\* (for High Speed)] Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Тур. | Max. | Unit | <b>Test Conditions</b> | |-----------------------------------------------------------|-------------------|-------------|------|------|------|------------------------| | Squelch-detected threshold voltage (differential voltage) | V <sub>HSSQ</sub> | 100 | _ | 150 | mV | | | Common mode voltage range | VHSCM | <b>–</b> 50 | _ | 500 | mV | | | Idle state | V <sub>HSOI</sub> | -10.0 | _ | 10.0 | mV | | | Output high voltage | V <sub>HSOH</sub> | 360 | _ | 440 | mV | _ | | Output low voltage | VHSOL | -10.0 | _ | 10.0 | mV | | | Chirp J output voltage (differential) | Vchirpj | 700 | _ | 1100 | mV | | | Chirp K output voltage (differential) | Vchirpk | -900 | _ | -500 | mV | | Note: \* Referring to the DP and DM pins #### **Table 29.4 Permissible Output Currents** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Тур. | Max. | Unit | |----------------------------------------------------|-----------------------------------|----------------|------|------|------|------| | Permissible output | Pins related to IC <sup>2</sup> * | loL | _ | _ | 10 | mA | | low current (per pin) Output pins other than above | | _ | | | 2 | mA | | Permissible output low current (total) | | Σ Ιοι | _ | _ | 60 | mA | | Permissible output high current (per pin) | | <b>-I</b> он | _ | _ | 2 | mA | | Permissible output high current (total) | | Σ <b>-I</b> οн | _ | _ | 60 | mA | Note: \* When use the PB01/ $\overline{IOIS16}$ /SCL and PB00/ $\overline{WAIT}$ /SDA pins as SCL and SDA. Caution: To protect the LSI's reliability, do not exceed the output current values in table 29.4. ## 29.4 AC Characteristics Signals input to this LSI are basically handled as signals in synchronization with a clock. The setup and hold times for input pins must be followed. #### **Table 29.5 Maximum Operating Frequency** Conditions: $$V_{cc} = V_{cc}$$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Тур. | Max. | Unit | Remarks | |---------------------|---------------------------------|--------|------|------|-------|------|---------------------------------| | Operating frequency | CPU (Ιφ) | f | 60 | _ | 200 | MHz | Regular specifications | | | | | | | 133.3 | _ | Wide temperature specifications | | | Internal bus, external bus (Βφ) | _ | 60 | _ | 100 | MHz | Regular specifications | | | | | | | 66.6 | _ | Wide temperature specifications | | | Peripheral module (Pφ) | _ | 10 | _ | 50 | MHz | Regular specifications | | | | | | | 33.3 | | Wide temperature specifications | #### **Clock Timing** 29.4.1 ## Table 29.6 Clock Timing Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Max. | Unit | Figure | |-------------------------------------------------------------------|------------------|------------------|--------------------|---------------------|--------------| | EXTAL*1 clock input frequency | f <sub>E</sub> X | 15 | 25* <sup>2</sup> | MHz | 29.2 | | | | | 16.6* <sup>3</sup> | _ | | | EXTAL*1 clock input cycle time | texcyc | 40*2 | 66.6 | ns | - | | | | 60* <sup>3</sup> | _ | | | | AUDIO_CLK clock input frequency | f <sub>EX</sub> | 10 | 40 | MHz | - | | AUDIO_CLK clock input cycle time | texcyc | 25 | 100 | ns | - | | USB_X1 clock input frequency | f <sub>EX</sub> | 48 | 48 | MHz | <del>.</del> | | EXTAL* <sup>1</sup> /AUDIO_CLK clock input low-level pulse width | texl | 0.4 | 0.6 | t <sub>EXcyc</sub> | - | | EXTAL* <sup>1</sup> /AUDIO_CLK clock input high-level pulse width | tехн | 0.4 | 0.6 | t <sub>EXcyc</sub> | - | | EXTAL* <sup>1</sup> /AUDIO_CLK clock input rise time | texr | _ | 4 | ns | <del>-</del> | | EXTAL* <sup>1</sup> /SSI_CLK clock input fall time | <b>t</b> EXf | _ | 4 | ns | - | | CKIO clock input frequency | fск | 60 | 100*2 | MHz | 29.3 | | | | | 66.6* <sup>3</sup> | _ | | | CKIO clock input cycle time | <b>t</b> CKIcyc | 10*2 | 16.6 | ns | - | | | | 15* <sup>3</sup> | _ | | | | CKIO clock input low-level pulse width | <b>t</b> ckil | 0.3 | 0.7 | t <sub>CKIcyc</sub> | - | | CKIO clock input high-level pulse width | <b>t</b> cкiн | 0.3 | 0.7 | t <sub>CKIcyc</sub> | - | | CKIO clock input rise time | <b>t</b> ckir | _ | 2 | ns | - | | CKIO clock input fall time | <b>t</b> ckif | _ | 2 | ns | - | | CKIO clock output frequency | fор | 60 | 100*2 | MHz | 29.4 | | | | | 66.6* <sup>3</sup> | = | | | CKIO clock output cycle time | tcyc | 10*2 | 16.6 | ns | - | | | | 15* <sup>3</sup> | <del>-</del><br> | | | | | | | | | · · | Jun 21, 2011 | Item | Symbo | l Min. | Max. | Unit | Figure | |----------------------------------------------------|---------------|--------|------|------|----------| | CKIO clock output low-level pulse width | <b>t</b> ckol | 2 | _ | ns | 29.4 | | CKIO clock output high-level pulse width | tскон | 2 | | ns | | | CKIO clock output rise time | <b>t</b> ckor | _ | 3 | ns | | | CKIO clock output fall time | <b>t</b> ckof | _ | 3 | ns | <u> </u> | | Power-on oscillation settling time | tosc1 | 10 | | ms | 29.5 | | Oscillation settling time on return from standby 1 | tosc2 | 10 | _ | ms | 29.6 | | Oscillation settling time on return from standby 2 | tosc3 | 10 | _ | ms | 29.7 | Notes: 1. When the clock operating mode is 0 - 2. Regular specifications - 3. Wide temperature specifications Figure 29.2 EXTAL, AUDIO\_CLK, and USB\_X1 Clock Input Timing Figure 29.3 CKIO Clock Input Timing Figure 29.4 CKIO Clock Output Timing Figure 29.5 Power-On Oscillation Settling Time Figure 29.6 Oscillation Settling Time on Return from Standby (Return by Reset) Figure 29.7 Oscillation Settling Time on Return from Standby (Return by NMI or IRQ) #### 29.4.2 Control Signal Timing #### **Table 29.7 Control Signal Timing** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Max. | Unit | Figure | |-----------------|-------------------|------|------|---------------------|--------| | RES pulse width | tresw | 20*1 | _ | tcyc*3 | 29.8 | | NMI pulse width | t <sub>NMIW</sub> | 20*2 | _ | t <sub>cyc</sub> *3 | 29.9 | | IRQ pulse width | tirqw | 20*2 | _ | t <sub>cyc</sub> *3 | _ | Notes: 1. In standby mode or when the clock multiplication ratio is changed, tresw = tosc2 (10 ms). - 2. In standby mode, the third throw = toscs (10 ms). - 3. t<sub>bcyc</sub> indicates the external bus clock (Βφ) cycle. Figure 29.8 Reset Input Timing Figure 29.9 Interrupt Signal Input Timing ## 29.4.3 Bus Timing ## Table 29.8 Bus Timing Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Max. | Unit | Figure | |---------------------|----------------|-------------------|---------------------------|----------------|------|----------------------------------------------------| | Address delay | A25 to A17, A0 | <b>t</b> AD1 | 1 | 10.3 | ns | 29.10 to 29.36 | | time 1 | A16 to A1 | | 1 | 8.3 | ns | _ | | Address setup time | Э | <b>t</b> as | 0 | _ | ns | 29.10 to 29.13 | | Address hold time | | <b>t</b> ah | 0 | _ | ns | 29.10 to 29.13 | | BS delay time | | <b>t</b> BSD | _ | 8.3 | ns | 29.10 to 29.29,<br>29.33 to 29.36 | | CS delay time 1 | | tcsD1 | 1 | 8.3 | ns | 29.10 to 29.36 | | Read/write delay ti | me 1 | <b>t</b> RWD1 | 1 | 8.3 | ns | 29.10 to 29.36 | | Read strobe delay | time | <b>t</b> RSD | 1/2tbcyc | 1/2tbcyc + 8.3 | ns | 29.10 to 29.15,<br>29.33, 29.34 | | Read data setup tii | me 1 | t <sub>RDS1</sub> | 1/2t <sub>bcyc</sub> + 10 | | ns | 29.10 to 29.13,<br>29.14, 29.15,<br>29.33 to 29.36 | | Read data setup tii | me 2 | t <sub>RDS2</sub> | 4.3 | _ | ns | 29.16 to 29.19,<br>29.24 to 29.26 | | Read data hold tim | e 1 | <b>t</b> RDH1 | 0 | _ | ns | 29.10 to 29.13,<br>29.33 to 29.36 | | Read data hold tim | ie 2 | <b>t</b> RDH2 | 2 | _ | ns | 29.16 to 29.19,<br>29.24 to 29.26 | | Write enable delay | time 1 | <b>t</b> WED1 | 1/2tbcyc | 1/2tbcyc + 8.3 | ns | 29.10 to 29.13,<br>29.33, 29.34 | | Write enable delay | time 2 | twed2 | _ | 8.3 | ns | 29.15 | | Item | Symbol | Min. | Max. | Unit | Figure | |-------------------------|--------------------|----------------|---------------------------------------|------|-----------------------------------| | Write data delay time 1 | <b>t</b> WDD1 | _ | 10 | ns | 29.10 to 29.15,<br>29.33 to 29.36 | | Write data delay time 2 | twdd2 | _ | 8.3 | ns | 29.20 to 29.23,<br>29.27 to 29.29 | | Write data hold time 1 | <b>t</b> WDH1 | 1 | _ | ns | 29.10 to 29.15,<br>29.33 to 29.36 | | Write data hold time 2 | twDH2 | 1 | _ | ns | 29.20 to 29.23,<br>29.27 to 29.29 | | Write data hold time 4 | <b>t</b> WDH4 | 0 | _ | ns | 29.10, 29.33,<br>29.35 | | WAIT setup time | <b>t</b> wrs | 1/2tbcyc + 6.5 | _ | ns | 29.11 to 29.15,<br>29.34, 29.36 | | WAIT hold time | <b>t</b> wтн | 1/2tbcyc + 1 | _ | ns | 29.11 to 29.15,<br>29.34, 29.36 | | IOIS16 setup time | t <sub>IO16S</sub> | 1/2tbcyc + 6.5 | _ | ns | 29.36 | | IOIS16 hold time | <b>t</b> 1016H | 1/2tbcyc + 1 | _ | ns | 29.36 | | RAS delay time 1 | trasd1 | 1 | 8.3 | ns | 29.16 to 29.32 | | CAS delay time 1 | tcasd1 | 1 | 8.3 | ns | 29.16 to 29.32 | | DQM delay time 1 | t <sub>DQMD1</sub> | 1 | 8.3 | ns | 29.16 to 29.29 | | CKE delay time 1 | tcked1 | 1 | 8.3 | ns | 29.31 | | DACK, TEND delay time | <b>t</b> dacd | _ | Refer to<br>DMAC<br>module<br>timing. | ns | 29.10 to 29.29,<br>29.33 to 29.36 | | ICIORD delay time | ticrsd | 1/2tbcyc | 1/2tbcyc + 8.3 | ns | 29.35, 29.36 | | ICIOWR delay time | ticwsp | 1/2tbcyc | 1/2tbcyc + 8.3 | ns | 29.35, 29.36 | Note: $t_{bcyc}$ indicates the external bus clock (B $\phi$ ) cycle. Figure 29.10 Basic Bus Timing for Normal Space (No Wait) Figure 29.11 Basic Bus Timing for Normal Space (One Software Wait Cycle) Page 1199 of 1278 Figure 29.12 Basic Bus Timing for Normal Space (One External Wait Cycle) Figure 29.13 Basic Bus Timing for Normal Space (One Software Wait Cycle, External Wait Enabled (WM Bit = 0), No Idle Cycle) Figure 29.14 SRAM Bus Cycle with Byte Selection (SW = One Cycle, HW = One Cycle, One Asynchronous External Wait Cycle, BAS = 0 (Write Cycle UB/LB Control)) Figure 29.15 SRAM Bus Cycle with Byte Selection (SW = One Cycle, HW = One Cycle, One Asynchronous External Wait Cycle, BAS = 1 (Write Cycle WE Control)) Figure 29.16 Synchronous DRAM Single-Read Bus Cycle (Auto-Precharged, CAS Latency 2, WTRCD = Zero Cycle, WTRP = Zero Cycle) Figure 29.17 Synchronous DRAM Single-Read Bus Cycle (Auto-Precharged, CAS Latency 2, WTRCD = One Cycle, WTRP = One Cycle) Figure 29.18 Synchronous DRAM Burst-Read Bus Cycle (Equivalent to Four Read Cycles) (Auto-Precharged, CAS Latency 2, WTRCD = Zero Cycle, WTRP = One Cycle) Figure 29.19 Synchronous DRAM Burst-Read Bus Cycle (Equivalent to Four Read Cycles) (Auto-Precharged, CAS Latency 2, WTRCD = One Cycle, WTRP = Zero Cycle) Page 1207 of 1278 Figure 29.20 Synchronous DRAM Single-Write Bus Cycle (Auto-Precharged, TRWL = One Cycle) Figure 29.21 Synchronous DRAM Single-Write Bus Cycle (Auto-Precharged, WTRCD = Two Cycles, TRWL = One Cycle) Figure 29.22 Synchronous DRAM Burst-Write Bus Cycle (Equivalent to Four Write Cycles) (Auto-Precharged, WTRCD = Zero Cycle, TRWL = One Cycle) Figure 29.23 Synchronous DRAM Burst-Write Bus Cycle (Equivalent to Four Write Cycles) (Auto-Precharged, WTRCD = One Cycle, TRWL = One Cycle) Figure 29.24 Synchronous DRAM Burst-Read Bus Cycle (Equivalent to Four Read Cycles) (Bank Active Mode: ACT+READ Commands, CAS Latency 2, WTRCD = Zero Cycle) Figure 29.25 Synchronous DRAM Burst-Read Bus Cycle (Equivalent to Four Read Cycles) (Bank Active Mode: READ Command, Same Row Address, CAS Latency 2, WTRCD = Zero Cycle) Figure 29.26 Synchronous DRAM Burst-Read Bus Cycle (Equivalent to Four Read Cycles) (Bank Active Mode: PRE+ACT+READ Commands, Different Row Addresses, CAS Latency 2, WTRCD = Zero Cycle) Figure 29.27 Synchronous DRAM Burst-Write Bus Cycle (Equivalent to Four Write Cycles) (Bank Active Mode: ACT+WRITE Commands, WTRCD = Zero Cycle, TRWL = Zero Cycle) Figure 29.28 Synchronous DRAM Burst-Write Bus Cycle (Equivalent to Four Write Cycles) (Bank Active Mode: WRITE Command, Same Row Address, WTRCD = Zero Cycle, TRWL = Zero Cycle) Figure 29.29 Synchronous DRAM Burst-Write Bus Cycle (Equivalent to Four Write Cycles) (Bank Active Mode: PRE+ACT+WRITE Commands, Different Row Addresses, WTRCD = Zero Cycle, TRWL = Zero Cycle) Figure 29.30 Synchronous DRAM Auto-Refreshing Timing (WTRP = One Cycle, WTRC = Three Cycles) Figure 29.31 Synchronous DRAM Self-Refreshing Timing (WTRP = One Cycle) Figure 29.32 Synchronous DRAM Mode Register Write Timing (WTRP = One Cycle) Figure 29.33 PCMCIA Memory Card Bus Cycle (TED = Zero Cycle, TEH = Zero Cycle, No Wait) Figure 29.34 PCMCIA Memory Card Bus Cycle (TED = Two Cycles, TEH = One Cycle, Zero Software Wait Cycle, One Hardware Wait Cycle) Figure 29.35 PCMCIA I/O Card Bus Cycle (TED = Zero Cycle, TEH = Zero Cycle, No Wait) Figure 29.36 PCMCIA I/O Card Bus Cycle (TED = Two Cycles, TEH = One Cycle, Zero Software Wait Cycle, One Hardware Wait Cycle) #### 29.4.4 DMAC Module Timing #### **Table 29.9 DMAC Module Timing** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Max. | Unit | Figure | |-----------------------|---------------|------|------|------|--------| | DREQ setup time | <b>t</b> DRQS | 10 | _ | ns | 29.37 | | DREQ hold time | <b>t</b> DRQH | 10 | _ | _ | | | DACK, TEND delay time | <b>t</b> dacd | _ | 10 | _ | 29.38 | Figure 29.37 DREQ Input Timing Figure 29.38 DACK, TEND Output Timing ### 29.4.5 Watchdog Timer Timing Table 29.10 shows the timing of the watchdog timer. #### **Table 29.10 Watchdog Timer Timing** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss} (PLL) = DG12 = UG12 = V_{ss}Q = DG33 = AG12 = AG33 = 0 V,$$ Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Max. | Unit | Figure | |-------------------|--------|------|------|------|--------| | WDTOVF delay time | twovd | _ | 100 | ns | 29.39 | Figure 29.39 Watchdog Timer Timing #### 29.4.6 SCIF Module Timing # **Table 29.11 SCIF Module Timing** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Max. | Unit | Figure | |----------------------------------------|---------------------|---------------|--------------------------|--------------------------|-------|--------| | Input clock cycle | Clocked synchronous | tscyc | 12 | _ | tpcyc | 29.40 | | | Asynchronous | _ | 4 | _ | tpcyc | 29.40 | | Input clock rise tin | ne | <b>t</b> sckr | _ | 1.5 | tpcyc | 29.40 | | Input clock fall time | | tsckf | _ | 1.5 | tpcyc | 29.40 | | Input clock width | | tsckw | 0.4 | 0.6 | tscyc | 29.40 | | Transmit data dela<br>(Clocked synchro | • | <b>t</b> txd | _ | $3 \times t_{pcyc} + 15$ | tpcyc | 29.41 | | Receive data setu<br>(Clocked synchro | ! | taxs | $4 \times t_{pcyc} + 15$ | _ | ns | 29.41 | | Receive data hold<br>(Clocked synchro | | tвхн | 100 | _ | ns | 29.41 | Note: $t_{news}$ indicates the peripheral clock (P $\phi$ ) cycle. Figure 29.40 SCK Input Clock Timing Figure 29.41 SCIF Input/Output Timing in Clocked Synchronous Mode # 29.4.7 IIC3 Module Timing ### Table 29.12 I<sup>2</sup>C Bus Interface 3 Timing Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | | | | Values | | | | | |-------------------------------------------------------|---------------|------------------------|--------------------------------|------|------|---------|--------| | Item | Symbol | <b>Test Conditions</b> | Min. | Тур. | Max. | Unit | Figure | | SCL input cycle time | tscL | | $12 \times t_{pcyc}*^1 + 600$ | _ | _ | ns | 29.42 | | SCL input high pulse width | <b>t</b> sclh | | $3 \times t_{pcyc}$ * + 300 | _ | _ | ns | - | | SCL input low pulse width | tscll | | $5 \times t_{pcyc}^{*1}$ + 300 | _ | _ | ns | - | | SCL, SDA input rise time | <b>t</b> sr | | _ | _ | 300 | ns | - | | SCL, SDA input fall time | <b>t</b> Sf | | _ | _ | 300 | ns | - | | SCL, SDA input spike pulse removal time* <sup>2</sup> | tsp | | _ | _ | 1, 2 | tpcyc*1 | - | | SDA input bus free time | <b>t</b> BUF | | 5 | _ | _ | tpcyc*1 | - | | Start condition input hold time | <b>t</b> stah | | 3 | _ | _ | tpcyc*1 | _ | | Retransmit start condition input setup time | <b>t</b> stas | | 3 | _ | _ | tpcyc*1 | - | | Stop condition input setup time | tsтоs | | 3 | _ | _ | tpcyc*1 | - | | Data input setup time | tsdas | | 1 × t <sub>pcyc</sub> *1 + 20 | _ | _ | ns | _ | | Data input hold time | <b>t</b> SDAH | | 0 | _ | _ | ns | - | | SCL, SDA capacitive load | Cb | | 0 | _ | 100 | pF | - | | SCL, SDA output fall time*3 | <b>t</b> sf | VccQ = 3.1 to 3.5 V | _ | _ | 250 | ns | -<br>- | Notes: 1. t<sub>pcyc</sub> indicates the peripheral clock (Pφ) cycle. - 2. Depends on the value of NF2CYC. - 3. Indicates the I/O buffer characteristics. Figure 29.42 I<sup>2</sup>C Bus Interface 3 Input/Output Timing #### **SSI Module Timing** 29.4.8 # **Table 29.13 SSI Module Timing** $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, Conditions: AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Тур. | Max. | Unit | Remarks | Figure | |---------------------------|-------------------------|------------|------|------|------|-----------------|----------------| | Output clock cycle | to | 80 | _ | 6400 | ns | Output | 29.43 | | Input clock cycle | tı | 80 | _ | 6400 | ns | Input | <del>-</del> | | Clock high | thc | 32 | _ | _ | ns | Bidirectional | - | | Clock low | <b>t</b> LC | 32 | _ | _ | ns | _ | | | Clock rise time | trc | _ | _ | 20 | ns | Output (100 pF) | <del>-</del> | | Delay | <b>t</b> <sub>DTR</sub> | <b>-</b> 5 | | 25 | ns | Transmit | 29.44, 29.45 | | Input setup time | <b>t</b> sr | 25 | _ | _ | ns | Receive | 29.46, 29.47 | | Input hold time | <b>t</b> HTR | 5 | _ | _ | ns | Receive | 29.46 to 29.47 | | AUDIO_CLK input frequency | faudio | 10 | _ | 40 | MHz | | 29.48 | Figure 29.43 Clock Input/Output Timing Figure 29.44 SSI Transmit Timing (1) Figure 29.45 SSI Transmit Timing (2) Figure 29.46 SSI Receive Timing (1) Figure 29.47 SSI Receive Timing (2) Figure 29.48 AUDIO\_CLK Input Timing ### 29.4.9 USB Transceiver Timing #### Table 29.14 USB Transceiver Timing (for Full Speed) Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Тур. | Max. | Unit | Figure | |----------------------|----------------------------------|------|------|------|------|--------| | Rise time | t <sub>FR</sub> | 4 | _ | 20 | ns | 29.49 | | Fall time | t <sub>FF</sub> | 4 | _ | 20 | ns | _ | | Rise/fall time ratio | t <sub>FR</sub> /t <sub>FF</sub> | 70 | _ | 130 | % | _ | Figure 29.49 DP/DM Output Timing (for Full Speed) Figure 29.50 Measurement Circuit (for Full Speed) #### Table 29.15 USB Transceiver Timing (for Low Speed) Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss} (PLL) = DG12 = UG12 = V_{ss}Q = DG33 = AG12 = AG33 = 0 V,$ Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Тур. | Max. | Unit | Figure | |--------------------------|-------------|------|------|------|------|-------------| | Rise time | <b>t</b> LR | 75 | _ | 300 | ns | 29.51 | | Fall time | tlf | 75 | _ | 300 | ns | <del></del> | | Output driver resistance | tlr/tlf | 80 | | 125 | % | | Figure 29.51 DP/DM Output Timing (for Low Speed) Figure 29.52 Measurement Circuit (for Low Speed) # 29.4.10 SDHI Module Timing #### **Table 29.16 SDHI Module Timing** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Max. | Unit | Figure | |--------------------------------------------|------------------------|---------------|------|-------------------|-------------------|-------------| | SDHICLK clock cycle | (Pφ > 33.3 MHz) | tsdpp | 4 | _ | t <sub>pcyc</sub> | 29.53 | | | (P | _ | 2 | | | | | SDHICLK clock high width | | <b>t</b> spwH | 0.4 | _ | t <sub>sdpp</sub> | | | SDHICLK clock low wid | <b>t</b> sdwl | 0.4 | | t <sub>SDPP</sub> | | | | SDHICMD, SDHID3 to delay (data transfer mo | tsdodly | _ | 14 | ns | _ | | | SDHICMD, SDHID3 to setup time | tspisu | 12 | | ns | _ | | | SDHICMD, SDHID3 to | SDHID0 input data hold | <b>t</b> sdih | 12 | _ | ns | <del></del> | Note: $t_{new}$ is a cycle of peripheral clock (P $\phi$ ). Figure 29.53 SD Card Interface # 29.4.11 I/O Port Timing # Table 29.17 I/O Port Timing Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss} (PLL) = DG12 = UG12 = V_{ss}Q = DG33 = AG12 = AG33 = 0 V,$ Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Max. | Unit | Figure | |------------------------|----------------|------|------|------|--------| | Output data delay time | <b>t</b> PORTD | _ | 100 | ns | 29.54 | | Input data setup time | <b>t</b> PORTS | 100 | | _ | | | Input data hold time | <b>t</b> PORTH | 100 | | _ | | Figure 29.54 I/O Port Timing ### 29.4.12 HIF Module Signal Timing ### **Table 29.18 HIF Module Signal Timing** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Max. | Unit | Figure | |------------------------------|----------------------|------------------------|--------------------------|-------------------|-------------| | Read bus cycle time | t <sub>HIFCYCR</sub> | 5.0 | _ | t <sub>pcyc</sub> | 29.55 | | Write bus cycle time | t <sub>HIFCYCW</sub> | 5.0 | _ | t <sub>pcyc</sub> | <del></del> | | Read low width (in reading) | t <sub>HIFWRL</sub> | 3.0 | _ | t <sub>pcyc</sub> | | | Write low width (in writing) | t <sub>HIFWWL</sub> | 3.0 | _ | t <sub>pcyc</sub> | | | Read/write high width | t <sub>HIFWRWH</sub> | 2.0 | _ | t <sub>pcyc</sub> | | | Read data delay time | t <sub>HIFRDD</sub> | _ | $2 \times t_{pcyc} + 16$ | ns | | | Read data hold time | t <sub>HIFRDH</sub> | 0 | _ | ns | | | Write data setup time | t <sub>HIFWDS</sub> | t <sub>pcyc</sub> + 10 | _ | ns | | | Write data hold time | t <sub>HIFWDH</sub> | 10 | _ | ns | | | HIFINT output delay time | t <sub>HIFITD</sub> | _ | 20 | ns | 29.56 | | HIFRDY output delay time | t <sub>HIFRYD</sub> | _ | 20 | t <sub>pcyc</sub> | 29.57 | | HIFDREQ output delay time | t <sub>HIFDQD</sub> | _ | 20 | ns | 29.56 | | HIF pin enable delay time | t <sub>HIFEBD</sub> | _ | 20 | ns | 29.57 | | HIF pin disable delay time | t <sub>HIFDBD</sub> | _ | 20 | ns | 29.57 | Notes: 1. $t_{neve}$ indicates the peripheral clock (P $\phi$ ) cycle. - 2. The $t_{HIFWBL}$ period is specified as the overlap between the LOW period of the $\overline{HIFCS}$ signal and the LOW period of the $\overline{HIFRD}$ signal. - 3. The t<sub>HIFWWL</sub> period is specified as the overlap between the LOW period of the HIFCS signal and the LOW period of the HIFWR signal. - 4. The $t_{\text{HIFWRWH}}$ (min) is equal to $2 \times t_{\text{pcyc}} + 5$ ns when writing into the HIF index register (HIFIDX) is followed by reading from the registers REG5 to REG0. Page 1236 of 1278 Figure 29.55 HIF Access Timing Figure 29.56 HIFINT/HIFDREQ Timing Figure 29.57 HIFRDY/HIF Pin Enable/Disable Timing ## 29.4.13 EtherC Module Signal Timing ## Table 29.19 EtherC Module Signal Timing Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Max. | Unit | Figure | |--------------------------------|---------------------|------|------|------|--------| | TX-CLK cycle time | $\mathbf{t}_{Tcyc}$ | 40 | _ | ns | _ | | TX-EN output delay time | t <sub>TENd</sub> | 1 | 20 | ns | 29.58 | | MII_TXD[3:0] output delay time | t <sub>MTDd</sub> | 1 | 20 | ns | | | CRS setup time | t <sub>CRSs</sub> | 10 | _ | ns | | | CRS hold time | t <sub>CRSh</sub> | 10 | _ | ns | | | COL setup time | t <sub>COLs</sub> | 10 | _ | ns | 29.59 | | COL hold time | t <sub>colh</sub> | 10 | _ | ns | | | RX-CLK cycle time | t <sub>Rcyc</sub> | 40 | _ | ns | _ | | RX-DV setup time | t <sub>RDVs</sub> | 10 | _ | ns | 29.60 | | RX-DV hold time | t <sub>RDVh</sub> | 10 | _ | ns | | | MII_RXD[3:0] setup time | t <sub>MRDs</sub> | 10 | _ | ns | | | MII_RXD[3:0] hold time | t <sub>mRDh</sub> | 10 | _ | ns | | | RX-ER setup time | t <sub>RERs</sub> | 10 | _ | ns | 29.61 | | RX-ER hold time | t <sub>ren</sub> | 10 | _ | ns | | | MDIO setup time | t <sub>MDIOs</sub> | 10 | _ | ns | 29.62 | | MDIO hold time | t <sub>MDIOh</sub> | 10 | _ | ns | | | MDIO output data hold time* | t <sub>MDIOdh</sub> | 5 | 18 | ns | 29.63 | | WOL output delay time | t <sub>woLd</sub> | 1 | 20 | ns | 29.64 | | EXOUT output delay time | t <sub>EXOUTd</sub> | 1 | 20 | ns | 29.65 | Note: \* Operate the internal register (PIR) in PHY block to meet the requirement of this specification. Figure 29.58 MII Transmit Timing (during Normal Operation) Figure 29.59 MII Transmit Timing (in the Event of a Collision) Figure 29.60 MII Receive Timing (during Normal Operation) Figure 29.61 MII Receive Timing (in the Event of a Collision) Figure 29.62 MDIO Input Timing Figure 29.63 MDIO Output Timing Figure 29.64 WOL Output Timing Figure 29.65 EXOUT Output Timing ## 29.4.14 H-UDI Related Pin Timing ## Table 29.20 H-UDI Related Pin Timing Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | Symbol | Min. | Max. | Unit | Figure | |----------------------|-----------------|------|------|-----------------|--------| | TCK cycle time | <b>t</b> TCKcyc | 50* | _ | ns | 29.66 | | TCK high pulse width | tтскн | 0.4 | 0.6 | <b>t</b> TCKcyc | _ | | TCK low pulse width | <b>t</b> TCKL | 0.4 | 0.6 | <b>t</b> TCKcyc | _ | | TDI setup time | todis | 10 | _ | ns | 29.67 | | TDI hold time | tтын | 10 | _ | ns | _ | | TMS setup time | tтмss | 10 | _ | ns | _ | | TMS hold time | tтмsн | 10 | _ | ns | _ | | TDO delay time | <b>t</b> tdod | _ | 16 | ns | _ | Note: \* This should be greater than the cycle time for the peripheral clock (Pφ). Figure 29.66 TCK Input Timing Figure 29.67 H-UDI Data Transfer Timing ## 29.4.15 STIF Module Signal Timing (1) ## Table 29.21 STIF Module Signal Timing (1) Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Max. | Unit | Figure | |-----------------------|---------------|--------------------------|------|------|--------------------------|--------------| | STn_CLKIN clock input | Parallel mode | t <sub>st_ckin_cyc</sub> | 2 | 24 | t <sub>bcyc</sub> * | 29.68 | | cycle | Serial mode | _ | 1.25 | 24 | _ | | | STn_CLKIN clock input | Parallel mode | t <sub>st_ckin_h</sub> | 0.4 | 0.6 | t <sub>st_ckin_cyc</sub> | _ | | high pulse width | Serial mode | _ | 0.4 | 0.6 | _ | | | STn_CLKIN clock input | Parallel mode | t <sub>st_ckin_l</sub> | 0.4 | 0.6 | t <sub>st_ckin_cyc</sub> | _ | | low pulse width | Serial mode | _ | 04 | 0.6 | <del>_</del> " | | | STn_CLKIN clock input | Parallel mode | t <sub>ST_CKIN_r</sub> | _ | 2.75 | ns | <del>-</del> | | rise time | Serial mode | _ | _ | 1.75 | <del>_</del> ' | | | STn_CLKIN clock input | Parallel mode | t <sub>ST_CKIN_f</sub> | _ | 2.75 | ns | - | | fall time | Serial mode | _ | _ | 1.75 | _ | | Note: \* t<sub>boyc</sub> indicates the external bus clock (Βφ) cycle. Figure 29.68 STIF Module Signal Timing (1) ## 29.4.16 STIF Module Signal Timing (2) ## Table 29.22 STIF Module Signal Timing (2) Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss} (PLL) = DG12 = UG12 = V_{ss}Q = DG33 = AG12 = AG33 = 0 V,$$ Ta = -20 to $70^{\circ}$ C (regular specifications), -40 to 85°C (wide temperature specifications) | Item | | Symbol | Min. | Max. | Unit | Figure | |-------------------------|---------------|---------------------------|------|------|---------------------|--------| | ST_CLKOUT clock | Parallel mode | t <sub>st_ckout_cyc</sub> | 2 | 24 | t <sub>bcyc</sub> * | 29.69 | | output cycle | Serial mode | _ | 1 | 24 | | | | ST_CLKOUT clock | Parallel mode | t <sub>st_ckout_h</sub> | 6.75 | _ | ns | _ | | output high pulse width | Serial mode | _ | 3 | _ | | | | ST_CLKOUT clock | Parallel mode | t <sub>st_ckout_l</sub> | 6.75 | _ | ns | _ | | output low pulse width | Serial mode | _ | 3 | _ | <del>_</del> | | | ST_CLKOUT clock | Parallel mode | t <sub>st_ckout_r</sub> | | 2.75 | ns | _ | | output rise time | Serial mode | _ | _ | 2.75 | <del>_</del> | | | ST_CLKOUT clock | Parallel mode | t <sub>st_ckout_f</sub> | _ | 2.75 | ns | _ | | output fall time | Serial mode | _ | _ | 2.75 | _ | | Note: \* t<sub>boyc</sub> indicates the external bus clock (Βφ) cycle. Figure 29.69 STIF Module Signal Timing (2) ## 29.4.17 STIF Module Signal Timing (3) (With Stream Input/Output Set Synchronized with STn\_CLKIN Rise Time) ## Table 29.23 STIF Module Signal Timing (3) Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Symbol | Min. | Max. | Unit | Figure | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | t <sub>STSD1</sub> | _ | 11 | ns | 29.70 | | t <sub>STVD1</sub> | _ | 11 | ns | | | t <sub>STRD1</sub> | _ | 11 | ns | | | t <sub>STDD1</sub> | _ | 11 | ns | | | t <sub>stss1</sub> | 4 | _ | ns | <del></del> | | t <sub>stsh1</sub> | 3 | _ | ns | | | t <sub>stvs1</sub> | 4 | _ | ns | | | t <sub>stvh1</sub> | 3 | _ | ns | | | t <sub>STRS1</sub> | 4 | _ | ns | | | t <sub>STRH1</sub> | 3 | _ | ns | <del></del> | | t <sub>stds1</sub> | 4 | _ | ns | <del></del> | | t <sub>stdH1</sub> | 3 | _ | ns | <del></del> | | | t <sub>STSD1</sub> t <sub>STSD1</sub> t <sub>STRD1</sub> t <sub>STRD1</sub> t <sub>STRD1</sub> t <sub>STSS1</sub> t <sub>STSS1</sub> t <sub>STSS1</sub> t <sub>STSS1</sub> t <sub>STVS1</sub> t <sub>STVS1</sub> t <sub>STNS1</sub> t <sub>STRS1</sub> t <sub>STRS1</sub> t <sub>STRS1</sub> | t <sub>STSD1</sub> — t <sub>STSD1</sub> — t <sub>STRD1</sub> — t <sub>STRD1</sub> — t <sub>STSD1</sub> 4 t <sub>STSS1</sub> 4 t <sub>STSH1</sub> 3 t <sub>STVS1</sub> 4 t <sub>STVH1</sub> 3 t <sub>STRS1</sub> 4 t <sub>STRS1</sub> 4 t <sub>STRH1</sub> 3 t <sub>STDS1</sub> 4 t 4 t <sub>STDS1</sub> 4 | t <sub>STSD1</sub> — 11 t <sub>STVD1</sub> — 11 t <sub>STD1</sub> — 11 t <sub>STD1</sub> — 11 t <sub>STD1</sub> — 11 t <sub>STSS1</sub> 4 — t <sub>STSH1</sub> 3 — t <sub>STVH1</sub> 3 — t <sub>STRS1</sub> 4 — t <sub>STRH1</sub> 3 — t <sub>STRH1</sub> 3 — t <sub>STDS1</sub> 4 — t 3 — | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | Figure 29.70 STIF Module Signal Timing (3) ## 29.4.18 STIF Module Signal Timing (4) (With Stream Input/Output Set Synchronized with STn\_CLKIN Fall Time) ## **Table 29.24 STIF Module Signal Timing (4)** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Symbol | Min. | Max. | Unit | Figure | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | t <sub>stsd2</sub> | _ | 11 | ns | 29.71 | | t <sub>STVD2</sub> | _ | 11 | ns | | | t <sub>STRD2</sub> | _ | 11 | ns | | | t <sub>STDD2</sub> | _ | 11 | ns | <del></del> | | t <sub>stss2</sub> | 4 | _ | ns | <del></del> | | t <sub>stsh2</sub> | 3 | _ | ns | | | t <sub>stvs2</sub> | 4 | _ | ns | | | t <sub>STVH2</sub> | 3 | _ | ns | | | t <sub>STRS2</sub> | 4 | _ | ns | | | t <sub>STRH2</sub> | 3 | _ | ns | <del></del> | | t <sub>STDS2</sub> | 4 | _ | ns | <del></del> | | t <sub>STDH2</sub> | 3 | _ | ns | | | | t <sub>STSD2</sub> t <sub>STVD2</sub> t <sub>STRD2</sub> t <sub>STRD2</sub> t <sub>STSD2</sub> t <sub>STSS2</sub> t <sub>STSH2</sub> t <sub>STVH2</sub> t <sub>STVH2</sub> t <sub>STRH2</sub> t <sub>STRH2</sub> t <sub>STRH2</sub> | t <sub>STSD2</sub> — t <sub>STVD2</sub> — t <sub>STND2</sub> — t <sub>STDD2</sub> — t <sub>STSS2</sub> 4 t <sub>STSS2</sub> 4 t <sub>STSH2</sub> 3 t <sub>STVS2</sub> 4 t <sub>STVS2</sub> 4 t <sub>STVH2</sub> 3 t <sub>STRS2</sub> 4 t <sub>STRS2</sub> 4 t <sub>STRS2</sub> 4 t <sub>STRS2</sub> 4 t <sub>STRS2</sub> 4 | t <sub>STSD2</sub> — 11 t <sub>STVD2</sub> — 11 t <sub>STD2</sub> — 11 t <sub>STDD2</sub> — 11 t <sub>STDD2</sub> — 11 t <sub>STD2</sub> 4 — t <sub>STSS2</sub> 4 — t <sub>STSH2</sub> 3 — t <sub>STVS2</sub> 4 — t <sub>STVH2</sub> 3 — t <sub>STRS2</sub> 4 — t <sub>STRH2</sub> 3 — t <sub>STDS2</sub> 4 — t 3 — | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | Figure 29.71 STIF Module Signal Timing (4) ## **STIF Module Signal Timing (5)** (With Stream Output Set Synchronized with STn\_CLKOUT Rise Time) ## Table 29.25 STIF Module Signal Timing (5) $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q$ = DV33 = 3.1 to 3.5 V, Conditions: AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss} (PLL) = DG12 = UG12 = V_{ss}Q = DG33 = AG12 = AG33 = 0 V,$ Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Max. | Unit | Figure | |-----------------------------|--------------------|------|------|------|--------| | STn_SYC output delay time 5 | t <sub>STSD5</sub> | _ | 5 | ns | 29.72 | | STn_VLD output delay time 5 | t <sub>STVD5</sub> | _ | 5 | ns | _ | | STn_Dm output delay time 5 | t <sub>STDD5</sub> | _ | 5 | ns | _ | | STn_REQ input setup time 5 | t <sub>STRS5</sub> | 8.5 | _ | ns | _ | | STn_REQ input hold time 5 | t <sub>STRH5</sub> | 0.5 | _ | ns | | Figure 29.72 STIF Module Signal Timing (5) ## 29.4.20 STIF Module Signal Timing (6) (With Stream Output Set Synchronized with STn\_CLKOUT Fall Time) ## Table 29.26 STIF Module Signal Timing (6) Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $$V_{ss} = V_{ss}$$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Max. | Unit | Figure | |-----------------------------|--------------------|------|------|------|--------| | STn_SYC output delay time 6 | t <sub>STSD6</sub> | _ | 5 | ns | 29.73 | | STn_VLD output delay time 6 | t <sub>STVD6</sub> | _ | 5 | ns | | | STn_Dm output delay time 6 | t <sub>STDD6</sub> | | 5 | ns | | | STn_REQ input setup time 6 | t <sub>STRS6</sub> | 8.5 | _ | ns | | | STn_REQ input hold time 6 | t <sub>STRH6</sub> | 0.5 | _ | ns | | Figure 29.73 STIF Module Signal Timing (6) ## 29.4.21 STIF Module Signal Timing (7) ## **Table 29.27 STIF Module Signal Timing (7)** Conditions: $V_{cc} = V_{cc}$ (PLL) = DV12 = UV12 = 1.1 to 1.3 V, $V_{cc}Q = DV33 = 3.1$ to 3.5 V, AV12 = 1.1 to 1.3 V, AV33 = 3.1 to 3.5 V, $V_{ss} = V_{ss}$ (PLL) = DG12 = UG12 = $V_{ss}Q$ = DG33 = AG12 = AG33 = 0 V, Ta = -20 to $70^{\circ}$ C (regular specifications), | Item | Symbol | Min. | Max. | Unit | Figure | |---------------------------|--------------------|------|------|------|--------| | STn_PWM output delay time | t <sub>STPWD</sub> | _ | 15 | ns | 29.74 | Figure 29.74 STIF Module Signal Timing (7) #### 29.4.22 AC Characteristics Measurement Conditions - Input/output signal reference levels: $V_{cc}Q/2$ ( $V_{cc}Q = 3.1$ to 3.5 V, $V_{cc} = 1.1$ to 1.3 V) - Input pulse level: V<sub>ss</sub>Q to 3.0 V (where EXTAL, CKIO, ST1\_CLKIN/SSISCK1, ST0\_CLKIN/SSISCK0, ST1\_VCO\_CLKIN/AUDIO\_CLK, ST0\_VCO\_CLKIN, RES, TRES, ASEMD, TESTMD, MD\_BW, MD\_CK1, MD\_CK0, NMI, and PB07 to PB00 are within V<sub>ss</sub>Q to V<sub>cc</sub>Q) - Input rise and fall times: 1 ns Figure 29.75 Output Load Circuit # Appendix ## A. Pin States | Pin Func | tion | Pin State | | | | | |-----------------|--------------|------------------------------------------|--------------------------------------|-------------------------|-----------|----------------------------| | Туре | Pin Name | Reset State | | Power-Do | wn State | | | | | Power-On<br>Reset (Non-HIF<br>Boot Mode) | Power-On<br>Reset (HIF<br>Boot Mode) | Software<br>Standby | Sleep | H-UDI<br>Module<br>Standby | | Clock | EXTAL | EX/OS*1 | EX/OS*1 | XZ | EX/OS*1 | EX/OS*1 | | | XTAL | O/OS*1 | O/OS*1 | XZ | O/OS*1 | O/OS*1 | | | CKIO | I/O/Z*1 | I/O/Z*1 | Z | I/O/Z*1*2 | I I/O/Z*1*2 | | System | RES | ı | I | ļ | I | I | | control | WDTOVF | Н | Н | 0 | 0 | 0 | | Operating | TESTMD | ı | I | ļ | I | I | | mode<br>control | MD_BW | ı | I | ļ | I | I | | CONTROL | MD_CK1 | I | I | ļ | I | I | | | MD_CK0 | I | I | I | I | I | | Interrupt | NMI | I | I | I | I | I | | | IRQ[7:0] | _ | _ | ļ | I | I | | Address<br>bus | A[25:17] | _ | _ | Z* <sup>4</sup> | 0 | 0 | | | A[16:0] | 0 | 0 | Z* <sup>4</sup> | 0 | 0 | | Data bus | D[31:0] | Z | Z | Z | I/O | I/O | | Bus<br>control | WAIT | _ | _ | I | I | I | | | IOIS16 | _ | _ | I | I | I | | | CKE | Z | Z | <b>Z</b> * <sup>5</sup> | 0 | 0 | | | CAS RAS | Z | Z | <b>Z</b> * <sup>5</sup> | 0 | 0 | | | WE0/DQMLL | Z | Z | Z* <sup>4</sup> | 0 | 0 | | | WE1/DQMLU/WE | Z | Z | Z* <sup>4</sup> | 0 | 0 | | | WE2/DQMUL/ | Z | Z | Z* <sup>4</sup> | 0 | 0 | Appendix SH7670 Group | Pin Function | | Pin State | | | | | |----------------|----------------------|------------------------------------------|--------------------------------------|---------------------|-------|----------------------------| | Туре | Pin Name | Reset State | Power-Down State | | | | | | | Power-On<br>Reset (Non-HIF<br>Boot Mode) | Power-On<br>Reset (HIF<br>Boot Mode) | Software<br>Standby | Sleep | H-UDI<br>Module<br>Standby | | Bus<br>control | WE3/DQMUU/<br>ICIOWR | Z | Z | Z* <sup>4</sup> | 0 | 0 | | | RD | Н | Н | Z*4 | 0 | 0 | | | RDWR | Z | Z | Z*4 | 0 | 0 | | | CS0 | Н | Н | Z*4 | 0 | 0 | | | CE2B CE2A | _ | _ | Z*4 | 0 | 0 | | | CS6/CE1B<br>CS5/CE1A | _ | _ | Z* <sup>4</sup> | 0 | 0 | | | CS4 | _ | _ | Z*4 | 0 | 0 | | | CS3 | Z | Z | Z*4 | 0 | 0 | | | BS | _ | _ | Z*4 | 0 | 0 | | Ether | MII_RXD[3:0] | _ | _ | I/Z*3 | I | I | | | MII_TXD[3:0] | _ | _ | O/Z*3 | 0 | 0 | | | RX_DV | _ | _ | I/Z*3 | I | I | | | RX_ER | _ | _ | I/Z*3 | I | I | | | RX_CLK | _ | _ | I/Z*3 | I | I | | | TX_ER | _ | _ | O/Z*3 | 0 | 0 | | | TX_EN | _ | _ | O/Z*3 | 0 | 0 | | | TX_CLK | _ | _ | I/Z*3 | I | I | | | COL | _ | _ | I/Z*3 | I | I | | | CRS | _ | _ | I/Z*3 | I | I | | | MDIO | _ | _ | I/O/Z*3 | I/O | I/O | | | MDC | _ | _ | O/Z*3 | 0 | 0 | | | LNKSTA | _ | _ | I/Z*3 | I | I | | | EXOUT | _ | _ | O/Z*3 | 0 | 0 | | | WOL | _ | _ | O/Z*3 | 0 | 0 | | USB | DP | I/O | I/O | I/O | I/O | I/O | | | DM | I/O | I/O | I/O | I/O | I/O | | | VBUS | I | I | ı | I | 1 | | Pin Function | | Pin State | | | | | | | |--------------|-------------------|------------------------------------------|--------------------------------------|---------------------|----------|----------------------------|--|--| | Туре | Pin Name | Reset State | | Power-Do | wn State | | | | | | | Power-On<br>Reset (Non-HIF<br>Boot Mode) | Power-On<br>Reset (HIF<br>Boot Mode) | Software<br>Standby | Sleep | H-UDI<br>Module<br>Standby | | | | USB | USB_X1 | EX/OS*1 | EX/OS*1 | XZ | EX/OS*1 | EX/OS*1 | | | | | USB_X2 | O/OS*1 | O/OS*1 | XZ | O/OS*1 | O/OS*1 | | | | | REFRIN | _ | _ | _ | _ | _ | | | | STIF | ST_CLKOUT | Z | Z | O/Z*3 | 0 | 0 | | | | | ST[1:0]_CLKIN | Z | Z | I/Z*3 | I | I | | | | | ST[1:0]_VCO_CLKIN | Z | Z | I/Z*3 | I | I | | | | | ST[1:0]_PWM | 0 | 0 | O/Z*3 | 0 | 0 | | | | | ST[1:0]_SYC | _ | _ | I/O/Z*3 | I/O | I/O | | | | | ST[1:0]_VLD | _ | _ | Z | I/O | I/O | | | | | ST[1:0]_REQ | _ | _ | Z | I/O | I/O | | | | | ST[1:0]_D[7:0] | _ | _ | Z | I/O | I/O | | | | Host-I/F | HIFEBL | _ | Z | I/Z*3 | I | I | | | | | HIFRDY | _ | L | O/Z*3 | 0 | O*6 | | | | | HIFDREQ | _ | Z | O/Z*3 | 0 | O*6 | | | | | HIFINT | _ | Z | O/Z*3 | 0 | O*6 | | | | | HIFRD | _ | Z | I/Z*3 | I | <b> </b> * <sup>6</sup> | | | | | HIFWR | _ | Z | I/Z*3 | I | <b> </b> * <sup>6</sup> | | | | | HIFRS | _ | Z | I/Z*3 | I | <b> </b> * <sup>6</sup> | | | | | HIFCS | _ | Z | I/Z*3 | I | <b> </b> * <sup>6</sup> | | | | | HIFD[15:0] | _ | Z | I/O/Z*3 | I/O | I/O* <sup>6</sup> | | | | | HIFMD | 1 | I | _ | _ | _ | | | | IIC | SCL | _ | _ | Z | I/O | I/O | | | | | SDA | _ | _ | Z | I/O | I/O | | | | SSI | AUDIO_CLK | _ | _ | I | I | I | | | | | SSI_SCK[1:0] | _ | _ | K/Z*3 | I/O | I/O | | | | | SSI_WS[1:0] | _ | _ | K/Z*3 | I/O | I/O | | | | | SSI_DATA[1:0] | _ | _ | K/Z*3 | I/O | I/O | | | | SCIF | TxD[2:0] | _ | _ | O/Z*3 | O/Z | Z | | | | | RxD[2:0] | _ | _ | K/Z*3 | I | I | | | | | | | | | | | | | | Pin Function | | Pin State | | | | | |--------------|-------------------|------------------------------------------|--------------------------------------|---------------------|--------------------|----------------------------| | Туре | Pin Name | Reset State | | Power-Do | wn State | | | | | Power-On<br>Reset (Non-HIF<br>Boot Mode) | Power-On<br>Reset (HIF<br>Boot Mode) | Software<br>Standby | Sleep | H-UDI<br>Module<br>Standby | | SCIF | SCK[2:0] | _ | _ | K/Z*3 | I/O | I | | | RTS[2:0] | _ | _ | K/Z*3 | I/O | | | | CTS[2:0] | _ | _ | K/Z*3 | I/O | I/O | | DMAC | DACK[1:0] | _ | _ | Z | 0 | 0 | | | DREQ[1:0] | _ | _ | Z | I | I | | | TEND[1:0] | _ | _ | Z | 0 | 0 | | SDHI | SDCLK | _ | _ | O/Z*3 | 0 | 0 | | | SDCMD | _ | _ | K/Z*3 | I/O | I/O | | | SDCD | _ | _ | Z | I | [ | | | SDWP | _ | _ | Z | I | I | | | SDDAT[3:0] | _ | _ | K/Z*3 | I/O | I/O | | H-UDI | TRST | PI | PI | PI | PI | PI | | | TCK | 1 | I | I | I | I | | | TMS | PI | PI | PI | PI | PI | | | TDI | PI | PI | PI | PI | PI | | | TDO | Z | Z | Z | Z | Z | | | ASEBRK/ASEBRKAK | I/PI* <sup>7</sup> | I/PI* <sup>7</sup> | I/PI* <sup>7</sup> | I/PI* <sup>7</sup> | I/PI* <sup>7</sup> | | | ASEMD | 1 | I | ļ | I | I | | I/O port | PA[25:17] [25] | I | I | K/Z*3 | I/O | I/O | | | [24:17] | Z | Z | K/Z*3 | I/O | I/O | | | PB[07:00] [01:00] | 1 | I | I | I/O | I/O | | | [07:02] | Z | Z | K/Z*3 | I/O | I/O | | | PC[20:00] | Z | Z | K/Z*3 | I/O | I/O | | | PD[07:00] | 1 | I | K/Z*3 | I/O | I/O | | | PE[11:00] [11] | _ | _ | K/Z*3 | I/O | I/O | | | [10:0] | Z | Z | K/Z*3 | I/O | I/O | | | PF[11:00] [11] | _ | _ | K/Z*3 | I/O | I/O | | | [10:0] | Z | Z | K/Z*3 | I/O | I/O | | | PG[23:00] | Z | Z | K/Z*3 | I/O | I/O | ### [Legend] —: This pin function is never selected as the initial state. I: Input O: Output EX: External clock input OS: Oscillated by a crystal oscillator XZ: Standby state H: High-level output L: Low-level output Z: High-impedance K: The pin retains its state. PI: Input enabled and pull-up state #### Notes: 1. Depends on clock mode. - 2. Depends on the setting of the CKOEN bits (bits 1 and 0) of the FRQCR register. - 3. Depends on the settings of the IOR register bits of the general-purpose port and the HIZ bit of the STBCR3 register. - 4. Depends on the HIZMEM bit of the CMNCR register. - 5. Depends on the HIZCNT bit of the CMNCR register. - 6. High impedance when HIFEBL is set to the low level. - PI in non-ASE mode (when ASEMD = H input), I in ASE mode (when ASEMD = L input). Appendix SH7670 Group ## **B.** Product Lineup | Type Code | Catalog Code | Operating temperature | Chemical composition of solder balls | Package Code | |----------------|----------------|-----------------------|--------------------------------------|--------------| | R5S76700B200BG | R5S76700B200BG | -20 to +70°C | Lead-free | PRBG0256GA-A | | R5S76710B200BG | R5S76710B200BG | -20 to +70°C | Lead-free | PRBG0256GA-A | | R5S76720B200BG | R5S76720B200BG | -20 to +70°C | Lead-free | PRBG0256GA-A | | R5S76730B200BG | R5S76730B200BG | -20 to +70°C | Lead-free | PRBG0256GA-A | | R5S76700D133BG | R5S76700D133BG | -40 to +85°C | Lead-free | PRBG0256GA-A | | R5S76710D133BG | R5S76710D133BG | -40 to +85°C | Lead-free | PRBG0256GA-A | | R5S76720D133BG | R5S76720D133BG | -40 to +85°C | Lead-free | PRBG0256GA-A | | R5S76730D133BG | R5S76730D133BG | -40 to +85°C | Lead-free | PRBG0256GA-A | #### C. **Package Dimensions** Figure C.1 Package Dimensions #### D. **Treatment of Unused Pins** Table D.1 **Treatment of Unused Pins** #### **Pin Functions** #### **Treatment of Unused Pins** | Classification | Symbol | Non-HIF Boot Mode | HIF Boot Mode | | |----------------|------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--| | Clock | EXTAL | Clock mode 0: These pins should be used. Clock mode 1: These pins should be used. Clock mode 2: Pull-up Clock mode 3: Pull-up | Clock mode 0: These pins should be used. Clock mode 1: These pins should be used. Clock mode 2: Pull-up Clock mode 3: Pull-up | | | | XTAL | Clock mode 0: These pins should be used. Clock mode 1: These pins should be used. Clock mode 2: Open Clock mode 3: Open | Clock mode 0: These pins should be used. Clock mode 1: These pins should be used. Clock mode 2: Open Clock mode 3: Open | | | | CKIO | Clock mode 0: Open Clock mode 1: Open Clock mode 2: These pins should be used. Clock mode 3: Open | Clock mode 0: Open Clock mode 1: Open Clock mode 2: These pins should be used. Clock mode 3: Open | | | System control | RES | These pins should be used. | These pins should be used. | | | | WDTOVF | Open | Open | | | Operating mode | TESTMD | These pins should be used. | These pins should be used. | | | control | MD_BW | These pins should be used. | These pins should be used. | | | | MD_CK1 | These pins should be used. | These pins should be used. | | | | MD_CK0 | These pins should be used. | These pins should be used. | | | Interrupts | NMI | Pull-up | Pull-up | | | | IRQ[7:0] | _ | _ | | | Address bus | A[25:17] | _ | _ | | | | A[16:0] | Open | Open | | | Data bus | D[31:0] | Open | Open | | | Bus control | WAIT | _ | _ | | | | IOIS16 | _ | _ | | | | CKE | Open | Open | | | | CAS, RAS | Open | Open | | | | WE0/DQMLL | Open | Open | | | | WE1/DQMLU/ | Open | Open | | | | | | | | #### Pin Functions #### **Treatment of Unused Pins** | Classification | Symbol | Non-HIF Boot Mode | HIF Boot Mode | |----------------|----------------------|-----------------------------------------|-----------------------------------------| | Bus control | WE2/DQMUL/<br>ICIORD | Open | Open | | | WE3/DQMUU/ | Open | Open | | | RD | Open | Open | | | RD/WR | Open | Open | | | CS0 | Open | Open | | | CE2B, CE2A | _ | _ | | | CS6/CE1B | _ | _ | | | CS5/CE1A | _ | _ | | | CS4 | _ | _ | | | CS3 | Open | Open | | | BS | _ | _ | | Ether | MII_RXD[3:0] | _ | _ | | | MII_TXD[3:0] | _ | _ | | | RX_DV | _ | _ | | | RX_ER | _ | _ | | | RX_CLK | _ | _ | | | TX_ER | _ | _ | | | TX_EN | _ | _ | | | TX_CLK | _ | _ | | | COL | _ | _ | | | CRS | _ | _ | | | MDIO | _ | _ | | | MDC | _ | _ | | | LNKSTA | _ | _ | | | EXOUT | _ | _ | | | WOL | _ | _ | | USB | DP | These pins should be connected to DG33. | These pins should be connected to DG33. | | | DM | These pins should be connected to DG33. | These pins should be connected to DG33. | | | VBUS | These pins should be connected to DG33. | These pins should be connected to DG33. | Appendix SH7670 Group #### Pin Functions Treatment of Unused Pins Classification Symbol Non-HIF Boot Mode **HIF Boot Mode** USB USB\_X1 Clock Mode 0: Pull-up Clock Mode 0: Pull-up Clock Mode 1: Pull-up Clock Mode 1: Pull-up Clock Mode 2: Pull-up Clock Mode 2: Pull-up Clock Mode 3: These pins should be used. Clock Mode 3: These pins should be used. USB\_X2 Clock Mode 0: Open Clock Mode 0: Open Clock Mode 1: Open Clock Mode 1: Open Clock Mode 2: Open Clock Mode 2: Open Clock Mode 3: These pins should be Clock Mode 3: These pins should be used. / Open used. / Open REFRIN STIF ST\_CLKOUT Open Open ST[1:0]\_CLKIN Pull-up Pull-up ST[1:0]\_ Pull-up Pull-up VCO\_CLKIN ST[1:0]\_PWM Open Open ST[1:0]\_SYC ST[1:0]\_VLD ST[1:0]\_REQ ST[1:0]\_D[7:0] Host-I/F **HIFEBL** These pins should be used. **HIFRDY** These pins should be used. **HIFDREQ** These pins should be used. HIFINT These pins should be used. **HIFRD** These pins should be used. **HIFWR** These pins should be used. **HIFRS** These pins should be used. **HIFCS** These pins should be used. HIFD[15:0] These pins should be used. **HIFMD** These pins should be used. These pins should be used. IIC SCL SDA SSI AUDIO\_CLK SSI\_SCK[1:0] SSI\_WS[1:0] #### Pin Functions #### **Treatment of Unused Pins** | Classification | Symbol | Non-HIF Boot Mode | HIF Boot Mode | |----------------|---------------------|----------------------------|----------------------------| | SSI | SSI_DATA[1:0] | _ | _ | | SCIF | TxD[2:0] | _ | — | | | RxD[2:0] | _ | _ | | | SCK[2:0] | _ | _ | | | RTS[2:0] | _ | _ | | | CTS[2:0] | _ | _ | | DMAC | DACK[1:0] | _ | _ | | | DREQ[1:0] | _ | _ | | | TEND[1:0] | _ | _ | | SDHI | SDCLK | _ | _ | | | SDCMD | _ | _ | | | SDCD | _ | _ | | | SDWP | _ | _ | | | SDDAT[3:0] | _ | _ | | H-UDI | TRST | These pins should be used. | These pins should be used. | | | TCK | Pull-up | Pull-up | | | TMS | Open | Open | | | TDI | Open | Open | | | TDO | Open | Open | | | ASEBRK/<br>ASEBRKAK | Open | Open | | | ASEMD | These pins should be used. | These pins should be used. | | I/O port | PA[25] | These pins should be used. | These pins should be used. | | | PA[24:17] | Pull-up | Pull-up | | | PB[01:00] | Pull-up | Pull-up | | | PB[07:02] | Pull-up | Pull-up | | | PC[20:00] | Pull-up | Pull-up | | | PD[07:00] | Pull-up | Pull-up | | | PE[11] | _ | _ | | | PE[10:0] | Pull-up | Pull-up | | | PF[11] | _ | _ | | | PF[10:0] | Pull-up | Pull-up | Appendix SH7670 Group | Pin Functions | | Treatment of | of Unused Pins | |----------------|-----------|-------------------|----------------| | Classification | Symbol | Non-HIF Boot Mode | HIF Boot Mode | | I/O port | PG[23:00] | Pull-up | _ | ## [Legend] —: This pin function is not selected as the initial state. # Main Revisions and Additions in this Edition ## Changes in Rev. 3.00 Compared to Rev. 2.00 | Item | Page | Revision (S | ee Mar | ual for | Details) | | | |----------------------------------|------|------------------------|--------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------|--|--| | Table 1.1 Overview of | 5 | Added | | | | | | | SH7670 Group Specifications | | Classification | Classification Module/Function Description | | | | | | | | External bus extension | Bus state | | <ul> <li>Address space for five areas (64<br/>Mbytes each) and 32-bit external<br/>bus</li> </ul> | | | | | | | | | For area 0, only big endian is<br>supported | | | | Figure 1.2 Block Diagram | 13 | Added | | | | | | | Figure 1.3 Pin Assignments | 14 | Amended | | | | | | | | | U4 pin: "Vss | Q_02" | → "Vss_ | 02" | | | | Table 1.4 List of I/O Attributes | | Amended | | | | | | | of Each Pin | 25 | Pin Number | Fund | ction Nan | ne I/O Attribute | | | | | | A18 | RAS | | 0 | | | | | | D16 | V <sub>ss</sub> Q | _11 | Power | | | | | | G17 | V <sub>cc</sub> C | _09 | Power | | | | | | G18 | D31 | | IO | | | | | | G19 | D23 | | IO | | | | | | G20 | D22 | | 10 | | | | 5.5.2 Interrupt Priority Level | 123 | Amended | | | | | | | | | cannot be se | et. See<br>16 (IP | section 6 | be set are 0 to 15. Level 16<br>6.3.1, Interrupt Priority Registers<br>802, IPR06 to IPR16), for details<br>to IPR16. | | | | Table 5.9 Interrupt Priority | 123 | Amended | | | | | | | Order | | Туре | | Priority<br>Level | Comment | | | | | | IRQ | | 0 to 15 | Set with interrupt priority registers | | | | | | On-chip peri<br>module | pheral | | 01, 02, and 06 to 16 (IPR01, IPR02, and IPR06 to IPR16). | | | Figure 6.1 Block Diagram of INTC 134 Amended #### 7.1 Features 171 Added For area 0, only big endian is supported. ### 7.4.2 CSn Space Bus Control 184 Register (CSnBCR) (n = 0, 3 to 6) Added # Bit Bit Name Description **ENDIAN** Endian Setting 11 Specifies the arrangement of data in a space. 0: Arranged in big endian 1: Arranged in little endian Note: Area 0 cannot be set to little endian mode. In the case of area 0, this bit is always read as 0, and the write value should always be 0. ## 7.4.3 CSn Space Wait Control 194 Register (CSnWCR) (n = 0, 3to 6) (1) Normal Space, SRAM with **Byte Selection** CS5WCR #### Amended | Bit | Bit Name | Initial<br>Value | R/W | Description | |----------|----------|------------------|-----|-------------------------------------------------------------------------| | 31 to 21 | _ | All 0 | R | Reserved | | | | | | These bits are always read as 0.<br>The write value should always be 0. | | Item | Page | Revision (See Manual for Details) | | |---------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 8.4.5 Number of Bus Cycles<br>and DREQ Pin Sampling<br>Timing | 341 | Amended Figures 8.13 to 8.17 show cases in which DACK and TEND are not divided at the time of DMA transfer. | | | (2) DREQ Pin Sampling<br>Timing | | | | | 13.3.1 (1) (b) Transmit | 476 | In bit figure, bits 31 to 16 amended | | | Descriptor 1 (TD1) | | $R/W: "R" \rightarrow "R/W"$ | | | Table14.6 AES Operation Cycles | 534 | Deleted | | | Table14.7 Encryption Operating Modes | 534,<br>535 | Deleted | | | 14.3.1 DMAC Channel | 535 | Deleted | | | Function | | If the AES encryption/decryption function is used by the DMAC channel, the A DMAC uses the descriptors to update keys and initial vectors. The A-DMAC can also use the descriptors to output the intermediate values (intermediate result) of the initial vectors obtained when encryption/decryption was performed in encryption eperating mode other than EGB. | | | 16.4.1 Bus Format | 608 | Deleted | | | | | The bus format can be selected from one of the <del>eight major</del> modes shown in table 16.4. | | | Table 17.16 Types of Reset | 764 | Amended | | | | | Name Operation | | | | | Power-on reset Low level input from the RES pin | | | 17.5.4 Usage Precautions of<br>USB Disconnection Process<br>at the Time of Using the<br>Function Controller Function<br>and Full-Speed Operations | 834,<br>835 | Added | | | 19.3.1 I <sup>2</sup> C Bus Control | 843 | Amended | | | Register 1 (ICCR1) | | Bit Bit Name Description | | | | | 7 ICE I <sup>2</sup> C Bus Interface 3 Enable | | | | | 0: SCL and SDA output is disabled. (Input to SCL and SDA is enabled.) | | | | | 1: This bit is enabled for transfer operations. (SCL and SDA pins are bus drive state.) | | | Item | Page | Revision (See Manual for Details) | |-----------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------| | 19.7.5 Note Regarding<br>Master Receive Mode of I <sup>2</sup> C-<br>Bus Interface Mode | 880 | Added | | 19.7.6 Accessing ICE and IICRST during I <sup>2</sup> C Bus Operation | 881,<br>882 | Added | | 23.1.4 Port B Control Register<br>L1 (PBCRL1) | 1017 | Amended Bit: 15 | | 23.1.10 Port E Control Registers L2 and L1 (PECRL2, PECRL1) • PECRL2 | 1030 | Amended Bit: 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | PECRL1 | 1032 | Amended Bit: 15 | | 23.1.12 Port F Control Registers L2 and L1 (PFCRL2, PFCRL1) • PFCRL1 | 1037 | Amended Bit: 15 | | 23.1.14 Port G Control Registers H2, L2, and L1 (PGCRH2, PGCRL2, PGCRL1) • PGCRL1 | 1046 | Amended Bit: 15 | | Item | Page | Revision (See Manual for Details) | |-----------------------------|--------------------|-----------------------------------------------------------------------------------------------------------| | Table 29.6 Clock Timing | 1190, | Amended and added | | | 1191 | Item Symbol Min. Max. Unit Figure | | | | EXTAL* clock input fex 15 25* MHz 29.2 frequency | | | | 16.6* <sup>3</sup> | | | | EXTAL*¹ clock input cycle texcyc 40*² 66.6 ns | | | | 60*3 | | | | EXTAL*/AUDIO_CLK clock text. 0.4 0.6 t <sub>excyc</sub> input low-level pulse width | | | | EXTAL**/AUDIO_CLK clock texh 0.4 0.6 t <sub>excyc</sub> input high-level pulse width | | | | EXTAL**/AUDIO_CLK clock texr — 4 ns input rise time | | | | EXTAL**/SSI_CLK clock text — 4 ns input fall time | | | | CKIO clock input frequency fck 60 100 <sup>32</sup> MHz 29.3 | | | | 66.6*3 | | | | CKIO clock input cycle time tcklcyc 10*2 16.6 ns | | | | 15*° | | | | CKIO clock output frequency for 60 100 MHz 29.4 | | | | 66.6* <sup>3</sup> | | | | CKIO clock output cycle time t <sub>cyc</sub> 10** <sup>2</sup> 16.6 ns | | | | 15* <sup>3</sup> | | | | Notes: 1. When the clock operating mode is 0 2. Regular specifications 3. Wide temperature specifications | | D. Treatment of Unused Pins | 1260<br>to<br>1264 | Added | ## Index | Numerics | Break on data access cycle | . 1086 | |--------------------------------------|---------------------------------------|--------| | 16-bit/32-bit displacement | Break on instruction fetch cycle | . 1085 | | | Burst mode | 336 | | | Burst read | 246 | | A | Burst write | | | Absolute address | Bus format for SSI module | 608 | | Absolute address accessing | Bus state controller (BSC) | 171 | | Absolute maximum ratings 1181 | Bus timing | . 1195 | | AC characteristics | Bus-released state | 75 | | AC characteristics measurement | | | | conditions | | | | Access size and data alignment | $\mathbf{C}$ | | | Access wait control | Cache | 89 | | Accessing MII registers | Calculating exception handling vector | | | Address array | table addresses | 114 | | Address array read | Canceling software standby mode | | | Address errors | (WDT) | 371 | | Address map 176 | Changing the division ratio | 360 | | Address multiplexing | Changing the frequency35 | 9, 371 | | Address-array write | Changing the multiplication rate | 359 | | (associative operation)105 | Clock frequency control circuit | 347 | | Address-array write | Clock operating modes | 351 | | (non-associative operation)104 | Clock pulse generator (CPG) | 345 | | Addressing modes | Clock timing | | | Arithmetic operation instructions 61 | Clocked synchronous serial format | 866 | | Auto-refreshing | CMCNT count timing | 925 | | Auto-request mode | Coherency of cache and external | | | | memory | | | | Compare match timer (CMT) | | | В | Conditions for determining number of | | | Bank active | idle cycles | 284 | | Banked register and input/output of | Conflict between byte-write and | | | banks | count-up processes of CMCNT | 930 | | Bit manipulation instructions | Conflict between word-write and | | | Bit synchronous circuit | count-up processes of CMCNT | 929 | | Branch instructions | Conflict between write and | | | Break detection and processing 993 | compare-match processes of CMCNT | 928 | | Connection to PHY-LSI | Equation for getting SCBRR value | 953 | | |--------------------------------------|---------------------------------------|------|--| | Control signal timing | EtherC module signal timing | 1237 | | | CPU31 | EtherC receiver | 429 | | | Crystal oscillator | EtherC transmitter | 427 | | | CSn assert period expansion | Ethernet controller (EtherC) | 397 | | | Cycle steal mode | Ethernet controller direct memory | | | | | access controller (E-DMAC) | 439 | | | | Exception handling | 109 | | | D | Exception handling state | 75 | | | Data array | Exception handling vector table | 113 | | | Data array read | Exception source generation | | | | Data array write | immediately after delayed branch | | | | Data format in registers | instruction | 129 | | | Data formats in memory | Exceptions triggered by instructions | 125 | | | Data register | External request mode | 323 | | | Data transfer instructions | | | | | Data transfer with interrupt request | | | | | signals168 | ${f F}$ | | | | DC characteristics | Fixed mode | 327 | | | Deep power-down mode | Floating-point exceptions | 87 | | | Delayed branch instructions | Floating-point format | | | | Denormalized numbers | Floating-point operation instruction | 128 | | | Direct memory access controller | Floating-point operation instructions | 69 | | | (DMAC) 293 | Floating-point ranges | 80 | | | Displacement accessing | Floating-point registers | 83 | | | Divider 1 | Floating-point unit (FPU) | | | | Divider 2 | Flow control | 436 | | | DMA transfer flowchart 322 | Format of double-precision | | | | DMAC module timing 1224 | floating-point number | 78 | | | DMAC that works with | Format of single-precision | | | | encryption/decryption and forward | foating-point number | 78 | | | error correction core (A-DMAC) 495 | FPU exception handling | 88 | | | DREQ pin sampling timing | FPU exception sources | 87 | | | Dual address mode | FPU-related CPU instructions | 71 | | | E | G | | | | Effective address calculation | General illegal instructions | 126 | | | Electrical characteristics | General registers | | | | Endian | Global base register (GBR) | | | | 1.71G1G11 | Global base register (GDR) | 33 | | | H | L | |---------------------------------------------|---------------------------------------------| | HIF module signal timing 1235 | Load-store architecture38 | | High-performance user debugging | Logic operation instructions64 | | interface (H-UDI)1093 | Low-power SDRAM268 | | Host interface (HIF) | LRU91 | | H-UDI commands1096 | | | H-UDI interrupt 145, 1100 | | | H-UDI reset | M | | H-UDI-related pin timing 1241 | Magic packet detection435 | | | Manual reset | | | Master receive operation | | I | Master transmit operation | | I/O Port timing | Memory-mapped cache104 | | I/O ports | MII frame timing430 | | I <sup>2</sup> C bus format857 | Module standby function | | I <sup>2</sup> C bus interface 3 (IIC3) 839 | Multi-buffer frame transmit/receive | | IIC3 module timing 1227 | processing487 | | Immediate data | multiplexed pin995 | | Immediate data accessing40 | Multiply and accumulate register high | | Immediate data format | (MACH)34 | | Initial values of control registers35 | Multiply and accumulate register low | | Initial values of general registers35 | (MACL)34 | | Initial values of system registers35 | Multiply/Multiply-and-accumulate | | Instruction features | operations39 | | Instruction format | | | Instruction set | | | Integer division instructions 127 | N | | Interrupt controller (INTC) | NMI interrupt145 | | Interrupt exception handling 124 | Noise filter | | Interrupt exception handling vectors | Non-compressed modes | | and priorities | Non-numbers (NaN)81 | | Interrupt priority level | Normal space interface | | Interrupt response time | Note on inputting external clock | | IRQ interrupts | Note on resonator362 | | | Note on using a PLL oscillation circuit 362 | | | Note on using an external | | J | crystal resonator361 | | Jump table base register (TBR) | | | <b>0</b> | APR | 424 | |------------------------------------------|----------|----------| | On-chip peripheral module interrupts 147 | BAMR | 1077 | | On-chip peripheral module request 325 | BAR | 1076 | | On-chip RAM1103 | BBR | 1080 | | Operation by IPG setting 436 | BDMR | 1079 | | Operation in asynchronous mode 971 | BDR | 1078 | | Operation in clocked synchronous | BEMPENB | 679 | | mode982 | BEMPSTS | 697 | | Output addition circuit 1252 | BRCR | 1082 | | | BRDYENB | 675 | | | BRDYSTS | 694 | | P | BUSWAIT | 645 | | Package12 | CCR1 | 92 | | Padding receive data | CCR2 | 94 | | Page conflict | CDCR | 414 | | PCMCIA interface | CEFCR | 417 | | Pin assignments | CFIFO | 658 | | Pin function controller (PFC) | CFIFOCTR | 667 | | Pin functions | CFIFOSEL | 660 | | PLL circuit347 | CHCR | 303 | | Power-down mode | CMCNT | 924 | | Power-down modes | CMCOR | 924 | | Power-down state | CMCSR | 922 | | Power-on reset | CMNCR | 179 | | Power-on sequence | CMSTR | 921 | | Power-on/power-off sequence 1182 | CnC | 501 | | Prefetch operation | CnD0 | 509 | | (only for operand cache) | CnD1 | 515 | | Procedure register (PR)34 | CnD2 | 516 | | Program counter (PC) | CnD3 | 516, 543 | | Program execution state | CnD4 | 518 | | | CnDCA | 508 | | | CNDCR | 416 | | R | CnDSA | 507 | | Receive data sampling timing and | CnI | 505 | | receive margin (asynchronous mode) 993 | CnM | 504 | | Receive descriptor 0 (RD0)478 | CS0WCR | 186 | | Receive descriptor 1 (RD1) | CS3WCR | 189, 199 | | Receive descriptor 2 (RD2) | CS4WCR | 191 | | Registers 482 | CS5WCR | 194, 203 | | 196, 203 | HIFDATA | 899 | |----------|------------------------------|------| | 181 | HIFDTR | 901 | | 657 | HIFEICR | 897 | | 658 | HIFGSR | 890 | | 667 | HIFIDX | 888 | | 660 | HIFIICR | 896 | | 763 | HIFMCR | 894 | | 657 | HIFSCR | 891 | | 658 | IBCR | 143 | | 667 | IBMPR | 214 | | 660 | IBNR | 144 | | 763 | ICCR1 | 842 | | 302 | ICCR2 | 845 | | 708 | ICDRR | 855 | | 710 | ICDRS | 855 | | 709 | ICDRT | 854 | | 760 | ICIER | 849 | | 315 | ICMR | 847 | | 319 | ICR0 | 139 | | 302 | ICR1 | 140 | | 648 | ICSR | 851 | | 402 | INTENB0 | 671 | | 407 | INTENB1 | 673 | | 405 | INTSTS0 | 683 | | 441 | INTSTS1 | 688 | | 461 | IPGR | 423 | | 444 | IPR01, IPR02, IPR06 to IPR16 | 137 | | 443 | IRQRR | 141 | | 452 | LCCR | 415 | | 447 | MAFCR | 422 | | 464 | MAHR | 409 | | 459 | MALR | 410 | | 84 | MPR | 425 | | 85 | NF2CYC | 856 | | 418 | NRDYENB | 677 | | 698 | NRDYSTS | 695 | | 356 | PACRH1 | 1013 | | 898 | PACRH2 | 1013 | | 899 | PADRH | 1050 | | 902 | PAIORH | 1012 | | | | 181 | | PBCRL1 1017 | RDMATCR | 314 | |--------------|------------|------| | PBCRL2 1017 | RFCR | 421 | | PBDRL 1053 | RFLR | 411 | | PBIORL1016 | RMCR | 460 | | PCCRH21020 | RMFCR | 457 | | PCCRL1 1020 | RSAR | 312 | | PCCRL2 1020 | RTCNT | 212 | | PCDRH1056 | RTCOR | 213 | | PCDRL 1056 | RTCSR | 210 | | PCIORH 1019 | SAR (DMAC) | 301 | | PCIORL1019 | SAR (IIC3) | 854 | | PDCRL2 1027 | SCBRR | 953 | | PDDRL1060 | SCFCR | 960 | | PDIORL1026 | SCFDR | 963 | | PECRL11030 | SCFRDR | 936 | | PECRL2 | SCFSR | 945 | | PEDRL 1063 | SCFTDR | 937 | | PEIORL 1029 | SCLSR | 967 | | PFCRL11035 | SCRSR | 936 | | PFCRL2 | SCSCR | 941 | | PFDRL1066 | SCSMR | 938 | | PFIORL 1034 | SCSPTR | 964 | | PGCRL1 1040 | SCSR | 607 | | PGCRL2 1040 | SCTSR | 937 | | PGDRL 1069 | SDBPR | 1095 | | PGIORL1039 | SDCR | 207 | | PIPEBUF | SDIR | 1096 | | PIPECFG722 | SOFCFG | 681 | | PIPEMAXP 732 | SSICR | 595 | | PIPEnCTR736 | SSIRDR | 606 | | PIPEnTRE | SSISR | 601 | | PIPEnTRN758 | SSITDR | 606 | | PIPEPERI | STBCR | 379 | | PIPESEL720 | STBCR2 | 380 | | PIR | STBCR3 | 382 | | PSR | STBCR4 | 384 | | RBWAR | STCNTCR | 554 | | RDAR313 | STCNTVR | 555 | | RDFAR463 | STCTLR | 552 | | RDLAR 446 | STDBGR | 572 | | STIER559 | Registers bank exception 16/ | |--------------------------------|---------------------------------------| | STLKCR | Registers banks35, 163 | | STMDR 549 | Relationship between access size and | | STPCR0R 567 | number of bursts246 | | STPCR1R 567 | Relationship between refresh requests | | STPWMCR | and bus cycles | | STPWMMR560 | Reset state75 | | STPWMR 566 | Restoration from bank165 | | STSTC0R 568 | Restoration from stack | | STSTC1R 568 | RISC-type instruction set38 | | STSTR 555 | Round to nearest86 | | SYSCFG641 | Rounding86 | | SYSCR1 | Round-robin mode | | SYSCR2 | | | SYSCR3 | | | SYSSTS646 | S | | TBRAR463 | Saving to bank164 | | TDFAR464 | Saving to stack | | TDLAR445 | SCIF interrupt sources991 | | TESTMODE | SCIF module timing 1226 | | TFTR458 | SD host interface (SDHI)837 | | TIER 558 | SDHI module timing | | TLFRCR | SDRAM interface | | TPAUSER | Searching cache | | TRIMD 467, 469, 470 | Self-refreshing | | TROCR413 | Sending a break signal | | TRSCER | Serial bit clock control | | TSFRCR | Serial communication interface with | | UFRMNUM701 | FIFO (SCIF)931 | | USBADDR702 | Serial sound interface (SSI) | | USBINDX | Shift instructions | | USBLENG707 | Sign extension of word data | | USBREQ 703 | Single address mode | | USBVAL | Single read | | WRCSR | Single write | | WTCNT365 | Slave receive operation | | WTCSR | Slave transmit operation 862 | | Registers bank error exception | Sleep mode | | handling | Slot illegal instructions | | Registers bank errors | Software standby mode 392 | | <u> </u> | Software standoy mode | | SRAM interface with byte selection 27 | | | | |-----------------------------------------|----------------------------------------|--|--| | SSI module timing | priority order | | | | Stack after interrupt exception | | | | | handling156 | 6 | | | | Stack status after exception handling | $\mathbf{U}$ | | | | ends | Chechaitional orange mondetions with | | | | Standby control circuit | 110 4014 5100 | | | | Status register (SR) | USB 2.0 host/function module (USB) 629 | | | | STIF module signal timing 1243 | | | | | Supported DMA transfers | | | | | System control instructions6 | Using interval timer mode | | | | | Using watchdog timer mode | | | | T | | | | | T bit | $\mathbf{v}$ | | | | TAP controller 1097 | Vector base register (VBR)33 | | | | TDO output timing 1099 | | | | | Timing to clear an interrupt source 170 | 0 | | | | Transceiver timing | $\mathbf{w}$ | | | | Transfer rate844 | Wait between access cycles | | | | Transmit descriptor 0 (TD0) | Watchdog timer (WDT) | | | | Transmit descriptor 1 (TD1) | | | | | Transmit descriptor 2 (TD2) | watchdog timer timing | | | | Trap instructions 120 | WILLE-DACK DULLEL | | | SH7670 Group User's Manual: Hardware Publication Date: Rev.1.00 Nov 14, 2007 Rev.3.00 Jun 21, 2011 Published by: Renesas Electronics Corporation ## SALES OFFICES ## Renesas Electronics Corporation http://www.renesas.com Refer to "http://www.renesas.com/" for the latest and detailed information. Renesas Electronics America Inc. 2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130 Renesas Electronics Canada Limited 1101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada Tel: +1-905-898-5441, Fax: +1-905-898-3220 Renesas Electronics Europe Limited Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K Tel: +44-1628-585-109, Fax: +44-1628-585-900 Renesas Electronics Europe GmbH Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-65030, Fax: +49-211-6503-1327 Renesas Electronics (China) Co., Ltd. 7th Floor, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100083, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679 Renesas Electronics (Shanghai) Co., Ltd. Unit 204, 205, AZIA Center, No.1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China Tel: +86-21-8577-1815, Fax: +86-21-8587-7858 / -7898 Renesas Electronics Hong Kong Limited Unit 1601-1613, 161F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tei: +852-2866-9318, Fax: +852-2866-9022/9044 Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670 Renesas Electronics Singapore Pte. Ltd. 1 harbourFront Avenue, #06-10, keppel Bay Tower, Singapore 098632 Tel: +65-6213-0200, Fax: +65-6278-8001 Renesas Electronics Malaysia Sdn.Bhd. Unit 906, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tei: +60-3-7955-9390, Fax +60-3-7955-9510 Renesas Electronics Korea Co., Ltd. 11F., Samik Lavied' or Bldg., 720-2 Yeoksam-Dong, Kangnam-Ku, Seoul 135-080, Korea Tel: +82-2-558-3737, Fax: +82-2-558-5141 SH7670 Group